1997-08-18 17:14:26 +02:00
|
|
|
\section{Standard Module \sectcode{ic}}
|
1998-02-18 16:10:24 +01:00
|
|
|
\label{module-ic}
|
1997-08-18 17:14:26 +02:00
|
|
|
\bimodindex{ic}
|
|
|
|
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
This module provides access to Macintosh Internet Config package,
|
1997-08-18 17:14:26 +02:00
|
|
|
which stores preferences for Internet programs such as mail address,
|
|
|
|
default homepage, etc. Also, Internet Config contains an elaborate set
|
|
|
|
of mappings from Macintosh creator/type codes to foreign filename
|
|
|
|
extensions plus information on how to transfer files (binary, ascii,
|
1998-03-14 23:22:14 +01:00
|
|
|
etc).
|
1997-08-18 17:14:26 +02:00
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
There is a low-level companion module
|
|
|
|
\module{icglue}\refbimodindex{icglue} which provides the basic
|
|
|
|
Internet Config access functionality. This low-level module is not
|
1997-08-18 17:14:26 +02:00
|
|
|
documented, but the docstrings of the routines document the parameters
|
1998-03-14 23:22:14 +01:00
|
|
|
and the routine names are the same as for the Pascal or \C{} API to
|
|
|
|
Internet Config, so the standard IC programmers' documentation can be
|
1997-08-18 17:14:26 +02:00
|
|
|
used if this module is needed.
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
The \module{ic} module defines the \exception{error} exception and
|
|
|
|
symbolic names for all error codes Internet Config can produce; see
|
|
|
|
the source for details.
|
1997-08-18 17:14:26 +02:00
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\begin{excdesc}{error}
|
|
|
|
Exception raised on errors in the \module{ic} module.
|
|
|
|
\end{excdesc}
|
1997-08-18 17:14:26 +02:00
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
|
|
|
|
The \module{ic} module defines the following functions:
|
|
|
|
|
|
|
|
\begin{funcdesc}{IC}{\optional{signature\optional{, ic}}}
|
1997-08-18 17:14:26 +02:00
|
|
|
Create an internet config object. The signature is a 4-char creator
|
|
|
|
code of the current application (default \code{'Pyth'}) which may
|
|
|
|
influence some of ICs settings. The optional \var{ic} argument is a
|
1998-03-14 23:22:14 +01:00
|
|
|
low-level \code{icglue.icinstance} created beforehand, this may be
|
|
|
|
useful if you want to get preferences from a different config file,
|
|
|
|
etc.
|
1997-08-18 17:14:26 +02:00
|
|
|
\end{funcdesc}
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\begin{funcdesc}{launchurl}{url\optional{, hint}}
|
|
|
|
\funcline{parseurl}{data\optional{, start\optional{, end\optional{, hint}}}}
|
|
|
|
\funcline{mapfile}{file}
|
|
|
|
\funcline{maptypecreator}{type, creator\optional{, filename}}
|
|
|
|
\funcline{settypecreator}{file}
|
1997-08-18 17:14:26 +02:00
|
|
|
These functions are ``shortcuts'' to the methods of the same name,
|
|
|
|
described below.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
|
|
|
|
|
|
|
\subsection{IC objects}
|
|
|
|
|
|
|
|
IC objects have a mapping interface, hence to obtain the mail address
|
1998-03-14 23:22:14 +01:00
|
|
|
you simply get \code{\var{ic}['MailAddress']}. Assignment also works,
|
|
|
|
and changes the option in the configuration file.
|
1997-08-18 17:14:26 +02:00
|
|
|
|
|
|
|
The module knows about various datatypes, and converts the internal IC
|
|
|
|
representation to a ``logical'' python datastructure. Running the
|
1998-03-14 23:22:14 +01:00
|
|
|
\module{ic} module standalone will run a test program that lists all
|
1997-08-18 17:14:26 +02:00
|
|
|
keys and values in your IC database, this will have to server as
|
|
|
|
documentation.
|
|
|
|
|
|
|
|
If the module does not know how to represent the data it returns an
|
1998-03-14 23:22:14 +01:00
|
|
|
instance of the \code{ICOpaqueData} type, with the raw data in its
|
1997-08-18 17:14:26 +02:00
|
|
|
\var{data} attribute. Objects of this type are also acceptable values
|
|
|
|
for assignment.
|
|
|
|
|
|
|
|
Besides the dictionary interface IC objects have the following methods:
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\setindexsubitem{(IC attribute)}
|
1997-08-18 17:14:26 +02:00
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\begin{funcdesc}{launchurl}{url\optional{, hint}}
|
1997-08-18 17:14:26 +02:00
|
|
|
Parse the given URL, lauch the correct application and pass it the
|
|
|
|
URL. The optional \var{hint} can be a scheme name such as
|
1998-03-14 23:22:14 +01:00
|
|
|
\code{'mailto:'}, in which case incomplete URLs are completed with this
|
|
|
|
scheme. If \var{hint} is not provided, incomplete URLs are invalid.
|
1997-08-18 17:14:26 +02:00
|
|
|
\end{funcdesc}
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\begin{funcdesc}{parseurl}{data\optional{, start\optional{, end\optional{, hint}}}}
|
1997-08-18 17:14:26 +02:00
|
|
|
Find an URL somewhere in \var{data} and return start position, end
|
|
|
|
position and the URL. The optional \var{start} and \var{end} can be
|
|
|
|
used to limit the search, so for instance if a user clicks in a long
|
|
|
|
textfield you can pass the whole textfield and the click-position in
|
|
|
|
\var{start} and this routine will return the whole URL in which the
|
1998-03-14 23:22:14 +01:00
|
|
|
user clicked. \var{Hint} is again an optional scheme used to complete
|
1997-08-18 17:14:26 +02:00
|
|
|
incomplete URLs.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
|
|
|
\begin{funcdesc}{mapfile}{file}
|
|
|
|
Return the mapping entry for the given \var{file}, which can be passed
|
1998-03-14 23:22:14 +01:00
|
|
|
as either a filename or an \code{macfs.FSSpec} object, and which need
|
|
|
|
not exist.
|
1997-08-18 17:14:26 +02:00
|
|
|
|
1997-12-29 19:53:31 +01:00
|
|
|
The mapping entry is returned as a tuple \code{(}\var{version},
|
|
|
|
\var{type}, \var{creator}, \var{postcreator}, \var{flags},
|
|
|
|
\var{extension}, \var{appname}, \var{postappname}, \var{mimetype},
|
|
|
|
\var{entryname}\code{)}, where \var{version} is the entry version
|
1997-08-18 17:14:26 +02:00
|
|
|
number, \var{type} is the 4-char filetype, \var{creator} is the 4-char
|
|
|
|
creator type, \var{postcreator} is the 4-char creator code of an
|
|
|
|
optional application to post-process the file after downloading,
|
|
|
|
\var{flags} are various bits specifying whether to transfer in binary
|
|
|
|
or ascii and such, \var{extension} is the filename extension for this
|
|
|
|
file type, \var{appname} is the printable name of the application to
|
|
|
|
which this file belongs, \var{postappname} is the name of the
|
|
|
|
postprocessing application, \var{mimetype} is the MIME type of this
|
|
|
|
file and \var{entryname} is the name of this entry.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
1998-03-14 23:22:14 +01:00
|
|
|
\begin{funcdesc}{maptypecreator}{type, creator\optional{, filename}}
|
1997-08-18 17:14:26 +02:00
|
|
|
Return the mapping entry for files with given 4-char \var{type} and
|
|
|
|
\var{creator} codes. The optional \var{filename} may be specified to
|
|
|
|
further help finding the correct entry (if the creator code is
|
|
|
|
\code{'????'}, for instance).
|
|
|
|
|
|
|
|
The mapping entry is returned in the same format as for \var{mapfile}.
|
|
|
|
\end{funcdesc}
|
|
|
|
|
|
|
|
\begin{funcdesc}{settypecreator}{file}
|
|
|
|
Given an existing \var{file}, specified either as a filename or as an
|
1998-03-14 23:22:14 +01:00
|
|
|
\code{macfs.FSSpec} record, set its creator and type correctly based
|
|
|
|
on its extension. The finder is told about the change, so the finder
|
|
|
|
icon will be updated quickly.
|
1997-08-18 17:14:26 +02:00
|
|
|
\end{funcdesc}
|