tie(3)



tie(3tcl)                     Tcl Data Structures                    tie(3tcl)

______________________________________________________________________________

NAME
       tie - Array persistence

SYNOPSIS
       package require Tcl  8.4

       package require tie  ?1.1?

       ::tie::tie arrayvarname options... dstype dsname...

       ::tie::untie arrayvarname ?token?

       ::tie::info ties arrayvarname

       ::tie::info types

       ::tie::info type dstype

       ::tie::register dsclasscmd as dstype

       dsclasscmd objname ?dsname...?

       ds destroy

       ds names

       ds size

       ds get

       ds set dict

       ds unset ?pattern?

       ds setv index value

       ds unsetv index

       ds getv index

______________________________________________________________________________

DESCRIPTION
       The tie package provides a framework for the creation of persistent Tcl
       array variables. It should be noted  that  the  provided  mechanism  is
       generic enough to also allow its usage for the distribution of the con-
       tents of Tcl arrays over multiple threads and processes, i.e.  communi-
       cation.

       This,  persistence  and  communication, is accomplished by tying) a Tcl
       array variable to a data source. Examples of data sources are other Tcl
       arrays and files.

       It should be noted that a single Tcl array variable can be tied to more
       than one data source. It is this feature which allows the framework  to
       be  used for communication as well. Just tie several Tcl arrays in many
       client processes to a Tcl array in a server and all changes to  any  of
       them  will be distributed to all. Less centralized variants of this are
       of course possible as well.

USING TIES
   TIE API
       This section describes the basic API used to establish and remove  ties
       between  Tcl  array  variables  and data sources. This interface is the
       only one a casual user has to be concerned about.  The  following  sec-
       tions about the various internal interfaces can be safely skipped.

       ::tie::tie arrayvarname options... dstype dsname...
              This  command establishes a tie between the Tcl array whose name
              is provided by the argument arrayvarname  and  the  data  source
              identified by the dstype and its series of dsname arguments. All
              changes made to the Tcl array after this command returns will be
              saved to the data source for safekeeping (or distribution).

              The result of the command is always a token which identifies the
              new tie. This token can be used later to destroy  this  specific
              tie.

              varname arrayvarname (in)
                     The name of the Tcl array variable to connect the new tie
                     to.

              name|command dstype (in)
                     This argument specifies the type of the  data  source  we
                     wish to access.  The dstype can be one of log, array, re-
                     motearray, file, growfile, or dsource; in  addition,  the
                     programmer  can  register  additional  data source types.
                     Each dstype is followed by one  or  more  arguments  that
                     identify  the  data  source  to  which the array is to be
                     tied.

              string dsname (in)
                     The series of dsname arguments coming  after  the  dstype
                     identifies the data source we wish to connect to, and has
                     to be appropriate for the chosen type.

       The command understands a number of additional options which guide  the
       process of setting up the connection between Tcl array and data source.

              -open  The  Tcl  array  for  the new tie is loaded from the data
                     source, and the previously existing contents of  the  Tcl
                     array are erased. Care is taken to not erase the previous
                     contents should the creation of the tie fail.

                     This option and the option -save exclude each  other.  If
                     neither this nor option -save are specified then this op-
                     tion is assumed as default.

              -save  The Tcl array for the  new  tie  is  saved  to  the  data
                     source,  and the previously existing contents of the data
                     source are erased.

                     This option and the option -open exclude each  other.  If
                     neither  this  nor option -open are specified then option
                     -open is assumed as default.

              -merge Using this option prevents the erasure of any  previously
                     existing  content  and merges the data instead. It can be
                     specified in conjunction with either -open or -save. They
                     determine  how  data  existing in both Tcl array and data
                     source, i.e duplicates, are dealt with.

                     When used with -open data in the data source  has  prece-
                     dence.   In  other  words, for duplicates the data in the
                     data source is loaded into the Tcl array.

                     When used with -save data in the  Tcl  array  has  prece-
                     dence. In other words, for duplicates the data in the Tcl
                     array is saved into the data source.

       ::tie::untie arrayvarname ?token?
              This command dissolves one or more ties associated with the  Tcl
              array  named  by arrayvarname. If no token is specified then all
              ties to that Tcl array are dissolved. Otherwise only the tie the
              token  stands for is removed, if it is actually connected to the
              array. Trying to remove a specific tie not belonging to the pro-
              vided array will cause an error.

              It  should  be noted that while severing a tie will destroy man-
              agement information internal to  the  package  the  data  source
              which was handled by the tie will not be touched, only closed.

              After the command returns none of changes made to the array will
              be saved to the data source anymore.

              The result of the command is an empty string.

              varname arrayname (in)
                     The name of a Tcl array variable which may have ties.

              handle token (in)
                     A handle representing a specific tie.  This  argument  is
                     optional.

       ::tie::info ties arrayvarname
              This  command returns a list of ties associated with the Tcl ar-
              ray variable named by arrayvarname.  The  result  list  will  be
              empty if the variable has no ties associated with it.

       ::tie::info types
              This  command  returns a dictionary of registered types, and the
              class commands they are associated with.

       ::tie::info type dstype
              This command returns the fully resolved class command for a type
              name.  This  means  that the command will follow a chain of type
              definitions ot its end.

   STANDARD DATA SOURCE TYPES
       This package provides the six following types as examples and  standard
       data sources.

       log    This  data source does not maintain any actual data, nor persis-
              tence. It does not accept any identifying arguments. All changes
              are simply logged to stdout.

       array  This  data  source uses a regular Tcl array as the origin of the
              persistent data. It accepts a single identifying  argument,  the
              name of this Tcl array. All changes are mirrored to that array.

       remotearray
              This data source is similar to array. The difference is that the
              Tcl array to which we are mirroring is not directly  accessible,
              but through a send-like command.

              It  accepts  three  identifying arguments, the name of the other
              Tcl array, the command prefix for the  send-like  accessor  com-
              mand, and an identifier for the remote entity hosting the array,
              in this order. All changes are mirrored to that array,  via  the
              command  prefix. All commands will be executed in the context of
              the global namespace.

              send-like means that the command prefix has to have send  syntax
              and semantics. I.e. it is a channel over which we can send arbi-
              trary commands to some other  entity.   The  remote  array  data
              source  however uses only the commands set, unset, array exists,
              array names, array set, and array get to retrieve and set values
              in the remote array.

              The  command  prefix and the entity id are separate to allow the
              data source to use options like -async when assembling  the  ac-
              tual commands.

              Examples  of  command prefixes, listed with the id of the remote
              entity, without options. In reality only the part before the  id
              is the command prefix:

              send tkname
                     The  Tcl array is in a remote interpreter and is accessed
                     via Tk's X communication.

              comm::comm send hostportid
                     The Tcl array is in a remote interpreter and is  accessed
                     through a socket.

              thread::send threadid
                     The  Tcl  array is in a remote interpreter in a different
                     thread of this process.

       file   This data source uses a single file as origin of the  persistent
              data. It accepts a single identifying argument, the path to this
              file. The file has to be both readable and writable. It may  not
              exist,  the  data  source will create it in that case. This (and
              only this) situation will require that  the  directory  for  the
              file exists and is writable as well.

              All  changes  are saved in the file, as proper Tcl commands, one
              command per operation. In other words, the file will always con-
              tain a proper Tcl script.

              If the file exists when the tie using it is set up, then it will
              be compacted, i.e. superfluous operations are  removed,  if  the
              operations  log stored in it contains either at least one opera-
              tion clearing the whole array, or at least 1.5 times more opera-
              tions than entries in the loaded array.

       growfile
              This data source is like file in terms of the storage medium for
              the array data, and how it is configured. In  constrast  to  the
              former  it  however assumes and ensures that the tied array will
              never shrink. I.e. the creation of new array  entries,  and  the
              modification of existing entries is allowed, but the deletion of
              entries is not, and causes the data source to throw errors.

              This restriction allows us to simplify both file format and  ac-
              cess  to the file radically. For one, the file is read only once
              and the internal cache cannot be  invalidated.  Second,  writing
              data  is  reduced  to a simple append, and no compaction step is
              necessary. The format of the contents is the string  representa-
              tion of a dictionary which can be incrementally extended forever
              at the end.

       dsource
              This data source uses an explicitly specified data source object
              as the source for the persistent data. It accepts a single iden-
              tifying argument, the command prefix, i.e. object command.

              To use this type it is necessary to know how the framework  man-
              ages ties and what data source objects are.

              All changes are delegated to the specified object.

CREATING NEW DATA SOURCES
       This  section is of no interest to the casual user of ties. Only devel-
       opers wishing to create new data sources have to know  the  information
       provided herein.

   DATA SOURCE OBJECTS
       All  ties are represented internally by an in-memory object which medi-
       ates between the tie framework and the specific data  source,  like  an
       array, file, etc.  This is the data source object.

       Its  class,  the  data source class is not generic, but specific to the
       type of the data source. Writing a new data source requires us to write
       such a class, and then registering it with the framework as a new type.

       The following subsections describe the various APIs a data source class
       and the objects it generates will have to follow to be compatible  with
       the tie framework.

       Data source objects are normally automatically created and destroyed by
       the framework when a tie is created, or removed. This management can be
       explicitly  bypassed through the usage of the "dsource" type.  The data
       source for this type is a data source object itself, and this object is
       outside  of  the  scope of the tie framework and not managed by it.  In
       other words, this type allows the creation of ties which talk  to  pre-
       existing  data  source  objects, and these objects will survive the re-
       moval of the ties using them as well.

   REGISTERING A NEW DATA SOURCE CLASS
       After a data source class has been written it is necessary to  register
       it as a new type with the framework.

       ::tie::register dsclasscmd as dstype
              Using  this  command  causes  the  tie framework to remember the
              class command dsclasscmd of a data source class under  the  type
              name dstype.

              After  the  call  the  argument dstype of the basic user command
              ::tie::tie will accept dstype as a type name  and  translate  it
              internally  to the appropriate class command for the creation of
              data source objects for the new data source.

   DATA SOURCE CLASS
       Each data source class is represented by a single command, also  called
       the class command, or object creation command. Its syntax is

       dsclasscmd objname ?dsname...?
              The  first argument of the class command is the name of the data
              source object to create.  The framework itself will always  sup-
              ply  the  string %AUTO%, to signal that the class command has to
              generate not only the object, but the object name as well.

              This is followed by a series of arguments identifying  the  data
              source  the  new  object is for. These are the same dsname argu-
              ments which are given to  the  basic  user  command  ::tie::tie.
              Their actual meaning is dependent on the data source class.

              The  result  of  the class command has to be the fully-qualified
              name of the new data source object, i.e. the name of the  object
              command.   The interface this command has to follow is described
              in the section DATA SOURCE OBJECT API

   DATA SOURCE OBJECT API
       Please read the section DATA SOURCE CLASS first, to know how to  gener-
       ate new object commands.

       Each  object  command  for a data source object has to provide at least
       the methods listed below for proper inter-operation with the tie frame-
       work.  Note that the names of most of the methods match the subcommands
       of the builtin array command.

       ds destroy
              This method is called when the object ds is  destroyed.  It  now
              has  to  release  all its internal resources associated with the
              external data source.

       ds names
              This command has to return a list containing the  names  of  all
              keys  found  in  the  data  source  the object talks to. This is
              equivalent to array names.

       ds size
              This command has to return an integer number specifying the num-
              ber  of  keys found in the data source the object talks to. This
              is equivalent to array size.

       ds get This command has to return  a  dictionary  containing  the  data
              found in the data source the object talks to. This is equivalent
              to array get.

       ds set dict
              This command takes a dictionary and adds  its  contents  to  the
              data  source  the  object  talks to. This is equivalent to array
              set.

       ds unset ?pattern?
              This command takes a pattern and removes all elements whose keys
              matching  it from the data source. If no pattern is specified it
              defaults to *, causing the removal  of  all  elements.  This  is
              nearly equivalent to array unset.

       ds setv index value
              This command has to save the value in the data source the object
              talks to, under the key index.

              The result of the command is ignored. If an error is thrown then
              this  error  will  show  up  as error of the set operation which
              caused the method call.

       ds unsetv index
              This command has to remove the value under the  key  index  from
              the data source the object talks to.

              The result of the command is ignored. If an error is thrown then
              this error will show up as error of the  unset  operation  which
              caused the method call.

       ds getv index
              This  command  has  to return the value for the key index in the
              data source the object talks to.

       And here a small table comparing the data source methods to the regular
       Tcl commands for accessing an array.

                      Regular Tcl             Data source
                      -----------             -----------
                      array names a           ds names
                      array size  a           ds size
                      array get   a           ds get
                      array set   a dict      ds set   dict
                      array unset a pattern   ds unset ?pattern?
                      -----------             -----------
                      set a($idx) $val        ds setv   idx val
                      unset a($idx)           ds unsetv idx
                      $a($idx)                ds getv   idx
                      -----------             -----------

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

       When proposing code changes, please provide unified diffs, i.e the out-
       put of diff -u.

       Note further that  attachments  are  strongly  preferred  over  inlined
       patches.  Attachments  can  be  made  by  going to the Edit form of the
       ticket immediately after its creation, and  then  using  the  left-most
       button in the secondary navigation bar.

KEYWORDS
       array, database, file, metakit, persistence, tie, untie

CATEGORY
       Programming tools

COPYRIGHT
       Copyright (c) 2004-2008 Andreas Kupries <andreas_kupries@users.sourceforge.net>

tcllib                                1.1                            tie(3tcl)

Man(1) output converted with man2html
list of all man pages