sample-function_key_setting.ads 4.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. ------------------------------------------------------------------------------
  2. -- --
  3. -- GNAT ncurses Binding Samples --
  4. -- --
  5. -- Sample.Function_Key_Setting --
  6. -- --
  7. -- S P E C --
  8. -- --
  9. ------------------------------------------------------------------------------
  10. -- Copyright (c) 1998 Free Software Foundation, Inc. --
  11. -- --
  12. -- Permission is hereby granted, free of charge, to any person obtaining a --
  13. -- copy of this software and associated documentation files (the --
  14. -- "Software"), to deal in the Software without restriction, including --
  15. -- without limitation the rights to use, copy, modify, merge, publish, --
  16. -- distribute, distribute with modifications, sublicense, and/or sell --
  17. -- copies of the Software, and to permit persons to whom the Software is --
  18. -- furnished to do so, subject to the following conditions: --
  19. -- --
  20. -- The above copyright notice and this permission notice shall be included --
  21. -- in all copies or substantial portions of the Software. --
  22. -- --
  23. -- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS --
  24. -- OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF --
  25. -- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. --
  26. -- IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, --
  27. -- DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR --
  28. -- OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR --
  29. -- THE USE OR OTHER DEALINGS IN THE SOFTWARE. --
  30. -- --
  31. -- Except as contained in this notice, the name(s) of the above copyright --
  32. -- holders shall not be used in advertising or otherwise to promote the --
  33. -- sale, use or other dealings in this Software without prior written --
  34. -- authorization. --
  35. ------------------------------------------------------------------------------
  36. -- Author: Juergen Pfeifer, 1996
  37. -- Version Control
  38. -- $Revision: 1.9 $
  39. -- Binding Version 01.00
  40. ------------------------------------------------------------------------------
  41. with Terminal_Interface.Curses; use Terminal_Interface.Curses;
  42. with Terminal_Interface.Curses.Panels; use Terminal_Interface.Curses.Panels;
  43. -- This package implements a simple stack of function key label environments.
  44. --
  45. package Sample.Function_Key_Setting is
  46. procedure Push_Environment (Key : in String;
  47. Reset : in Boolean := True);
  48. -- Push the definition of the current function keys on an internal
  49. -- stack. If the reset flag is true, all labels are reset while
  50. -- pushed, so the new environment can assume a tabula rasa.
  51. -- The Key defines the new Help Context associated with the new
  52. -- Environment. This saves also the currently active Notepad.
  53. procedure Pop_Environment;
  54. -- Pop the Definitions from the stack and make them the current ones.
  55. -- This also restores the Help context and the previous Notepad.
  56. procedure Initialize (Mode : Soft_Label_Key_Format := PC_Style;
  57. Just : Label_Justification := Left);
  58. -- Initialize the environment
  59. function Context return String;
  60. -- Return the current context identitfier
  61. function Find_Context (Key : String) return Boolean;
  62. -- Look for a context, return true if it is in the stack,
  63. -- false otherwise.
  64. procedure Notepad_To_Context (Pan : in Panel);
  65. -- Add a panel representing a notepad to the current context.
  66. Function_Key_Stack_Error : exception;
  67. procedure Default_Labels;
  68. -- Set the default labels used in all environments
  69. function Notepad_Window return Window;
  70. -- Return the current notepad window or Null_Window if there is none.
  71. end Sample.Function_Key_Setting;