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

 

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

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

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

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

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

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

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



mime(n)                                             Mime                                             mime(n)



____________________________________________________________________________________________________________

NAME
       mime - Manipulation of MIME body parts

SYNOPSIS
       package require Tcl

       package require mime  ?1.5.4?

       ::mime::initialize  ?-canonical  type/subtype ?-param {key value}...? ?-encoding value? ?-header {key
       value}...?? (-file name | -string value | -part {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 | -part {token1 ... tokenN})
              This command creates a MIME part and returns a token representing it.

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

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

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

                    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 appropri-ate. appropriate.
                     ate.

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

              If the -subordinates option is  present,  it  specifies  which  subordinates  should  also  be
              destroyed.  The  default  value  is dynamic, 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 properties 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 property 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 corre-sponding corresponding
              sponding value(s) is returned; instead, 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;  how-ever, however,
              ever,  some  keys (e.g., "Received") often occur more than once in the header, accordingly 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 containing the previous value associated with the key.

              The value for -mode is one of:

              write  The key/value is either created or overwritten (the default).

              append A new value is appended for the key (creating it as necessary).

              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::getbody is a string con-taining containing
              taining the MIME part's entire body.

              If the option -decode is absent the return value computed above is returned 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 returning 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  inde-pendently. independently.
              pendently. 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 chan-nel. channel.
              nel.

       ::mime::parseaddress string
              This  command  takes  a  string  containing  one  or more 822-style address 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
       SourceForge Tcllib Bug #447037
              This problem affects only people which are using Tcl and Mime on a  64-bit  system.  The  cur-rently currently
              rently  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  solution  as  it would force a large number of unaffected users to
              upgrade their Tcl interpreter for no reason.

              See   http://sourceforge.net/tracker/?func=detail&aid=447_37&group_id=12883&atid=112883    for
              additional information.


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   SF   Trackers   [http://source -
       forge.net/tracker/? group_id=12883].   Please  also report any ideas for enhancements you may have for
       either package and/or documentation.

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




mime                                                1.5.4                                            mime(n)

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

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

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