X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=panel%2Fp_above.c;h=2a6fde55cdc804f1e86f4845079b83708f8a332a;hp=fa32196db42b109c459cc3a3e434b2992734a693;hb=f67a188e71a0e6f80c1c45e50e7a7449c2d7bfb3;hpb=0eb88fc5281804773e2a0c7a488a4452463535ce diff --git a/panel/p_above.c b/panel/p_above.c index fa32196d..2a6fde55 100644 --- a/panel/p_above.c +++ b/panel/p_above.c @@ -1,5 +1,6 @@ /**************************************************************************** - * Copyright (c) 1998 Free Software Foundation, Inc. * + * Copyright 2020 Thomas E. Dickey * + * Copyright 1998-2010,2012 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -29,23 +30,56 @@ /**************************************************************************** * Author: Zeyd M. Ben-Halim 1995 * * and: Eric S. Raymond * + * and: Juergen Pfeifer 1997-1999,2008 * ****************************************************************************/ /* p_above.c */ #include "panel.priv.h" -MODULE_ID("$Id: p_above.c,v 1.3 1999/09/18 11:03:28 juergen Exp $") +MODULE_ID("$Id: p_above.c,v 1.11 2020/05/24 01:40:20 anonymous.maarten Exp $") -PANEL* -panel_above(const PANEL *pan) +#if NCURSES_SP_FUNCS +PANEL_EXPORT(PANEL *) +ground_panel(SCREEN * sp) { - if(!pan) + T((T_CALLED("ground_panel(%p)"), (void *)sp)); + if (sp) { - /* if top and bottom are equal, we have no or only the pseudo panel; - if not, we return the panel above the pseudo panel */ - return(EMPTY_STACK() ? (PANEL*)0 : _nc_bottom_panel->above); + struct panelhook *ph = NCURSES_SP_NAME(_nc_panelhook) (sp); + + if (_nc_bottom_panel) /* this is the pseudo panel */ + returnPanel(_nc_bottom_panel->above); + else + returnPanel(0); + } + else + { + if (0 == CURRENT_SCREEN) + returnPanel(0); + else + returnPanel(ground_panel(CURRENT_SCREEN)); } +} +#endif + +PANEL_EXPORT(PANEL *) +panel_above(const PANEL * pan) +{ + PANEL *result; + + T((T_CALLED("panel_above(%p)"), (const void *)pan)); + if (pan) + result = pan->above; else - return(pan->above); + { +#if NCURSES_SP_FUNCS + result = ground_panel(CURRENT_SCREEN); +#else + /* if top and bottom are equal, we have no or only the pseudo panel; + if not, we return the panel above the pseudo panel */ + result = EMPTY_STACK()? (PANEL *) 0 : _nc_bottom_panel->above; +#endif + } + returnPanel(result); }