mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-04-04 13:42:48 +00:00
More include file cleanup for bug 38061. These files are now all unused. r=blake.
This commit is contained in:
parent
a8c1709124
commit
b4f9bcb51a
@ -5,7 +5,6 @@
|
||||
client.h
|
||||
csid.h
|
||||
ctxtfunc.h
|
||||
dirprefs.h
|
||||
edttypes.h
|
||||
fe_proto.h
|
||||
glhist.h
|
||||
@ -13,14 +12,12 @@ gui.h
|
||||
intl_csi.h
|
||||
libc_r.h
|
||||
libi18n.h
|
||||
libmime.h
|
||||
lo_ele.h
|
||||
merrors.h
|
||||
mime.h
|
||||
mimeenc.h
|
||||
minicom.h
|
||||
mk_cx_fn.h
|
||||
msgcom.h
|
||||
msgtypes.h
|
||||
m_cvstrm.h
|
||||
ncompat.h
|
||||
|
@ -29,7 +29,6 @@ EXPORTS = \
|
||||
intl_csi.h \
|
||||
libi18n.h \
|
||||
merrors.h \
|
||||
msgcom.h \
|
||||
msgtypes.h \
|
||||
net.h \
|
||||
npapi.h \
|
||||
|
@ -1,275 +0,0 @@
|
||||
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
||||
*
|
||||
* The contents of this file are subject to the Netscape Public
|
||||
* License Version 1.1 (the "License"); you may not use this file
|
||||
* except in compliance with the License. You may obtain a copy of
|
||||
* the License at http://www.mozilla.org/NPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS
|
||||
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
||||
* implied. See the License for the specific language governing
|
||||
* rights and limitations under the License.
|
||||
*
|
||||
* The Original Code is mozilla.org code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is Netscape
|
||||
* Communications Corporation. Portions created by Netscape are
|
||||
* Copyright (C) 1998 Netscape Communications Corporation. All
|
||||
* Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
*/
|
||||
|
||||
#ifndef _DIRPREFS_H_
|
||||
#define _DIRPREFS_H_
|
||||
|
||||
#define kCurrentListVersion 1
|
||||
|
||||
/* DIR_Server.dirType */
|
||||
typedef enum
|
||||
{
|
||||
LDAPDirectory,
|
||||
HTMLDirectory,
|
||||
PABDirectory
|
||||
} DirectoryType;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
cn,
|
||||
givenname,
|
||||
sn,
|
||||
mail,
|
||||
telephonenumber,
|
||||
o,
|
||||
ou,
|
||||
l,
|
||||
street,
|
||||
auth,
|
||||
custom1,
|
||||
custom2,
|
||||
custom3,
|
||||
custom4,
|
||||
custom5
|
||||
} DIR_AttributeId;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
capLdapV3, /* LDAP v3.0 protocol */
|
||||
capVirtualListView, /* Virtual list view */
|
||||
|
||||
kNumCaps /* must be last capability */
|
||||
} DIR_ServerCaps;
|
||||
|
||||
/* The values in this enum control the kind of LDAP filter expression
|
||||
* we send to the LDAP server to do name completion
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
acsGivenAndSurname, /* do auto-complete using givenname and sn attributes */
|
||||
acsCnForwards, /* do auto-complete assuming cn in F L order */
|
||||
acsCnBackwards /* do auto-complete assuming cn in L, F order */
|
||||
} DIR_AutoCompleteStyle;
|
||||
|
||||
|
||||
typedef struct _DIR_ReplicationInfo
|
||||
{
|
||||
char *description; /* human readable description of replica */
|
||||
char *fileName; /* file name of replication database */
|
||||
char *filter; /* LDAP filter string which constrains the repl search */
|
||||
int32 lastChangeNumber; /* Last change we saw -- start replicating here */
|
||||
char *dataVersion; /* LDAP server's scoping of the lastChangeNumber */
|
||||
/* this changes when the server's DB gets reloaded from LDIF */
|
||||
char **excludedAttributes; /* list of attributes we shouldn't replicate */
|
||||
int excludedAttributesCount; /* duh */
|
||||
} DIR_ReplicationInfo;
|
||||
|
||||
|
||||
typedef struct DIR_Server
|
||||
{
|
||||
char *description; /* human readable name */
|
||||
char *serverName; /* network host name */
|
||||
char *searchBase; /* DN suffix to search at */
|
||||
char *fileName; /* XP path name of local DB */
|
||||
char *prefId; /* name of this server's tree in JS prefs */
|
||||
int port; /* network port number */
|
||||
int maxHits; /* maximum number of hits to return */
|
||||
XP_Bool isSecure; /* use SSL? */
|
||||
XP_Bool saveResults;
|
||||
XP_Bool efficientWildcards; /* server can match substrings */
|
||||
char *lastSearchString; /* required if saving results */
|
||||
DirectoryType dirType;
|
||||
uint32 flags;
|
||||
uint32 refCount; /* Use count for server */
|
||||
|
||||
/* site-configurable attributes and filters */
|
||||
XP_List *customFilters;
|
||||
XP_List *customAttributes;
|
||||
char *tokenSeps;
|
||||
XP_Bool stopFiltersOnHit;
|
||||
XP_Bool isOffline;
|
||||
|
||||
/* site-configurable list of attributes whose values are DNs */
|
||||
char **dnAttributes;
|
||||
int dnAttributesCount;
|
||||
|
||||
/* site-configurable list of attributes we shouldn't display in HTML */
|
||||
char **suppressedAttributes;
|
||||
int suppressedAttributesCount;
|
||||
|
||||
/* site-configurable list of attributes for the Basic Search dialog */
|
||||
DIR_AttributeId *basicSearchAttributes;
|
||||
int basicSearchAttributesCount;
|
||||
|
||||
/* site-configurable URL to open LDAP results */
|
||||
char *customDisplayUrl;
|
||||
|
||||
/* authentication fields */
|
||||
XP_Bool enableAuth; /* Use DN and password when binding? */
|
||||
XP_Bool savePassword; /* Remember the DN and password we gave? */
|
||||
char *authDn; /* DN to give to authenticate as */
|
||||
char *password; /* Password for the DN */
|
||||
|
||||
/* Ldap fields */
|
||||
DIR_ReplicationInfo *replInfo;
|
||||
char *searchPairList;
|
||||
|
||||
/* auto-complete fields */
|
||||
DIR_AutoCompleteStyle autoCompleteStyle;
|
||||
|
||||
} DIR_Server;
|
||||
|
||||
|
||||
XP_BEGIN_PROTOS
|
||||
|
||||
/* We are developing a new model for managing DIR_Servers. In the 4.0x world, the FEs managed each list.
|
||||
Calls to FE_GetDirServer caused the FEs to manage and return the DIR_Server list. In our new view of the
|
||||
world, the back end does most of the list management so we are going to have the back end create and
|
||||
manage the list. Replace calls to FE_GetDirServers() with DIR_GetDirServers(). */
|
||||
|
||||
XP_List * DIR_GetDirServers(void);
|
||||
int DIR_ShutDown(void); /* FEs should call this when the app is shutting down. It frees all DIR_Servers regardless of ref count values! */
|
||||
|
||||
int DIR_DecrementServerRefCount (DIR_Server *);
|
||||
int DIR_IncrementServerRefCount (DIR_Server *);
|
||||
|
||||
/* We are trying to phase out use of FE_GetDirServers. The back end is now managing the dir server list. So you should
|
||||
be calling DIR_GetDirServers instead. */
|
||||
|
||||
XP_List * FE_GetDirServers(void);
|
||||
|
||||
/* Since the strings in DIR_Server are allocated, we have bottleneck
|
||||
* routines to help with memory mgmt
|
||||
*/
|
||||
int DIR_InitServer (DIR_Server *);
|
||||
int DIR_ValidateServer (DIR_Server *);
|
||||
int DIR_CopyServer (DIR_Server *in, DIR_Server **out);
|
||||
XP_Bool DIR_AreServersSame (DIR_Server *first, DIR_Server *second);
|
||||
|
||||
int DIR_DeleteServer (DIR_Server *);
|
||||
int DIR_DeleteServerList(XP_List *wholeList);
|
||||
|
||||
int DIR_GetLdapServers (XP_List *wholeList, XP_List *subList);
|
||||
int DIR_ReorderLdapServers (XP_List *wholeList);
|
||||
|
||||
/* These two routines should be called to initialize and save
|
||||
* directory preferences from the XP Java Script preferences
|
||||
*/
|
||||
int DIR_GetServerPreferences (XP_List **list, const char* pabFile);
|
||||
int DIR_SaveServerPreferences (XP_List *wholeList);
|
||||
|
||||
/* This routine will clean up files for deleted directories */
|
||||
int DIR_CleanUpServerPreferences(XP_List *deletedList);
|
||||
|
||||
|
||||
#if 1
|
||||
|
||||
/* Returns a pointer into the list (not allocated, so don't free) */
|
||||
int DIR_GetPersonalAddressBook (XP_List *wholeList, DIR_Server **pab);
|
||||
int DIR_GetComposeNameCompletionAddressBook (XP_List *wholeList, DIR_Server **cab);
|
||||
|
||||
/* Returns an allocated list of all personal address books, excluding
|
||||
* LDAP directories, replicated directories, and CABs
|
||||
*/
|
||||
int DIR_GetPersonalAddressBooks (XP_List *wholeList, XP_List * subList);
|
||||
|
||||
#else
|
||||
XP_List *DIR_GetAddressBooksForCompletion (XP_List *wholeList);
|
||||
#endif
|
||||
|
||||
void DIR_GetServerFileName(char** filename, const char* leafName);
|
||||
void DIR_SetServerFileName(DIR_Server* pServer, const char* leafName);
|
||||
|
||||
/* APIs for site-configurability of LDAP attribute names and
|
||||
* search filter behavior.
|
||||
*
|
||||
* Strings are NOT allocated, and arrays are NULL-terminated
|
||||
*/
|
||||
const char *DIR_GetAttributeName (DIR_Server *server, DIR_AttributeId id);
|
||||
const char **DIR_GetAttributeStrings (DIR_Server *server, DIR_AttributeId id);
|
||||
const char *DIR_GetFirstAttributeString (DIR_Server *server, DIR_AttributeId id);
|
||||
const char *DIR_GetFilterString (DIR_Server *server);
|
||||
const char *DIR_GetReplicationFilter (DIR_Server *server);
|
||||
const char *DIR_GetTokenSeparators (DIR_Server *server);
|
||||
XP_Bool DIR_RepeatFilterForTokens (DIR_Server *server, const char *filter);
|
||||
XP_Bool DIR_SubstStarsForSpaces (DIR_Server *server, const char *filter);
|
||||
XP_Bool DIR_UseCustomAttribute (DIR_Server *server, DIR_AttributeId id);
|
||||
|
||||
XP_Bool DIR_IsDnAttribute (DIR_Server *s, const char *attr);
|
||||
XP_Bool DIR_IsAttributeExcludedFromHtml (DIR_Server *s, const char *attr);
|
||||
|
||||
int DIR_AttributeNameToId (const char *attrName, DIR_AttributeId *id);
|
||||
|
||||
/* APIs for authentication */
|
||||
void DIR_SetAuthDN (DIR_Server *s, const char *dn);
|
||||
void DIR_SetPassword (DIR_Server *s, const char *password);
|
||||
|
||||
/* APIs for unescaping LDAP special chars */
|
||||
char *DIR_Unescape (const char *src, XP_Bool makeHtml);
|
||||
XP_Bool DIR_IsEscapedAttribute (DIR_Server *s, const char *attrib);
|
||||
|
||||
/* API for building a URL */
|
||||
char *DIR_BuildUrl (DIR_Server *s, const char *dn, XP_Bool forAddToAB);
|
||||
|
||||
/* Walks the list enforcing the rule that only one LDAP server can be configured for autocomplete */
|
||||
void DIR_SetAutoCompleteEnabled (XP_List *list, DIR_Server *server, XP_Bool enabled);
|
||||
|
||||
/* Flags manipulation */
|
||||
|
||||
#define DIR_AUTO_COMPLETE_ENABLED 0x00000001 /* Directory is configured for autocomplete addressing */
|
||||
#define DIR_ENABLE_AUTH 0x00000002 /* Directory is configured for LDAP simple authentication */
|
||||
#define DIR_SAVE_PASSWORD 0x00000004
|
||||
#define DIR_UTF8_DISABLED 0x00000008 /* not used by the FEs */
|
||||
#define DIR_IS_SECURE 0x00000010
|
||||
#define DIR_SAVE_RESULTS 0x00000020 /* not used by the FEs */
|
||||
#define DIR_EFFICIENT_WILDCARDS 0x00000040 /* not used by the FEs */
|
||||
#define DIR_REPLICATION_ENABLED 0x00000080 /* Directory is configured for offline use */
|
||||
#define DIR_LDAP_PUBLIC_DIRECTORY 0x00000100 /* not used by the FEs */
|
||||
#define DIR_LDAP_VERSION3 0x00000200 /* not used by the FEs */
|
||||
#define DIR_LDAP_VIRTUALLISTVIEW 0x00000400 /* not used by the FEs */
|
||||
#define DIR_LDAP_ROOTDSE_PARSED 0x00000800 /* not used by the FEs */
|
||||
|
||||
XP_Bool DIR_TestFlag (DIR_Server *server, uint32 flag);
|
||||
void DIR_SetFlag (DIR_Server *server, uint32 flag);
|
||||
void DIR_ClearFlag (DIR_Server *server, uint32 flag);
|
||||
void DIR_ForceFlag (DIR_Server *server, uint32 flag, XP_Bool forceOnOrOff);
|
||||
|
||||
char *DIR_ConvertToServerCharSet (DIR_Server *s, char *src, int16 srcCsid);
|
||||
char *DIR_ConvertFromServerCharSet (DIR_Server *s, char *src, int16 dstCsid);
|
||||
|
||||
#ifdef MOZ_LDAP
|
||||
|
||||
/* Does the LDAP client lib work for SSL */
|
||||
#include "ldap.h"
|
||||
|
||||
int DIR_SetupSecureConnection (LDAP *l);
|
||||
|
||||
/* APIs for replication */
|
||||
int DIR_ValidateRootDSE (DIR_Server *s, char *version, int32 first, int32 last);
|
||||
int DIR_ParseRootDSE (DIR_Server *s, LDAP *ld, LDAPMessage *message);
|
||||
|
||||
#endif /* MOZ_LDAP */
|
||||
|
||||
XP_END_PROTOS
|
||||
|
||||
|
||||
#endif /* dirprefs.h */
|
@ -1,561 +0,0 @@
|
||||
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
||||
*
|
||||
* The contents of this file are subject to the Netscape Public
|
||||
* License Version 1.1 (the "License"); you may not use this file
|
||||
* except in compliance with the License. You may obtain a copy of
|
||||
* the License at http://www.mozilla.org/NPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS
|
||||
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
||||
* implied. See the License for the specific language governing
|
||||
* rights and limitations under the License.
|
||||
*
|
||||
* The Original Code is mozilla.org code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is Netscape
|
||||
* Communications Corporation. Portions created by Netscape are
|
||||
* Copyright (C) 1998 Netscape Communications Corporation. All
|
||||
* Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
*/
|
||||
|
||||
/* libmime.h --- external interface to libmime.a
|
||||
Created: Jamie Zawinski <jwz@netscape.com>, 15-May-96.
|
||||
*/
|
||||
|
||||
|
||||
#ifndef _LIBMIME_H_
|
||||
#define _LIBMIME_H_
|
||||
|
||||
#include "xp.h"
|
||||
|
||||
#ifndef MOZILLA_30
|
||||
# define MIME_DRAFTS
|
||||
#endif
|
||||
|
||||
/* Opaque object describing a block of message headers, and a couple of
|
||||
routines for extracting data from one.
|
||||
*/
|
||||
|
||||
typedef struct MimeHeaders
|
||||
{
|
||||
char *all_headers; /* A char* of the entire header section. */
|
||||
int32 all_headers_fp; /* The length (it is not NULL-terminated.) */
|
||||
uint32 all_headers_size; /* The size of the allocated block. */
|
||||
|
||||
XP_Bool done_p; /* Whether we've read the end-of-headers marker
|
||||
(the terminating blank line.) */
|
||||
|
||||
char **heads; /* An array of length n_headers which points
|
||||
to the beginning of each distinct header:
|
||||
just after the newline which terminated
|
||||
the previous one. This is to speed search.
|
||||
|
||||
This is not initialized until all the
|
||||
headers have been read.
|
||||
*/
|
||||
int32 heads_size; /* The length (and consequently, how many
|
||||
distinct headers are in here.) */
|
||||
|
||||
|
||||
char *obuffer; /* This buffer is used for output. */
|
||||
uint32 obuffer_size;
|
||||
int32 obuffer_fp;
|
||||
|
||||
char *munged_subject; /* What a hack. This is a place to write down
|
||||
the subject header, after it's been
|
||||
charset-ified and stuff. Remembered so that
|
||||
we can later use it to generate the
|
||||
<TITLE> tag. */
|
||||
} MimeHeaders;
|
||||
|
||||
typedef struct MimeDisplayOptions MimeDisplayOptions;
|
||||
typedef struct MimeParseStateObject MimeParseStateObject;
|
||||
/*#ifndef MOZILLA_30*/
|
||||
typedef struct MSG_AttachmentData MSG_AttachmentData;
|
||||
/*#endif*/
|
||||
|
||||
XP_BEGIN_PROTOS
|
||||
|
||||
/* Given the name of a header, returns the contents of that header as
|
||||
a newly-allocated string (which the caller must free.) If the header
|
||||
is not present, or has no contents, NULL is returned.
|
||||
|
||||
If `strip_p' is TRUE, then the data returned will be the first token
|
||||
of the header; else it will be the full text of the header. (This is
|
||||
useful for getting just "text/plain" from "text/plain; name=foo".)
|
||||
|
||||
If `all_p' is FALSE, then the first header encountered is used, and
|
||||
any subsequent headers of the same name are ignored. If TRUE, then
|
||||
all headers of the same name are appended together (this is useful
|
||||
for gathering up all CC headers into one, for example.)
|
||||
*/
|
||||
extern char *MimeHeaders_get(MimeHeaders *hdrs,
|
||||
const char *header_name,
|
||||
XP_Bool strip_p,
|
||||
XP_Bool all_p);
|
||||
|
||||
/* Given a header of the form of the MIME "Content-" headers, extracts a
|
||||
named parameter from it, if it exists. For example,
|
||||
MimeHeaders_get_parameter("text/plain; charset=us-ascii", "charset")
|
||||
would return "us-ascii".
|
||||
|
||||
Returns NULL if there is no match, or if there is an allocation failure.
|
||||
|
||||
RFC2231 - MIME Parameter Value and Encoded Word Extensions: Character Sets,
|
||||
Languages, and Continuations
|
||||
|
||||
RFC2231 has added the character sets, languages, and continuations mechanism.
|
||||
charset, and language information may also be returned to the caller.
|
||||
For example,
|
||||
MimeHeaders_get_parameter("text/plain; name*=us-ascii'en-us'This%20is%20%2A%2A%2Afun%2A%2A%2A", "name")
|
||||
MimeHeaders_get_parameter("text/plain; name*0*=us-ascii'en-us'This%20is%20; CRLFLWSPname*1*=%2A%2A%2Afun%2A%2A%2A", "name")
|
||||
would return "This is ***fun***" and *charset = "us-ascii", *language = "en-us"
|
||||
*/
|
||||
extern char *MimeHeaders_get_parameter (const char *header_value,
|
||||
const char *parm_name,
|
||||
char **charset,
|
||||
char **language);
|
||||
|
||||
extern MimeHeaders *MimeHeaders_copy (MimeHeaders *srcHeaders);
|
||||
|
||||
extern void MimeHeaders_free (MimeHeaders *hdrs);
|
||||
|
||||
/* Some defines for various standard header field names.
|
||||
*/
|
||||
#define HEADER_BCC "BCC"
|
||||
#define HEADER_CC "CC"
|
||||
#define HEADER_CONTENT_BASE "Content-Base"
|
||||
#define HEADER_CONTENT_DESCRIPTION "Content-Description"
|
||||
#define HEADER_CONTENT_DISPOSITION "Content-Disposition"
|
||||
#define HEADER_CONTENT_ENCODING "Content-Encoding"
|
||||
#define HEADER_CONTENT_LENGTH "Content-Length"
|
||||
#define HEADER_CONTENT_NAME "Content-Name"
|
||||
#define HEADER_CONTENT_TRANSFER_ENCODING "Content-Transfer-Encoding"
|
||||
#define HEADER_CONTENT_TYPE "Content-Type"
|
||||
#define HEADER_DATE "Date"
|
||||
#define HEADER_DISTRIBUTION "Distribution"
|
||||
#define HEADER_FCC "FCC"
|
||||
#define HEADER_FOLLOWUP_TO "Followup-To"
|
||||
#define HEADER_FROM "From"
|
||||
#define HEADER_LINES "Lines"
|
||||
#define HEADER_MESSAGE_ID "Message-ID"
|
||||
#define HEADER_MIME_VERSION "MIME-Version"
|
||||
#define HEADER_NEWSGROUPS "Newsgroups"
|
||||
#define HEADER_ORGANIZATION "Organization"
|
||||
#define HEADER_REFERENCES "References"
|
||||
#define HEADER_REPLY_TO "Reply-To"
|
||||
#define HEADER_RESENT_COMMENTS "Resent-Comments"
|
||||
#define HEADER_RESENT_DATE "Resent-Date"
|
||||
#define HEADER_RESENT_FROM "Resent-From"
|
||||
#define HEADER_RESENT_MESSAGE_ID "Resent-Message-ID"
|
||||
#define HEADER_RESENT_SENDER "Resent-Sender"
|
||||
#define HEADER_RESENT_TO "Resent-To"
|
||||
#define HEADER_RESENT_CC "Resent-CC"
|
||||
#define HEADER_SENDER "Sender"
|
||||
#define HEADER_SUBJECT "Subject"
|
||||
#define HEADER_TO "To"
|
||||
#define HEADER_X_MAILER "X-Mailer"
|
||||
#define HEADER_X_NEWSREADER "X-Newsreader"
|
||||
#define HEADER_X_POSTING_SOFTWARE "X-Posting-Software"
|
||||
#define HEADER_X_MOZILLA_STATUS "X-Mozilla-Status"
|
||||
#define HEADER_X_MOZILLA_NEWSHOST "X-Mozilla-News-Host"
|
||||
#define HEADER_X_MOZILLA_DRAFT_INFO "X-Mozilla-Draft-Info"
|
||||
#define HEADER_X_UIDL "X-UIDL"
|
||||
#define HEADER_XREF "XREF"
|
||||
#define HEADER_X_SUN_CHARSET "X-Sun-Charset"
|
||||
#define HEADER_X_SUN_CONTENT_LENGTH "X-Sun-Content-Length"
|
||||
#define HEADER_X_SUN_CONTENT_LINES "X-Sun-Content-Lines"
|
||||
#define HEADER_X_SUN_DATA_DESCRIPTION "X-Sun-Data-Description"
|
||||
#define HEADER_X_SUN_DATA_NAME "X-Sun-Data-Name"
|
||||
#define HEADER_X_SUN_DATA_TYPE "X-Sun-Data-Type"
|
||||
#define HEADER_X_SUN_ENCODING_INFO "X-Sun-Encoding-Info"
|
||||
#define HEADER_X_PRIORITY "X-Priority"
|
||||
|
||||
#define HEADER_PARM_BOUNDARY "BOUNDARY"
|
||||
#define HEADER_PARM_FILENAME "FILENAME"
|
||||
#define HEADER_PARM_NAME "NAME"
|
||||
#define HEADER_PARM_TYPE "TYPE"
|
||||
|
||||
|
||||
typedef enum {
|
||||
MimeHeadersAll, /* Show all headers */
|
||||
MimeHeadersSome, /* Show all "interesting" headers */
|
||||
MimeHeadersSomeNoRef, /* Same, but suppress the `References' header
|
||||
(for when we're printing this message.) */
|
||||
MimeHeadersMicro, /* Show a one-line header summary */
|
||||
MimeHeadersMicroPlus, /* Same, but show the full recipient list as
|
||||
well (To, CC, etc.) */
|
||||
MimeHeadersCitation /* A one-line summary geared toward use in a
|
||||
reply citation ("So-and-so wrote:") */
|
||||
} MimeHeadersState;
|
||||
|
||||
|
||||
/* The signature for various callbacks in the MimeDisplayOptions structure.
|
||||
*/
|
||||
typedef char *(*MimeHTMLGeneratorFunction) (const char *data, void *closure,
|
||||
MimeHeaders *headers);
|
||||
|
||||
struct MimeDisplayOptions
|
||||
{
|
||||
const char *url; /* Base URL for the document. This string should
|
||||
be freed by the caller, after the parser
|
||||
completes (possibly at the same time as the
|
||||
MimeDisplayOptions itself.) */
|
||||
|
||||
#ifndef MOZILLA_30
|
||||
MSG_Pane* pane; /* The libmsg pane object that corresponds to
|
||||
what we're showing. This is used by very
|
||||
little... */
|
||||
#endif /* !MOZILLA_30 */
|
||||
|
||||
MimeHeadersState headers; /* How headers should be displayed. */
|
||||
XP_Bool fancy_headers_p; /* Whether to do clever formatting of headers
|
||||
using tables, instead of spaces. */
|
||||
|
||||
#ifndef MOZILLA_30
|
||||
XP_Bool output_vcard_buttons_p; /* Whether to output the buttons */
|
||||
/* on vcards. */
|
||||
#endif /* !MOZILLA_30 */
|
||||
|
||||
XP_Bool fancy_links_p; /* Whether to insert fancy links, so you can
|
||||
do things like click on an email address to
|
||||
add it to your address book. Something you
|
||||
don't want to do while printing. */
|
||||
|
||||
XP_Bool variable_width_plaintext_p; /* Whether text/plain messages should
|
||||
be in variable width, or fixed. */
|
||||
XP_Bool wrap_long_lines_p; /* Whether to wrap long lines in text/plain
|
||||
messages. */
|
||||
|
||||
XP_Bool rot13_p; /* Whether text/plain parts should be rotated
|
||||
Set by "?rot13=true" */
|
||||
XP_Bool no_inline_p; /* Whether inline display of attachments should
|
||||
be suppressed. Set by "?inline=false" */
|
||||
char *part_to_load; /* The particular part of the multipart which
|
||||
we are extracting. Set by "?part=3.2.4" */
|
||||
|
||||
XP_Bool write_html_p; /* Whether the output should be HTML, or raw. */
|
||||
|
||||
XP_Bool decrypt_p; /* Whether all traces of encryption should be
|
||||
eradicated -- this is only meaningful when
|
||||
write_html_p is FALSE; we set this when
|
||||
attaching a message for forwarding, since
|
||||
forwarding someone else a message that wasn't
|
||||
encrypted for them doesn't work. We have to
|
||||
decrypt it before sending it.
|
||||
*/
|
||||
|
||||
#ifndef MOZILLA_30
|
||||
XP_Bool nice_html_only_p; /* If TRUE, then we only should write html if
|
||||
it's pretty HTML (stuff that we're willing
|
||||
to get shipped out in mail messages). If we
|
||||
can't generate nice stuff for some part,
|
||||
then don't say anything at all. */
|
||||
|
||||
XP_Bool dont_touch_citations_p; /* If TRUE, then we should leave citations
|
||||
alone in plaintext parts. If FALSE, then
|
||||
go ahead and tweak the fonts according
|
||||
to preferences. */
|
||||
#endif /* !MOZILLA_30 */
|
||||
|
||||
char *default_charset; /* If this is non-NULL, then it is the charset to
|
||||
assume when no other one is specified via a
|
||||
`charset' parameter.
|
||||
*/
|
||||
char *override_charset; /* If this is non-NULL, then we will assume that
|
||||
all data is in this charset, regardless of what
|
||||
the `charset' parameter of that part says.
|
||||
This overrides `default_charset' as well.
|
||||
(This is to cope with the fact that, in the
|
||||
real world, many messages are mislabelled with
|
||||
the wrong charset.)
|
||||
*/
|
||||
|
||||
/* =======================================================================
|
||||
Stream-related callbacks; for these functions, the `closure' argument
|
||||
is what is found in `options->stream_closure'. (One possible exception
|
||||
is for output_fn; see "output_closure" below.)
|
||||
*/
|
||||
void *stream_closure;
|
||||
|
||||
/* For setting up the display stream, so that the MIME parser can inform
|
||||
the caller of the type of the data it will be getting. */
|
||||
int (*output_init_fn) (const char *type,
|
||||
const char *charset,
|
||||
const char *name,
|
||||
const char *x_mac_type,
|
||||
const char *x_mac_creator,
|
||||
void *stream_closure);
|
||||
|
||||
/* How the MIME parser feeds its output (HTML or raw) back to the caller. */
|
||||
int (*output_fn) (char *buf, int32 size, void *closure);
|
||||
|
||||
/* Closure to pass to the above output_fn. If NULL, then the
|
||||
stream_closure is used. */
|
||||
void *output_closure;
|
||||
|
||||
/* A callback used to encapsulate an HTML section and to reset the
|
||||
HTML parser to its default state at the end of a section.
|
||||
start_p indicates whether this is being called just before the
|
||||
start or immediately after the end of the encapsulated HTML.
|
||||
layer_encapsulate_p indicates whether or not to put special
|
||||
ILAYER container tags around the HTML -- Also, when start_p is
|
||||
FALSE, this function should close off any tags we've left open,
|
||||
reset the font size and face, etc. This may be called multiple
|
||||
times -- in particular, it will be called at the end of each
|
||||
message part which might contain human-generated (and thus
|
||||
arbitrarily buggy) markup. The `abort_p' argument specifies
|
||||
whether it's ok for data to be discarded.
|
||||
*/
|
||||
int (*set_html_state_fn) (void *stream_closure,
|
||||
XP_Bool layer_encapsulate_p,
|
||||
XP_Bool start_p,
|
||||
XP_Bool abort_p);
|
||||
|
||||
/* A hook for the caller to perform charset-conversion before HTML is
|
||||
returned. Each set of characters which originated in a mail message
|
||||
(body or headers) will be run through this filter before being converted
|
||||
into HTML. (This should return bytes which may appear in an HTML file,
|
||||
ie, we must be able to scan through the string to search for "<" and
|
||||
turn it in to "<", and so on.)
|
||||
|
||||
`input' is a non-NULL-terminated string of a single line from the message.
|
||||
`input_length' is how long it is.
|
||||
`input_charset' is a string representing the charset of this string (as
|
||||
specified by MIME headers.)
|
||||
`output_charset' is the charset to which conversion is desired.
|
||||
`output_ret' is where a newly-malloced string is returned. It may be
|
||||
NULL if no translation is needed.
|
||||
`output_size_ret' is how long the returned string is (it need not be
|
||||
NULL-terminated.).
|
||||
*/
|
||||
int (*charset_conversion_fn) (const char *input_line, int32 input_length,
|
||||
const char *input_charset,
|
||||
const char *output_charset,
|
||||
char **output_ret, int32 *output_size_ret,
|
||||
void *stream_closure);
|
||||
|
||||
/* A hook for the caller to perform both charset-conversion and decoding of
|
||||
MIME-2 header fields (using RFC-1522 encoding.) Arguments and returned
|
||||
values are as for `charset_conversion_fn'.
|
||||
*/
|
||||
int (*rfc1522_conversion_fn) (const char *input_line, int32 input_length,
|
||||
const char *input_charset,
|
||||
const char *output_charset,
|
||||
char **output_ret, int32 *output_size_ret,
|
||||
void *stream_closure);
|
||||
|
||||
/* A hook for the caller to translate a time string into a prettier or more
|
||||
compact or localized form. */
|
||||
char *(*reformat_date_fn) (const char *old_date, void *stream_closure);
|
||||
|
||||
/* A hook for the caller to turn a file name into a content-type. */
|
||||
char *(*file_type_fn) (const char *filename, void *stream_closure);
|
||||
|
||||
/* A hook for the caller to turn a content-type into descriptive text. */
|
||||
char *(*type_description_fn) (const char *content_type,void *stream_closure);
|
||||
|
||||
/* A hook for the caller to turn a content-type into an image icon. */
|
||||
char *(*type_icon_name_fn) (const char *content_type, void *stream_closure);
|
||||
|
||||
/* A hook by which the user may be prompted for a password by the security
|
||||
library. (This is really of type `SECKEYGetPasswordKey'; see sec.h.) */
|
||||
void *(*passwd_prompt_fn)(void *arg1, void *arg2);
|
||||
void *passwd_prompt_fn_arg;
|
||||
|
||||
/* =======================================================================
|
||||
Various callbacks; for all of these functions, the `closure' argument
|
||||
is what is found in `html_closure'.
|
||||
*/
|
||||
void *html_closure;
|
||||
|
||||
/* For emitting some HTML before the start of the outermost message
|
||||
(this is called before any HTML is written to layout.) */
|
||||
MimeHTMLGeneratorFunction generate_header_html_fn;
|
||||
|
||||
/* For emitting some HTML after the outermost header block, but before
|
||||
the body of the first message. */
|
||||
MimeHTMLGeneratorFunction generate_post_header_html_fn;
|
||||
|
||||
/* For emitting some HTML at the very end (this is called after libmime
|
||||
has written everything it's going to write.) */
|
||||
MimeHTMLGeneratorFunction generate_footer_html_fn;
|
||||
|
||||
/* For turning a message ID into a loadable URL. */
|
||||
MimeHTMLGeneratorFunction generate_reference_url_fn;
|
||||
|
||||
/* For turning a mail address into a mailto URL. */
|
||||
MimeHTMLGeneratorFunction generate_mailto_url_fn;
|
||||
|
||||
/* For turning a newsgroup name into a news URL. */
|
||||
MimeHTMLGeneratorFunction generate_news_url_fn;
|
||||
|
||||
/* =======================================================================
|
||||
Callbacks to handle the backend-specific inlined image display
|
||||
(internal-external-reconnect junk.) For `image_begin', the `closure'
|
||||
argument is what is found in `stream_closure'; but for all of the
|
||||
others, the `closure' argument is the data that `image_begin' returned.
|
||||
*/
|
||||
|
||||
/* Begins processing an embedded image; the URL and content_type are of the
|
||||
image itself. */
|
||||
void *(*image_begin) (const char *image_url, const char *content_type,
|
||||
void *stream_closure);
|
||||
|
||||
/* Stop processing an image. */
|
||||
void (*image_end) (void *image_closure, int status);
|
||||
|
||||
/* Dump some raw image data down the stream. */
|
||||
int (*image_write_buffer) (char *buf, int32 size, void *image_closure);
|
||||
|
||||
/* What HTML should be dumped out for this image. */
|
||||
char *(*make_image_html) (void *image_closure);
|
||||
|
||||
|
||||
/* =======================================================================
|
||||
Other random opaque state.
|
||||
*/
|
||||
MimeParseStateObject *state; /* Some state used by libmime internals;
|
||||
initialize this to 0 and leave it alone.
|
||||
*/
|
||||
|
||||
|
||||
#ifdef MIME_DRAFTS
|
||||
/* =======================================================================
|
||||
Mail Draft hooks -- 09-19-1996
|
||||
*/
|
||||
XP_Bool decompose_file_p; /* are we decomposing a mime msg
|
||||
into separate files */
|
||||
XP_Bool done_parsing_outer_headers; /* are we done parsing the outer message
|
||||
headers; this is really useful when
|
||||
we have multiple Message/RFC822
|
||||
headers */
|
||||
XP_Bool is_multipart_msg; /* are we decomposing a multipart
|
||||
message */
|
||||
|
||||
int decompose_init_count; /* used for non multipart message only
|
||||
*/
|
||||
|
||||
XP_Bool signed_p; /* to tell draft this is a signed
|
||||
message */
|
||||
|
||||
/* Callback to gather the outer most headers so we could use the
|
||||
information to initialize the addressing/subject/newsgroups fields
|
||||
for the composition window. */
|
||||
int (*decompose_headers_info_fn) (void *closure,
|
||||
MimeHeaders *headers);
|
||||
|
||||
/* Callbacks to create temporary files for drafts attachments. */
|
||||
int (*decompose_file_init_fn) (void *stream_closure,
|
||||
MimeHeaders *headers );
|
||||
|
||||
int (*decompose_file_output_fn) (char *buf, int32 size,
|
||||
void *stream_closure);
|
||||
|
||||
int (*decompose_file_close_fn) (void *stream_closure);
|
||||
#endif /* MIME_DRAFTS */
|
||||
|
||||
int32 attachment_icon_layer_id; /* Hackhackhack. This is zero if we have
|
||||
not yet emitted the attachment layer
|
||||
stuff. If we have, then this is the
|
||||
id number for that layer, which is a
|
||||
unique random number every time, to keep
|
||||
evil people from writing javascript code
|
||||
to hack it. */
|
||||
|
||||
XP_Bool missing_parts; /* Whether or not this message is going to contain
|
||||
missing parts (from IMAP Mime Parts On Demand) */
|
||||
|
||||
};
|
||||
|
||||
|
||||
|
||||
/* Mozilla-specific interfaces
|
||||
*/
|
||||
|
||||
/* Given a URL, this might return a better suggested name to save it as.
|
||||
|
||||
When you have a URL, you can sometimes get a suggested name from
|
||||
URL_s->content_name, but if you're saving a URL to disk before the
|
||||
URL_Struct has been filled in by netlib, you don't have that yet.
|
||||
|
||||
So if you're about to prompt for a file name *before* you call FE_GetURL
|
||||
with a format_out of FO_SAVE_AS, call this function first to see if it
|
||||
can offer you advice about what the suggested name for that URL should be.
|
||||
|
||||
(This works by looking in a cache of recently-displayed MIME objects, and
|
||||
seeing if this URL matches. If it does, the remembered content-name will
|
||||
be used.)
|
||||
*/
|
||||
extern char *MimeGuessURLContentName(MWContext *context, const char *url);
|
||||
|
||||
/* Given a URL, return the content type for the mime part, if the passed context
|
||||
recently parsed a message containing the part specified by the URL.
|
||||
This is used to figure out if we need to open the url in a browser window,
|
||||
or if we're just going to do a save as, anyay.
|
||||
*/
|
||||
extern char *MimeGetURLContentType(MWContext *context, const char *url);
|
||||
|
||||
|
||||
/* Determines whether the given context is currently showing a text/html
|
||||
message. (Used by libmsg to determine if replys should bring up the
|
||||
text/html editor. */
|
||||
|
||||
extern XP_Bool MimeShowingTextHtml(MWContext* context);
|
||||
|
||||
|
||||
|
||||
/* Yeech, hack... Determine the URL to use to save just the HTML part of the
|
||||
currently-displayed message to disk. If the current message doesn't have
|
||||
a text/html part, returns NULL. Otherwise, the caller must free the
|
||||
returned string using XP_FREE(). */
|
||||
|
||||
extern char* MimeGetHtmlPartURL(MWContext* context);
|
||||
|
||||
|
||||
/* Return how many attachments are in the currently-displayed message. */
|
||||
extern int MimeGetAttachmentCount(MWContext* context);
|
||||
|
||||
/* Returns what attachments are being viewed in the currently-displayed
|
||||
message. The returned data must be free'd using
|
||||
MimeFreeAttachmentList(). */
|
||||
extern int MimeGetAttachmentList(MWContext* context,
|
||||
MSG_AttachmentData** data);
|
||||
|
||||
extern void MimeFreeAttachmentList(MSG_AttachmentData* data);
|
||||
|
||||
|
||||
/* Call this when destroying a context; this frees up some memory.
|
||||
*/
|
||||
extern void MimeDestroyContextData(MWContext *context);
|
||||
|
||||
|
||||
/* After a message has been fully displayed (the document has finished
|
||||
loading) FEs call this with a Mail or News window to determine how
|
||||
the "security" toolbar button should be rendered.
|
||||
|
||||
The first two values are whether it was an encrypted and/or signed
|
||||
message; the second two are whether it was *valid*.
|
||||
*/
|
||||
extern void MIME_GetMessageCryptoState(MWContext *context,
|
||||
XP_Bool *signed_return,
|
||||
XP_Bool *encrypted_return,
|
||||
XP_Bool *signed_ok_return,
|
||||
XP_Bool *encrypted_ok_return);
|
||||
|
||||
#ifndef MOZILLA_30
|
||||
/* Used only by libnet, this indicates that the user bonked on the "show me
|
||||
details about attachments" button. */
|
||||
|
||||
extern int MIME_DisplayAttachmentPane(MWContext* context);
|
||||
#endif /* MOZILLA_30 */
|
||||
|
||||
/* Register message/rfc822, message/news, etc. with netlib. */
|
||||
extern void MIME_RegisterConverters(void);
|
||||
|
||||
|
||||
XP_END_PROTOS
|
||||
|
||||
#endif /* _LIBMIME_H_ */
|
@ -54,7 +54,6 @@ EXPORTS = \
|
||||
libi18n.h \
|
||||
merrors.h \
|
||||
minicom.h \
|
||||
msgcom.h \
|
||||
msgtypes.h \
|
||||
net.h \
|
||||
npapi.h \
|
||||
|
2616
include/msgcom.h
2616
include/msgcom.h
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user