messenger-cli

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

lobby_create_dialog.h (1998B)


      1 /*
      2    This file is part of GNUnet.
      3    Copyright (C) 2022--2023 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_create_dialog.h
     23  */
     24 
     25 #ifndef UI_LOBBY_CREATE_DIALOG_H_
     26 #define UI_LOBBY_CREATE_DIALOG_H_
     27 
     28 #include <stdlib.h>
     29 #include <curses.h>
     30 
     31 #include <gnunet/gnunet_chat_lib.h>
     32 #include <gnunet/gnunet_util_lib.h>
     33 
     34 struct MESSENGER_Application;
     35 
     36 /**
     37  * @struct UI_LOBBY_CREATE_DIALOG_Handle
     38  */
     39 typedef struct UI_LOBBY_CREATE_DIALOG_Handle
     40 {
     41   WINDOW *window;
     42   WINDOW **win;
     43 
     44   int line_prev;
     45   int line_next;
     46 
     47   int line_index;
     48   int line_offset;
     49   int line_selected;
     50 
     51   uint64_t selected;
     52 
     53   struct GNUNET_CHAT_Lobby *lobby;
     54   char *uri;
     55 } UI_LOBBY_CREATE_DIALOG_Handle;
     56 
     57 /**
     58  * Processes the current key event by the dialog
     59  * to create a lobby.
     60  *
     61  * @param[in,out] create_dialog Lobby creation dialog
     62  * @param[in,out] app Application handle
     63  * @param[in] key Key
     64  */
     65 void
     66 lobby_create_dialog_event(UI_LOBBY_CREATE_DIALOG_Handle *create_dialog,
     67 		          struct MESSENGER_Application *app,
     68 		          int key);
     69 
     70 /**
     71  * Prints the content of the dialog to create a
     72  * lobby to its selected window view.
     73  *
     74  * @param[in] create_dialog Lobby creation dialog
     75  */
     76 void
     77 lobby_create_dialog_print(UI_LOBBY_CREATE_DIALOG_Handle *create_dialog);
     78 
     79 #endif /* UI_LOBBY_CREATE_DIALOG_H_ */