messenger-cli

Command-line user interface for GNUnet Messenger
Log | Files | Refs | README | LICENSE

lobby_enter_dialog.h (1780B)


      1 /*
      2    This file is part of GNUnet.
      3    Copyright (C) 2022 GNUnet e.V.
      4 
      5    GNUnet is free software: you can redistribute it and/or modify it
      6    under the terms of the GNU Affero General Public License as published
      7    by the Free Software Foundation, either version 3 of the License,
      8    or (at your option) any later version.
      9 
     10    GNUnet is distributed in the hope that it will be useful, but
     11    WITHOUT ANY WARRANTY; without even the implied warranty of
     12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     13    Affero General Public License for more details.
     14 
     15    You should have received a copy of the GNU Affero General Public License
     16    along with this program.  If not, see <http://www.gnu.org/licenses/>.
     17 
     18    SPDX-License-Identifier: AGPL3.0-or-later
     19  */
     20 /*
     21  * @author Tobias Frisch
     22  * @file ui/lobby_enter_dialog.h
     23  */
     24 
     25 #ifndef UI_LOBBY_ENTER_DIALOG_H_
     26 #define UI_LOBBY_ENTER_DIALOG_H_
     27 
     28 #include <stdlib.h>
     29 #include <curses.h>
     30 
     31 struct MESSENGER_Application;
     32 
     33 /**
     34  * @struct UI_LOBBY_ENTER_DIALOG_Handle
     35  */
     36 typedef struct UI_LOBBY_ENTER_DIALOG_Handle
     37 {
     38   WINDOW **window;
     39 
     40   char *error;
     41 
     42   char uri [2048];
     43   int uri_len;
     44   int uri_pos;
     45 } UI_LOBBY_ENTER_DIALOG_Handle;
     46 
     47 /**
     48  * Processes the current key event by the dialog
     49  * to enter a lobby.
     50  *
     51  * @param[in,out] enter_dialog Lobby entry dialog
     52  * @param[in,out] app Application handle
     53  * @param[in] key Key
     54  */
     55 void
     56 lobby_enter_dialog_event(UI_LOBBY_ENTER_DIALOG_Handle *enter_dialog,
     57 		         struct MESSENGER_Application *app,
     58 		         int key);
     59 
     60 /**
     61  * Prints the content of the dialog to enter a
     62  * lobby to its selected window view.
     63  *
     64  * @param[in] enter_dialog Lobby entry dialog
     65  */
     66 void
     67 lobby_enter_dialog_print(UI_LOBBY_ENTER_DIALOG_Handle *enter_dialog);
     68 
     69 #endif /* UI_LOBBY_ENTER_DIALOG_H_ */