Spec-Zone .ru
спецификации, руководства, описания, API
Spec-Zone .ru
спецификации, руководства, описания, API
Библиотека разработчика Mac Разработчик
Поиск

 

Эта страница руководства для  версии 10.9 Mac OS X

Если Вы выполняете различную версию  Mac OS X, просматриваете документацию локально:

Читать страницы руководства

Страницы руководства предназначаются как справочник для людей, уже понимающих технологию.

  • Чтобы изучить, как руководство организовано или узнать о синтаксисе команды, прочитайте страницу руководства для страниц справочника (5).

  • Для получения дополнительной информации об этой технологии, ищите другую документацию в Библиотеке Разработчика Apple.

  • Для получения общей информации о записи сценариев оболочки, считайте Shell, Пишущий сценарий Учебника для начинающих.



configbody(n)                                    [incr Tcl]                                    configbody(n)



____________________________________________________________________________________________________________

NAME
       configbody - change the "config" code for a public variable

SYNOPSIS
       itcl::configbody className::varName body
____________________________________________________________________________________________________________


DESCRIPTION
       The  configbody  command  is used outside of an [incr Tcl] class definition to define or redefine the
       configuration code associated with a  public  variable.   Public  variables  act  like  configuration
       options  for  an  object.   They can be modified outside the class scope using the built-in configure
       method.  Each variable can have a bit of "config" code associate with it that is  automatically  exe-cuted executed
       cuted when the variable is configured.  The configbody command can be used to define or redefine this
       body of code.

       Like the body command, this facility allows a class  definition  to  have  separate  "interface"  and
       "implementation"  parts.   The  "interface"  part  is  a class command with declarations for methods,
       procs, instance variables and common variables.  The "implementation" part is a series  of  body  and
       configbody  commands.   If  the  "implementation"  part is kept in a separate file, it can be sourced
       again and again as bugs are fixed, to support interactive development.  When using the "tcl" mode  in
       the  emacs  editor,  the "interface" and "implementation" parts can be kept in the same file; as bugs
       are fixed, individual bodies can be highlighted and sent to the test application.

       The name "className::varName" identifies the public variable  being  updated.   If  the  body  string
       starts with "@", it is treated as the symbolic name for a C procedure.  Otherwise, it is treated as a
       Tcl command script.

       Symbolic names for C procedures are established by registering procedures via Itcl_RegisterC().  This
       is  usually  done  in the Tcl_AppInit() procedure, which is automatically called when the interpreter
       starts up.  In the following example, the procedure My_FooCmd() is registered with the symbolic  name
       "foo".  This procedure can be referenced in the configbody command as "@foo".
              int
              Tcl_AppInit(interp)
                  Tcl_Interp *interp;     /* Interpreter for application. */
              {
                  if (Itcl_Init(interp) == TCL_ERROR) {
                      return TCL_ERROR;
                  }

                  if (Itcl_RegisterC(interp, "foo", My_FooCmd) != TCL_OK) {
                      return TCL_ERROR;
                  }
              }


EXAMPLE
       In  the  following  example, a "File" class is defined to represent open files.  Whenever the "-name"
       option is configured, the existing file is closed, and a new file is opened.  Note that the  "config"
       code for a public variable is optional.  The "-access" option, for example, does not have it.
              itcl::class File {
                  private variable fid ""

                  public variable name ""
                  public variable access "r"

                  constructor {args} {
                      eval configure $args
                  }
                  destructor {
                      if {$fid != ""} {
                          close $fid
                      }
                  }

                  method get {}
                  method put {line}
                  method eof {}
              }

              itcl::body File::get {} {
                  return [gets $fid]
              }
              itcl::body File::put {line} {
                  puts $fid $line
              }
              itcl::body File::eof {} {
                  return [::eof $fid]
              }

              itcl::configbody File::name {
                  if {$fid != ""} {
                      close $fid
                  }
                  set fid [open $name $access]
              }

              #
              # See the File class in action:
              #
              File x

              x configure -name /etc/passwd
              while {![x eof]} {
                  puts "=> [x get]"
              }
              itcl::delete object x


KEYWORDS
       class, object, variable, configure



itcl                                                 3.0                                       configbody(n)

Сообщение о проблемах

Способ сообщить о проблеме с этой страницей руководства зависит от типа проблемы:

Ошибки содержания
Ошибки отчета в содержании этой документации к проекту Tcl.
Отчеты об ошибках
Сообщите об ошибках в функциональности описанного инструмента или API к Apple через Генератор отчетов Ошибки и к проекту Tcl через их страницу создания отчетов ошибки.
Форматирование проблем
Отчет, форматирующий ошибки в интерактивной версии этих страниц со ссылками на отзыв ниже.