xref: /freebsd/contrib/ncurses/menu/m_hook.c (revision aae38d10b4eebf81c0942947e8b83a9bb8651d88)
10e3d5408SPeter Wemm /****************************************************************************
2*aae38d10SBaptiste Daroussin  * Copyright (c) 1998-2016,2018 Free Software Foundation, Inc.              *
30e3d5408SPeter Wemm  *                                                                          *
40e3d5408SPeter Wemm  * Permission is hereby granted, free of charge, to any person obtaining a  *
50e3d5408SPeter Wemm  * copy of this software and associated documentation files (the            *
60e3d5408SPeter Wemm  * "Software"), to deal in the Software without restriction, including      *
70e3d5408SPeter Wemm  * without limitation the rights to use, copy, modify, merge, publish,      *
80e3d5408SPeter Wemm  * distribute, distribute with modifications, sublicense, and/or sell       *
90e3d5408SPeter Wemm  * copies of the Software, and to permit persons to whom the Software is    *
100e3d5408SPeter Wemm  * furnished to do so, subject to the following conditions:                 *
110e3d5408SPeter Wemm  *                                                                          *
120e3d5408SPeter Wemm  * The above copyright notice and this permission notice shall be included  *
130e3d5408SPeter Wemm  * in all copies or substantial portions of the Software.                   *
140e3d5408SPeter Wemm  *                                                                          *
150e3d5408SPeter Wemm  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
160e3d5408SPeter Wemm  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
170e3d5408SPeter Wemm  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
180e3d5408SPeter Wemm  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
190e3d5408SPeter Wemm  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
200e3d5408SPeter Wemm  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
210e3d5408SPeter Wemm  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
220e3d5408SPeter Wemm  *                                                                          *
230e3d5408SPeter Wemm  * Except as contained in this notice, the name(s) of the above copyright   *
240e3d5408SPeter Wemm  * holders shall not be used in advertising or otherwise to promote the     *
250e3d5408SPeter Wemm  * sale, use or other dealings in this Software without prior written       *
260e3d5408SPeter Wemm  * authorization.                                                           *
270e3d5408SPeter Wemm  ****************************************************************************/
280e3d5408SPeter Wemm 
290e3d5408SPeter Wemm /****************************************************************************
304a1a9510SRong-En Fan  *   Author:  Juergen Pfeifer, 1995,1997                                    *
310e3d5408SPeter Wemm  ****************************************************************************/
320e3d5408SPeter Wemm 
330e3d5408SPeter Wemm /***************************************************************************
340e3d5408SPeter Wemm * Module m_hook                                                            *
350e3d5408SPeter Wemm * Assign application specific routines for automatic invocation by menus   *
360e3d5408SPeter Wemm ***************************************************************************/
370e3d5408SPeter Wemm 
380e3d5408SPeter Wemm #include "menu.priv.h"
390e3d5408SPeter Wemm 
40*aae38d10SBaptiste Daroussin MODULE_ID("$Id: m_hook.c,v 1.18 2018/12/16 00:13:36 tom Exp $")
410e3d5408SPeter Wemm 
420e3d5408SPeter Wemm /* "Template" macro to generate function to set application specific hook */
430e3d5408SPeter Wemm #define GEN_HOOK_SET_FUNCTION( typ, name ) \
447a69bbfbSPeter Wemm NCURSES_IMPEXP int NCURSES_API set_ ## typ ## _ ## name (MENU *menu, Menu_Hook func )\
450e3d5408SPeter Wemm {\
46*aae38d10SBaptiste Daroussin    TR_FUNC_BFR(1);\
47*aae38d10SBaptiste Daroussin    T((T_CALLED("set_" #typ "_" #name "(%p,%s)"), (void *) menu, TR_FUNC_ARG(0, func)));\
480e3d5408SPeter Wemm    (Normalize_Menu(menu) -> typ ## name = func );\
490e3d5408SPeter Wemm    RETURN(E_OK);\
500e3d5408SPeter Wemm }
510e3d5408SPeter Wemm 
520e3d5408SPeter Wemm /* "Template" macro to generate function to get application specific hook */
530e3d5408SPeter Wemm #define GEN_HOOK_GET_FUNCTION( typ, name ) \
547a69bbfbSPeter Wemm NCURSES_IMPEXP Menu_Hook NCURSES_API typ ## _ ## name ( const MENU *menu )\
550e3d5408SPeter Wemm {\
5606bfebdeSXin LI    T((T_CALLED(#typ "_" #name "(%p)"), (const void *) menu));\
574a1a9510SRong-En Fan    returnMenuHook(Normalize_Menu(menu) -> typ ## name);\
580e3d5408SPeter Wemm }
590e3d5408SPeter Wemm 
600e3d5408SPeter Wemm /*---------------------------------------------------------------------------
610e3d5408SPeter Wemm |   Facility      :  libnmenu
620e3d5408SPeter Wemm |   Function      :  int set_menu_init(MENU *menu, void (*f)(MENU *))
630e3d5408SPeter Wemm |
640e3d5408SPeter Wemm |   Description   :  Set user-exit which is called when menu is posted
650e3d5408SPeter Wemm |                    or just after the top row changes.
660e3d5408SPeter Wemm |
670e3d5408SPeter Wemm |   Return Values :  E_OK               - success
680e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
690e3d5408SPeter Wemm GEN_HOOK_SET_FUNCTION(menu, init)
700e3d5408SPeter Wemm 
710e3d5408SPeter Wemm /*---------------------------------------------------------------------------
720e3d5408SPeter Wemm |   Facility      :  libnmenu
730e3d5408SPeter Wemm |   Function      :  void (*)(MENU *) menu_init(const MENU *menu)
740e3d5408SPeter Wemm |
750e3d5408SPeter Wemm |   Description   :  Return address of user-exit function which is called
760e3d5408SPeter Wemm |                    when a menu is posted or just after the top row
770e3d5408SPeter Wemm |                    changes.
780e3d5408SPeter Wemm |
790e3d5408SPeter Wemm |   Return Values :  Menu init function address or NULL
800e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
810e3d5408SPeter Wemm GEN_HOOK_GET_FUNCTION(menu, init)
820e3d5408SPeter Wemm 
830e3d5408SPeter Wemm /*---------------------------------------------------------------------------
840e3d5408SPeter Wemm |   Facility      :  libnmenu
850e3d5408SPeter Wemm |   Function      :  int set_menu_term (MENU *menu, void (*f)(MENU *))
860e3d5408SPeter Wemm |
870e3d5408SPeter Wemm |   Description   :  Set user-exit which is called when menu is unposted
880e3d5408SPeter Wemm |                    or just before the top row changes.
890e3d5408SPeter Wemm |
900e3d5408SPeter Wemm |   Return Values :  E_OK               - success
910e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
920e3d5408SPeter Wemm GEN_HOOK_SET_FUNCTION(menu, term)
930e3d5408SPeter Wemm 
940e3d5408SPeter Wemm /*---------------------------------------------------------------------------
950e3d5408SPeter Wemm |   Facility      :  libnmenu
960e3d5408SPeter Wemm |   Function      :  void (*)(MENU *) menu_term(const MENU *menu)
970e3d5408SPeter Wemm |
980e3d5408SPeter Wemm |   Description   :  Return address of user-exit function which is called
990e3d5408SPeter Wemm |                    when a menu is unposted or just before the top row
1000e3d5408SPeter Wemm |                    changes.
1010e3d5408SPeter Wemm |
1020e3d5408SPeter Wemm |   Return Values :  Menu finalization function address or NULL
1030e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1040e3d5408SPeter Wemm GEN_HOOK_GET_FUNCTION(menu, term)
1050e3d5408SPeter Wemm 
1060e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1070e3d5408SPeter Wemm |   Facility      :  libnmenu
1080e3d5408SPeter Wemm |   Function      :  int set_item_init (MENU *menu, void (*f)(MENU *))
1090e3d5408SPeter Wemm |
1100e3d5408SPeter Wemm |   Description   :  Set user-exit which is called when menu is posted
1110e3d5408SPeter Wemm |                    or just after the current item changes.
1120e3d5408SPeter Wemm |
1130e3d5408SPeter Wemm |   Return Values :  E_OK               - success
1140e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1150e3d5408SPeter Wemm GEN_HOOK_SET_FUNCTION(item, init)
1160e3d5408SPeter Wemm 
1170e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1180e3d5408SPeter Wemm |   Facility      :  libnmenu
1190e3d5408SPeter Wemm |   Function      :  void (*)(MENU *) item_init (const MENU *menu)
1200e3d5408SPeter Wemm |
1210e3d5408SPeter Wemm |   Description   :  Return address of user-exit function which is called
1220e3d5408SPeter Wemm |                    when a menu is posted or just after the current item
1230e3d5408SPeter Wemm |                    changes.
1240e3d5408SPeter Wemm |
1250e3d5408SPeter Wemm |   Return Values :  Item init function address or NULL
1260e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1270e3d5408SPeter Wemm GEN_HOOK_GET_FUNCTION(item, init)
1280e3d5408SPeter Wemm 
1290e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1300e3d5408SPeter Wemm |   Facility      :  libnmenu
1310e3d5408SPeter Wemm |   Function      :  int set_item_term (MENU *menu, void (*f)(MENU *))
1320e3d5408SPeter Wemm |
1330e3d5408SPeter Wemm |   Description   :  Set user-exit which is called when menu is unposted
1340e3d5408SPeter Wemm |                    or just before the current item changes.
1350e3d5408SPeter Wemm |
1360e3d5408SPeter Wemm |   Return Values :  E_OK               - success
1370e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1380e3d5408SPeter Wemm GEN_HOOK_SET_FUNCTION(item, term)
1390e3d5408SPeter Wemm 
1400e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1410e3d5408SPeter Wemm |   Facility      :  libnmenu
1420e3d5408SPeter Wemm |   Function      :  void (*)(MENU *) item_init (const MENU *menu)
1430e3d5408SPeter Wemm |
1440e3d5408SPeter Wemm |   Description   :  Return address of user-exit function which is called
1450e3d5408SPeter Wemm |                    when a menu is unposted or just before the current item
1460e3d5408SPeter Wemm |                    changes.
1470e3d5408SPeter Wemm |
1480e3d5408SPeter Wemm |   Return Values :  Item finalization function address or NULL
1490e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1500e3d5408SPeter Wemm GEN_HOOK_GET_FUNCTION(item, term)
1510e3d5408SPeter Wemm 
1520e3d5408SPeter Wemm /* m_hook.c ends here */
153