Provided by: tklib_0.8~20230222-1_all bug

NAME

       menubar - Creates an instance of the menubar Class.

SYNOPSIS

       package require Tcl  8.6

       package require Tk  8.6

       package require menubar  ?0.5?

       menubar new ?options?

       mBarInst define body

       mBarInst install pathName body

       mBarInst menu.configure option tag-settings ?option tag-settings ...?

       mBarInst menu.namespace tag namespace

       mBarInst menu.hide tag

       mBarInst menu.show tag

       mBarInst tag.add tag value

       mBarInst tag.configure pathName tag ?option value ...option value?

       mBarInst tag.cget pathName tag ?option?

       mBarInst group.add tag label ?cmd? ?accel? ?sequence? ?state?

       mBarInst group.delete tag label

       mBarInst group.move direction tag label

       mBarInst group.configure tag label ?option value ...option value?

       mBarInst group.serialize tag

       mBarInst group.deserialize tag stream

       mBarInst notebook.addTabStore pathname

       mBarInst notebook.deleteTabStore pathname

       mBarInst notebook.setTabValue pathname tag

       mBarInst notebook.restoreTabValues pathname

_________________________________________________________________________________________________

DESCRIPTION

       menubar new ?options?

       Create  and return a new instance of the menubar class. The menubar class encapsulates the
       definition, installation and dynamic behavior of a menubar. The class doesn't depend on  a
       widget  framework  and  therefore  can  be used with or without a framework (e.g. Bwidget,
       IWidget, Snit, etc.). Unlike other Tk widget commands, the menubar command doesn't have  a
       pathName argument because menubars are handled by the window manager (i.e. wm) and not the
       application.

OPTIONS

       The following options can be passed to the menubar new command.

       These options are inherited from the Tk menu command, their effect is platform specific.

       -activebackground      [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-
       activebackground]

       -activeborderwidth     [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-
       activeborderwidth]

       -activeforeground      [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-
       activeforeground]

       -background [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-background]

       -borderwidth           [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-
       borderwidth]

       -cursor [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-cursor]

       -disabledforeground    [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-
       disabledforeground]

       -font [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-font]

       -foreground [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-foreground]

       -relief [http://docs.activestate.com/activetcl/8.5/tcl/TkCmd/options.htm#M-relief]

INTRODUCTION

       An  instance  of  the  menubar  class  provides methods for compiling a description of the
       menubar, configuring menu items and installing the menubar in toplevel windows.

       A menubar can be thought of as a tree of cascading menus. Users define a menubar  using  a
       language that results in a human readable description of a menubar. The description of the
       menubar is then compiled by an instance of  the  menubar  class  after  which  it  can  be
       installed in one or more toplevel windows.

       The  menubar  class  provides  many unique capabilities that are not found in other tcl/tk
       menubar implementation. Some of these are:

       •      A tagging system that simplifies access to menu entries in the menu tree.

       •      Support for user defined tags that depend on the toplevel window context.

       •      A simplified and uniform interface for all callback commands.

       •      Namespace support for all callback commands so  callback  commands  can  be  easily
              grouped into namespaces.

       •      Support for hiding and exposing menus on the menubar.

       •      A simplified method for creating radiobutton groups.

       •      Automatic management of state variables for checkbuttons and radiobuttons.

       •      Scope control for the state variables of checkbuttons and radiobuttons.

       •      Tear-off menu management that ensures only one tearoff menu is created.

       •      Support  for  dynamic  menu  extension  to simplify the creation of recent document
              menus.

       •      Support for saving and restoring dynamic menu extensions.

TERMINOLOGY

       MENUBAR
              The visible rendering of a menubar in a toplevel window is a horizontally group  of
              cascading Tk menus.

       MENU   A  menu  is  an  ordered  list  of items that is rendered vertically. Menus are not
              visible until a user preforms some action (normally  a  <ButtonPress-1>  event).  A
              menu  may  contain  any number of child menus that are rendered as cascading menus.
              Cascading menus are rendered next to the parent menu when they are activated.

       MENU ENTRY
              A menu contains an ordered list of items called entries.  Menu entries have a  type
              and  the  menubar class supports the following 6 entry types: Command, Checkbutton,
              Radiobutton, Separator, Group and Menu.

       ENTRY LABEL
              Each menu entry has a visible string that is called the entry label.

       TAG    A tag is name that is normally used to referr to an item in a menu tree. A tag name
              is an alphanumeric character string that may include the underscore character. Menu
              tree tags are defined for all nodes and leafs in a menu tree. This provides a  flat
              abstraction of the tree and simplifies item referencing in menubar methods. Without
              this abstraction it would be necessary to reference menu elements using a tree path
              which could change at run-time. The menubar class also has a method that can create
              a user defined tag. User defined  tags  store  values  that  change  based  on  the
              currently  active  toplevel  window.  User defined tags can be used to store widget
              pathnames use by callback code so that output can  be  routed  to  the  appropriate
              toplevel window.

METHODS

       mBarInst define body
              Compiles  body  into  a  tree of menu entries which define the visual layout of the
              menubar. The body argument describes the layout using the following  syntax,  where
              the elements of the syntax are described below.

              body == definitions

              definitions    ::= { <ignore> | <definition> | <definition> <definitions> }
              ignore         ::= { <nl> | <white-space> <nl> | # <comment> <nl> }
              definition     ::= { <command> | <checkbutton> | <radiobutton> | <separator> | <group> | <menu> }
              command        ::= <label> C <tag> <nl>
              checkbutton    ::= <label> X<scope> { <tag> | <tag>+ } <nl>
              radiobutton    ::= <label> R<scope> { <tag> | <tag>+ } <nl>
              separator      ::= <stext> S <tag> <nl>
              group          ::= <dummy> G <tag> <nl>
              menu           ::= <label> { M:<tag> | M:<tag>+ } <nl> <definitions>
              stext          ::= '--' | <label>
              scope          ::= '' | '@' | '='

              C - Command
                     The  C  type  entry  is the most common type of entry. This entry executes a
                     command when it is invoked.

              X - Checkbutton
                     A X type entry behaves much like a Tk checkbutton widget. When it is invoked
                     it  toggles  back  and  forth  between a selected and deselected states. The
                     value of a  checkbutton  is  a  boolean  (i.e.  1  or  0).  By  default  all
                     checkbuttons  are  deselected.  If  you want the checkbutton to be initially
                     selected then include a trailing plus (+)  with  the  tag  name.  See  SCOPE
                     CONTROL below for a description of the scope indicator.

              R - Radiobutton
                     A  R  type  menu  entry  behaves  much  like  a  Tk radiobutton widget. Each
                     radiobutton entry is a member of  a  radiobutton  group  that  controls  the
                     behavior  of  the radiobuttons in the group. All radiobuttons in a group are
                     given the same tag name. In the example below Red, Green and Blue  all  have
                     the same tag and are therefore all in the same radiobutton group. A trailing
                     plus (+) on the tag name of a radiobutton entry will cause the entry  to  be
                     the  initially  selected entry. See SCOPE CONTROL below for a description of
                     the scope indicator.

              S - Separator
                     A S type menu entry is an entry that is displayed  either  as  a  horizontal
                     dividing  line  or a label. Separators are not active elements of a menu and
                     have no associated behavior if they are invoked. If <stext>  is  two  dashes
                     (i.e.  '--')  then  the  separator  will  be  displayed as a horizontal line
                     otherwise <stext> will be displayed as a bold  label  surrounded  by  double
                     dashes (e.g. "-- <stext> --") with a lightgray background.

              G - Command Group
                     The G type menu entry marks a location in the menu tree where entries can be
                     dynamically added and removed. Menu extension can only occur at the end of a
                     menu  so G type entries must be the last item on a menu.  A G  type entry is
                     rendered as a separator line.  The  group.<xxx>  sub-commands  are  used  to
                     manipulate command group entries.

              M - Menu
                     An  M  type  entry is used to define both menubar menus and cascading menus.
                     Menu entries are the most complicated of the 6 menu types.  A menu entry  is
                     composed of three list elements. The first element of the list is its label.
                     The second element of the list is a composite string consisting  of  a  type
                     identifier  (M) followed by an optional tag (beginning with a ':' separator)
                     and finally an optional plus (+) which indicates that the menu is a tear-off
                     menu. The final element of the list is a LIST VALUE.

       mBarInst install pathName body
              The  install  method  installs  the  menubar  created  with  the define method into
              toplevel window pathName. The body argument of the command contains  a  tcl  script
              which  is  used  to  initialize the installed menubar. Normally the tcl script will
              contain calls to  various  menubar  methods  to  perform  the  initialization.  The
              initialization  code  is only run once when the menubar is installed. The namespace
              in which the install method is executed becomes the default namespace for  callback
              commands (see menu.namespace below for more details).

METHODS - MENU.XXX

       mBarInst menu.configure option tag-settings ?option tag-settings ...?
              Configures  the tags of a menubar and returns an empty string. This method provides
              a convenient way to configure a larger number of  tags  without  the  verbosity  of
              using the tag.configure method.

              option Option may have any of the values accepted by the tag.configure method.

              tag-settings
                     The  tag-settings  argument  is a string that is converted to a list of tag-
                     value pairs using the following syntax.

                     Syntax for tag-settings.

                     tag-settings ::= { <ignore> | <value> | <value> <tag-settings> }
                     ignore       ::= { <nl> | <white-space> <nl> | # <comment> <nl> }
                     value        ::= <tag> <option-value> <nl>

       mBarInst menu.namespace tag namespace
              Change the namespace for a sub-tree of the menubar starting at entry tag.  The  new
              value  will  be  namespace.   Each  entry  in  the  menubar  tree has an associated
              namespace which will be used for its callback procedure. The default  namespace  is
              the  namespace  where the install  method was executed. The namespace method can be
              used to change the namespace that will be used for callbacks in a sub-tree  of  the
              menubar. This method can only be used in the context of an install script.

       mBarInst menu.hide tag
              Remove  (hide)  a  menubar  entry.  When  a menubar tree is defined all entries are
              visible by default.  This method can be used to hide a  menubar  entry.   The  hide
              methods  can  be  used  in  the context of an install script so that a menu will be
              initially hidden at application start up. The tag argument is the tag name  of  the
              menu to be hidden.

       mBarInst menu.show tag
              Exposes  (shows) a hidden menubar entry. When a menubar tree is defined all entries
              are visible by default.  If a entry is hidden from the user  (using  the  menu.hide
              method) then it can be exposed again using the show method. The tag argument is the
              tag name of the menu to be shown.

METHODS - TAG.XXX

       mBarInst tag.add tag value
              Add a user defined tag value. The tag.add method adds a new tag-value pair  to  the
              the  tags  defined  for  a  menubar.  User defined tags are different from the tags
              created by the define method. The tag.add method can only be  used  in  an  install
              script  and  its  value  is  associated  with  the  toplevel  where  the menubar is
              installed. This makes the tag context sensitive so callback code that  queries  the
              tag  value  will  receive a value that is associated with the window that performed
              the callback.

       mBarInst tag.configure pathName tag ?option value ...option value?
              Given the pathName of a toplevel window and a tag this method configures  the  menu
              entry associated with the tag and return an empty string.

              Standard Options
                     These option are the same as those described for menu entries in the Tk menu
                     documentation.

                     -activebackground

                     -activeforeground

                     -background

                     -bitmap

                     -columnbreak

                     -compound

                     -font

                     -foreground

                     -hidemargin

                     -image

                     -indicatoron

                     -label

                     -selectcolor

                     -selectimage

                     -state

              Class Specific Options

                     -bind {uline accel sequence}
                            The value of the -bind option is three element list where the  values
                            are as follows.

                            uline  An  integer  index  of  a character to underline in the entry.
                                   This  value  performs  the  same  function  as  the  Tk   menu
                                   -underline  option.   If this value is an empty string then no
                                   underlining is performed.

                            accel  A string to display at the right side of the menu  entry.  The
                                   string  normally  describes  an accelerator keystroke sequence
                                   that may be typed to invoke the  same  function  as  the  menu
                                   entry.   This  value performs the same function as the Tk menu
                                   -accelerator option.  If this value is an empty string then no
                                   accelerator is displayed.

                            sequence
                                   A bind sequence that will cause the entries associated command
                                   to fire.

                     -command cmdprefix
                            The value of the -command option a command prefix that  is  evaluated
                            when  the menu entry is invoked.  By default the callback is evaluate
                            in the namespace where the install method  was  executed.  Additional
                            values  are  appended  to  the  cmdprefix  and are thus passed to the
                            callback  command  as  argument.  These  additional   arguments   are
                            described in the list below.

                            command entry
                                   1)  The  pathname  of  the  toplevel  window  that invoked the
                                   callback.

                            checkbutton entry
                                   1) The pathname  of  the  toplevel  window  that  invoked  the
                                   callback.

                                   2) The checkbutton's tag name

                                   3) The new value for the checkbutton

                            radiobutton entry
                                   1)  The  pathname  of  the  toplevel  window  that invoked the
                                   callback.

                                   2) The radiobutton's tag name

                                   3) The label of the button that was selected

                            group entry
                                   1) The pathname  of  the  toplevel  window  that  invoked  the
                                   callback.

       mBarInst tag.cget pathName tag ?option?
              Returns  the  value  of  the configuration option given by option or the value of a
              user defined tag. The option argument may be any of the  options  accepted  by  the
              tag.configure  method  for  the  tag type. User defined tags are queried without an
              option value.

METHODS - GROUP.XXX

       mBarInst group.add tag label ?cmd? ?accel? ?sequence? ?state?
              Add a command to the group with tag name tag. This method  appends  a  new  command
              entry  to  the  end  of  a  command  group. The order of the arguments is fixed but
              arguments to the right can be ignored. Arguments to this method have the  following
              meaning.

              tag (string)
                     The tag name of the command group.

              label (string)
                     The displayed label for the menu entry.

              cmd (string)
                     A command prefix that will be used for callback command.

              accel (string)
                     An accelerator string that will be displayed next to the entry label.

              sequence (string)
                     A bind sequence that will be bound to the callback command.

              state (enum)
                     Sets the active state of the command. One of:  normal, disabled, active

       mBarInst group.delete tag label
              Delete  a command from a group with tag name tag. This method deletes command label
              from a command group.

       mBarInst group.move direction tag label
              Change the position of an entry in a  group  with  tag  name  tag.   The  direction
              argument  is the direction ('up' or 'down') the entry will be moved. The entry that
              is moved has the name label.

       mBarInst group.configure tag label ?option value ...option value?
              Configure the options of an entry in the command group  with  tag  name  tag.  This
              method  is similar to the tag.configure method except that it works on entries in a
              command group. Set documentation for the  tag.configure  method  (above)  for  more
              details on command entry options.

       mBarInst group.serialize tag
              Return  a  string serialization of the entries in a command group. The argument tag
              is  the  tag  name  for  the  group  that  is  to  be  serialized.   The  resulting
              serialization  is  a  list  containing three element  (1) the tag name of the group
              (2) a dictionary containing group level options  (3tk)  a  list  of  zero  or  more
              similar three element lists that describe the entries in the group.

       mBarInst group.deserialize tag stream
              Replace   the  contents  of  group  tag  tag  with  the  commands  defined  in  the
              serialization stream. The original contents of the group are lost.

METHODS - NOTEBOOK.XXX

       mBarInst notebook.addTabStore pathname
              This method should be used in code that creates a new notebook tab.   Execution  of
              this  method will cause state storage to be allocated for the new notebook tab. The
              pathname for the notebook tab is passed as an argument to the method.

       mBarInst notebook.deleteTabStore pathname
              This command deallocates the state store for a notebook tab. The pathname  for  the
              notebook tab is passed as an argument to the method.

       mBarInst notebook.setTabValue pathname tag
              This method should be used in the callback for menubar checkbuttons or radiobuttons
              that have notebook tab scope control. When this method is executed it will move the
              value associated with tag into the tab store for the tab identified by pathname.

       mBarInst notebook.restoreTabValues pathname
              This  method  should  be  place  in  a bind script that is triggered by a notebooks
              <<NotebookTabChanged>> event.

SCOPE CONTROL

       By default a menubar instance looks the same in all installed toplevel windows. As changes
       are  made  to  one  instance of a menubar all the other instances are immediately updated.
       This means the internal state of all the menu entries for the instances are  synchronized.
       This behavior is called global scope control of the menubar state.

       The  menubar  class  allows  finer scope control on check and radio buttons.  The scope of
       these entry types can be modified by adding a modifier character to their type  character.
       Two modifier characters are supported as show in the table below.

       When  the  local scope character (@) is added to the definition of a button, the button is
       given a new variable for each installed toplevel window. This has the effect of making the
       button's  state  local  to  the  window  (i.e. local scope).  An example use case for this
       behavior might be a status bar that can be  toggled  on  an  off  by  a  checkbutton.  The
       developer  may want to allow the user to control the visibility of the status bar on a per
       window basis. In this case a local modifier would be added to the status bar  selector  so
       the callback code would receive an appropriate value based on the current toplevel window.

       The notebook tab scope character (=) is similar in effect to the local scope character but
       it allows a notebook tab selection to also manage the state of of  a  button.  Adding  the
       notebook tab scope modifier enables notebook tab scope control but the developer must then
       make use of the notebook.xxxx sub-commands to actively manage state  values  as  tabs  are
       added, deleted and selected.

EXAMPLE

              package require Tcl
              package require Tk
              package require menubar

              set tout [text .t -width 25 -height 12]
              pack ${tout} -expand 1 -fill both
              set mbar [menubar new \
                  -borderwidth 4 \
                  -relief groove  \
                  -foreground black \
                  -background tan \
                  ]
              ${mbar} define {
                  File M:file {
                      Exit                 C      exit
                  }
                  Edit M:items+ {
                  #   Label               Type    Tag Name(s)
                  #   -----------------   ----    ---------
                      "Cut"               C       cut
                      "Copy"              C       copy
                      "Paste"             C       paste
                      --                  S       s2
                      "Options" M:opts {
                          "CheckList" M:chx+ {
                              Coffee      X       coffee+
                              Donut       X       donut
                              Eggs        X       eggs
                              }
                          "RadioButtons" M:btn+ {
                              "Red"       R       color
                              "Green"     R       color+
                              "Blue"      R       color
                              }
                      }
                  }
                  Help M:help {
                      About               C       about
                  }
              }
              ${mbar} install . {
                  ${mbar} tag.add tout ${tout}
                  ${mbar} menu.configure -command {
                      # file menu
                      exit            {Exit}
                      # Item menu
                      cut             {CB Edit cut}
                      copy            {CB Edit copy}
                      paste           {CB Edit paste}
                      # boolean menu
                      coffee          {CB CheckButton}
                      donut           {CB CheckButton}
                      eggs            {CB CheckButton}
                      # radio menu
                      color           {CB RadioButton}
                      # Help menu
                      about           {CB About}
                  } -bind {
                      exit        {1 Cntl+Q  Control-Key-q}
                      cut         {2 Cntl+X  Control-Key-x}
                      copy        {0 Cntl+C  Control-Key-c}
                      paste       {0 Cntl+V  Control-Key-v}
                      coffee      {0 Cntl+A  Control-Key-a}
                      donut       {0 Cntl+B  Control-Key-b}
                      eggs        {0 Cntl+C  Control-Key-c}
                      about       0
                  } -background {
                      exit red
                  } -foreground {
                      exit white
                  }
              }
              proc pout { txt } {
                  global mbar
                  set tout [${mbar} tag.cget . tout]
                  ${tout} insert end "${txt}\n"
              }
              proc Exit { args } {
                  puts "Goodbye"
                  exit
              }
              proc CB { args } {
                  set alist [lassign ${args} cmd]
                  pout "${cmd}: [join ${alist} {, }]"
              }
              wm minsize . 300 300
              wm geometry . +4+4
              wm protocol . WM_DELETE_WINDOW exit
              wm title . "Example"
              wm focusmodel . active
              pout "Example started ..."

CAVEATS

       This  implementation  uses  TclOO  so it requires 8.6. The code has been tested on Windows
       (Vista), Linux and OSX (10.4).

REFERENCES

       See also

       [1]    menu [http://www.tcl.tk/man/tcl8.6/TkCmd/menu.htm]

       [2]    A command that creates menubar objects [http://wiki.tcl.tk/25231]

BUGS, IDEAS, FEEDBACK

       This document, and the package it describes,  will  undoubtedly  contain  bugs  and  other
       problems.    Please   report   such   in  the  category  menubar  of  the  Tklib  Trackers
       [http://core.tcl.tk/tklib/reportlist].  Please also report any ideas for enhancements  you
       may have for either package and/or documentation.

COPYRIGHT

       Copyright (c) 2009 Tom Krehbiel <krehbiel.tom@gmail.com> All rights reserved.