OSDN Git Service

Please enter the commit message for your changes. Lines starting
[eos/base.git] / util / src / TclTk / tcl8.6.4 / pkgs / itcl4.0.3 / doc / ensemble.n
diff --git a/util/src/TclTk/tcl8.6.4/pkgs/itcl4.0.3/doc/ensemble.n b/util/src/TclTk/tcl8.6.4/pkgs/itcl4.0.3/doc/ensemble.n
deleted file mode 100644 (file)
index 0b303b7..0000000
+++ /dev/null
@@ -1,178 +0,0 @@
-'\"
-'\" Copyright (c) 1993-1998  Lucent Technologies, Inc.
-'\"
-'\" See the file "license.terms" for information on usage and redistribution
-'\" of this file, and for a DISCLAIMER OF ALL WARRANTIES.
-'\" 
-.TH ensemble n 3.0 itcl "[incr\ Tcl]"
-.so man.macros
-.BS
-'\" Note:  do not modify the .SH NAME line immediately below!
-.SH NAME
-itcl::ensemble \- create or modify a composite command
-.SH SYNOPSIS
-.nf
-\fBitcl::ensemble \fIensName\fR ?\fIcommand arg arg...\fR?
-.fi
-or
-.nf
-\fBensemble \fIensName\fR {
-    \fBpart \fIpartName args body\fR
-    \fI...\fR
-    \fBensemble \fIpartName\fR {
-        \fBpart \fIsubPartName args body\fR
-        \fBpart \fIsubPartName args body\fR
-    \fI...\fR
-    }
-}
-.fi
-.BE
-
-.SH DESCRIPTION
-.PP
-The \fBensemble\fR command is used to create or modify a composite
-command.  See the section \fBWHAT IS AN ENSEMBLE?\fR below for a
-brief overview of ensembles.
-.PP
-If the \fBensemble\fR command finds an existing ensemble called
-\fIensName\fR, it updates that ensemble.  Otherwise, it creates an
-ensemble called \fIensName\fR.  If the \fIensName\fR is a simple name
-like "foo", then an ensemble command named "foo" is added to the
-current namespace context.  If a command named "foo" already exists
-in that context, then it is deleted.  If the \fIensName\fR contains
-namespace qualifiers like "a::b::foo", then the namespace path is
-resolved, and the ensemble command is added that namespace context.
-Parent namespaces like "a" and "b" are created automatically, as needed.
-.PP
-If the \fIensName\fR contains spaces like "a::b::foo bar baz", then
-additional words like "bar" and "baz" are treated as sub-ensembles.
-Sub-ensembles are merely parts within an ensemble; they do not have
-a Tcl command associated with them.  An ensemble like "foo" can
-have a sub-ensemble called "foo bar", which in turn can have a
-sub-ensemble called "foo bar baz".  In this case, the sub-ensemble
-"foo bar" must be created before the sub-ensemble "foo bar baz"
-that resides within it.
-.PP
-If there are any arguments following \fIensName\fR, then they are
-treated as commands, and they are executed to update the ensemble.
-The following commands are recognized in this context:  \fBpart\fR
-and \fBensemble\fR.
-.PP
-The \fBpart\fR command defines a new part for the ensemble.
-Its syntax is identical to the usual \fBproc\fR command, but
-it defines a part within an ensemble, instead of a Tcl command.
-If a part called \fIpartName\fR already exists within the ensemble,
-then the \fBpart\fR command returns an error.
-.PP
-The \fBensemble\fR command can be nested inside another \fBensemble\fR
-command to define a sub-ensemble.
-
-.SH "WHAT IS AN ENSEMBLE?"
-.PP
-The usual "info" command is a composite command--the command name
-\fBinfo\fR must be followed by a sub-command like \fBbody\fR or \fBglobals\fR.
-We will refer to a command like \fBinfo\fR as an \fIensemble\fR, and to
-sub-commands like \fBbody\fR or \fBglobals\fR as its \fIparts\fR.
-.PP
-Ensembles can be nested.  For example, the \fBinfo\fR command has
-an ensemble \fBinfo namespace\fR within it.  This ensemble has parts
-like \fBinfo namespace all\fR and \fBinfo namespace children\fR.
-.PP
-With ensembles, composite commands can be created and extended
-in an automatic way.  Any package can find an existing ensemble
-and add new parts to it.  So extension writers can add their
-own parts, for example, to the \fBinfo\fR command.
-.PP
-The ensemble facility manages all of the part names and keeps
-track of unique abbreviations.  Normally, you can abbreviate
-\fBinfo complete\fR to \fBinfo comp\fR.  But if an extension adds the
-part \fBinfo complexity\fR, the minimum abbreviation for \fBinfo complete\fR
-becomes \fBinfo complet\fR.
-.PP
-The ensemble facility not only automates the construction of
-composite commands, but it automates the error handling as well.
-If you invoke an ensemble command without specifying a part name,
-you get an automatically generated error message that summarizes
-the usage information.  For example, when the \fBinfo\fR command
-is invoked without any arguments, it produces the following error
-message:
-.PP
-.CS
-wrong # args: should be one of...
-  info args procname
-  info body procname
-  info cmdcount
-  info commands ?pattern?
-  info complete command
-  info context
-  info default procname arg varname
-  info exists varName
-  info globals ?pattern?
-  info level ?number?
-  info library
-  info locals ?pattern?
-  info namespace option ?arg arg ...?
-  info patchlevel
-  info procs ?pattern?
-  info protection ?-command? ?-variable? name
-  info script
-  info tclversion
-  info vars ?pattern?
-  info which ?-command? ?-variable? ?-namespace? name
-.CE
-.PP
-You can also customize the way an ensemble responds to errors.
-When an ensemble encounters an unspecified or ambiguous part
-name, it looks for a part called \fB@error\fR.  If it exists,
-then it is used to handle the error.  This part will receive all
-of the arguments on the command line starting with the offending
-part name.  It can find another way of resolving the command,
-or generate its own error message.
-
-.SH EXAMPLE
-.PP
-We could use an ensemble to clean up the syntax of the various
-"wait" commands in Tcl/Tk.  Instead of using a series of
-strange commands like this:
-.PP
-.CS
-vwait x
-tkwait visibility .top
-tkwait window .
-.CE
-.PP
-we could use commands with a uniform syntax, like this:
-.PP
-.CS
-wait variable x
-wait visibility .top
-wait window .
-.CE
-.PP
-The Tcl package could define the following ensemble:
-.PP
-.CS
-itcl::ensemble wait part variable {name} {
-    uplevel vwait $name
-}
-.CE
-.PP
-The Tk package could add some options to this ensemble, with a
-command like this:
-.PP
-.CS
-itcl::ensemble wait {
-    part visibility {name} {
-        tkwait visibility $name
-    }
-    part window {name} {
-        tkwait window $name
-    }
-}
-.CE
-.PP
-Other extensions could add their own parts to the \fBwait\fR command
-too.
-
-.SH KEYWORDS
-ensemble, part, info