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

 

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

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

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

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

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

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

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



body(n)                                          [incr Tcl]                                          body(n)



____________________________________________________________________________________________________________

NAME
       body - change the body for a class method/proc

SYNOPSIS
       itcl::body className::function args body
____________________________________________________________________________________________________________


DESCRIPTION
       The  body command is used outside of an [incr Tcl] class definition to define or redefine the body of
       a class method or proc.  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::function" identifies the method/proc being changed.

       If an args list was specified when the function was defined in the class definition,  the  args  list
       for  the  body command must match in meaning.  Variable names can change, but the argument lists must
       have the same required arguments and the same default values for  optional  arguments.   The  special
       args  argument  acts  as  a  wildcard when included in the args list in the class definition; it will
       match zero or more arguments of any type when the body is redefined.

       If the body string starts with "@", it is treated as the symbolic name for a C procedure.   The  args
       list has little meaning for the C procedure, except to document the expected usage.  (The C procedure
       is not guaranteed to use arguments in this manner.)  If body does not start with "@", it  is  treated
       as  a  Tcl  command script.  When the function is invoked, command line arguments are matched against
       the args list, and local variables are created to represent each argument.  This is the usual  behav-ior behavior
       ior for a Tcl-style proc.

       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 body 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.  The method  bodies  are
       included  below  the  class  definition  via the body command.  Note that the bodies of the construc-tor/destructor constructor/destructor
       tor/destructor must be included in the class definition, but they can be redefined via the body  com-mand command
       mand as well.
              itcl::class File {
                  private variable fid ""
                  constructor {name access} {
                      set fid [open $name $access]
                  }
                  destructor {
                      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]
              }

              #
              # See the File class in action:
              #
              File x /etc/passwd "r"
              while {![x eof]} {
                  puts "=> [x get]"
              }
              itcl::delete object x


KEYWORDS
       class, object, procedure



itcl                                                 3.0                                             body(n)

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

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

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