mime(3)



mime(3tcl)                           Mime                           mime(3tcl)

______________________________________________________________________________

NAME
       mime - Manipulation of MIME body parts

SYNOPSIS
       package require Tcl  8.5

       package require mime  ?1.6.2?

       ::mime::initialize  ?-canonical  type/subtype  ?-param  {key value}...?
       ?-encoding value? ?-header {key value}...?? (-file name | -string value
       | -parts {token1 ... tokenN})

       ::mime::finalize token ?-subordinates all | dynamic | none?

       ::mime::getproperty token ?property | -names?

       ::mime::getheader token ?key | -names?

       ::mime::setheader token key value ?-mode write | append | delete?

       ::mime::getbody token ?-decode? ?-command callback ?-blocksize octets??

       ::mime::copymessage token channel

       ::mime::buildmessage token

       ::mime::parseaddress string

       ::mime::parsedatetime (string | -now) property

       ::mime::mapencoding encoding_name

       ::mime::reversemapencoding charset_type

______________________________________________________________________________

DESCRIPTION
       The mime library package provides the commands to create and manipulate
       MIME body parts.

       ::mime::initialize ?-canonical  type/subtype  ?-param  {key  value}...?
       ?-encoding value? ?-header {key value}...?? (-file name | -string value
       | -parts {token1 ... tokenN})
              This command creates a MIME part and returns a token  represent-
              ing it.

              o      If  the -canonical option is present, then the body is in
                     canonical (raw) form and is found  by  consulting  either
                     the -file, -string, or -parts option.

                     In  addition, both the -param and -header options may oc-
                     cur zero or more times to specify Content-Type parameters
                     (e.g., charset) and header keyword/values (e.g., Content-
                     Disposition), respectively.

                     Also, -encoding, if present, specifies the Content-Trans-
                     fer-Encoding when copying the body.

              o      If  the  -canonical  option is not present, then the MIME
                     part contained in either the -file or the -string  option
                     is  parsed, dynamically generating subordinates as appro-
                     priate.

       ::mime::finalize token ?-subordinates all | dynamic | none?
              This command destroys the MIME part represented by token. It re-
              turns an empty string.

              If  the -subordinates option is present, it specifies which sub-
              ordinates should also be destroyed. The  default  value  is  dy-
              namic,   destroying  all  subordinates  which  were  created  by
              ::mime::initialize together with the containing body part.

       ::mime::getproperty token ?property | -names?
              This command returns a string or a list  of  strings  containing
              the  properties  of  a MIME part. If the command is invoked with
              the name of a specific property, then the corresponding value is
              returned; instead, if -names is specified, a list of all proper-
              ties is returned; otherwise, a serialized  array  of  properties
              and values is returned.

              The possible properties are:

              content
                     The type/subtype describing the content

              encoding
                     The "Content-Transfer-Encoding"

              params A list of "Content-Type" parameters

              parts  A list of tokens for the part's subordinates.  This prop-
                     erty is present only if the MIME part has subordinates.

              size   The approximate size of the content (unencoded)

       ::mime::getheader token ?key | -names?
              This command returns the header of a MIME part,  as  a  list  of
              strings.

              A header consists of zero or more key/value pairs. Each value is
              a list containing one or more strings.

              If this command is invoked with the name of a specific key, then
              a  list  containing  the corresponding value(s) is returned; in-
              stead, if -names is specified, a list of all keys  is  returned;
              otherwise,  a  serialized  array of keys and values is returned.
              Note that when a key is specified (e.g.,  "Subject"),  the  list
              returned usually contains exactly one string; however, some keys
              (e.g., "Received") often occur more than once in the header, ac-
              cordingly  the  list  returned  usually  contains  more than one
              string.

       ::mime::setheader token key value ?-mode write | append | delete?
              This command writes, appends to, or deletes the value associated
              with  a key in the header. It returns a list of strings contain-
              ing the previous value associated with the key.

              The value for -mode is one of:

              write  The key/value is either created or overwritten  (the  de-
                     fault).

              append A  new value is appended for the key (creating it as nec-
                     essary).

              delete All values associated with the key are removed (the value
                     parameter is ignored).

       ::mime::getbody token ?-decode? ?-command callback ?-blocksize octets??
              This  command  returns  a string containing the body of the leaf
              MIME part represented by token in canonical form.

              If the -command option is present, then it is repeatedly invoked
              with a fragment of the body as this:

                uplevel #0 $callback [list "data" $fragment]

       (The  -blocksize option, if present, specifies the maximum size of each
       fragment passed to the callback.)

       When the end of the body is reached, the callback is invoked as:

                  uplevel #0 $callback "end"

       Alternatively, if an error occurs, the callback is invoked as:

                  uplevel #0 $callback [list "error" reason]

       Regardless, the return value of the final invocation of the callback is
       propagated upwards by ::mime::getbody.

       If the -command option is absent, then the return value of ::mime::get-
       body is a string containing the MIME part's entire body.

       If the option -decode is absent the return value computed above is  re-
       turned  as  is. This means that it will be in the charset specified for
       the token and not the usual utf-8.  If the option  -decode  is  present
       however  the  command  will use the charset information associated with
       the token to convert the string from its encoding into utf-8 before re-
       turning it.

       ::mime::copymessage token channel
              This  command  copies  the MIME represented by token part to the
              specified channel. The command operates synchronously, and  uses
              fileevent  to  allow asynchronous operations to proceed indepen-
              dently. It returns an empty string.

       ::mime::buildmessage token
              This command returns the MIME part represented  by  token  as  a
              string.   It  is similar to ::mime::copymessage, only it returns
              the data as a return string instead of writing to a channel.

       ::mime::parseaddress string
              This command takes a string containing one or more 822-style ad-
              dress  specifications  and  returns a list of serialized arrays,
              one element for each address specified in the argument.  If  the
              string  contains more than one address they will be separated by
              commas.

              Each serialized array contains the properties below.  Note  that
              one or more of these properties may be empty.

              address
                     local@domain

              comment
                     822-style comment

              domain the domain part (rhs)

              error  non-empty on a parse error

              group  this address begins a group

              friendly
                     user-friendly rendering

              local  the local part (lhs)

              memberP
                     this address belongs to a group

              phrase the phrase part

              proper 822-style address specification

              route  822-style route specification (obsolete)

       ::mime::parsedatetime (string | -now) property
              This  command  takes  a string containing an 822-style date-time
              specification and returns the specified property as a serialized
              array.

              The list of properties and their ranges are:

              hour   0 .. 23

              lmonth January, February, ..., December

              lweekday
                     Sunday, Monday, ... Saturday

              mday   1 .. 31

              min    0 .. 59

              mon    1 .. 12

              month  Jan, Feb, ..., Dec

              proper 822-style date-time specification

              rclock elapsed seconds between then and now

              sec    0 .. 59

              wday   0 .. 6 (Sun .. Mon)

              weekday
                     Sun, Mon, ..., Sat

              yday   1 .. 366

              year   1900 ...

              zone   -720 .. 720 (minutes east of GMT)

       ::mime::mapencoding encoding_name
              This commansd maps tcl encodings onto the proper names for their
              MIME charset type.   This  is  only  done  for  encodings  whose
              charset types were known.  The remaining encodings return "" for
              now.

       ::mime::reversemapencoding charset_type
              This command maps MIME charset types onto  tcl  encoding  names.
              Those that are unknown return "".

KNOWN BUGS
       Tcllib Bug #447037
              This problem affects only people which are using Tcl and Mime on
              a 64-bit system. The currently recommended fix for this  problem
              is  to  upgrade to Tcl version 8.4. This version has extended 64
              bit support and the bug does not appear anymore.

              The problem could have been generally solved  by  requiring  the
              use  of  Tcl 8.4 for this package. We decided against this solu-
              tion as it would force a large number of unaffected users to up-
              grade their Tcl interpreter for no reason.

              See Ticket 447037 [/tktview?name=447037] for additional informa-
              tion.

BUGS, IDEAS, FEEDBACK
       This document, and the package it describes, will  undoubtedly  contain
       bugs  and  other  problems.  Please report such in the category mime 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.

SEE ALSO
       ftp, http, pop3, smtp

KEYWORDS
       email, internet, mail, mime, net, rfc 2045, rfc  2046,  rfc  2049,  rfc
       821, rfc 822, smtp

CATEGORY
       Text processing

COPYRIGHT
       Copyright (c) 1999-2000 Marshall T. Rose

tcllib                               1.6.2                          mime(3tcl)

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