mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-15 03:00:30 +00:00
72 lines
2.5 KiB
C
72 lines
2.5 KiB
C
/* -*- 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):
|
|
*/
|
|
|
|
/* mimeleaf.h --- definition of the MimeLeaf class (see mimei.h)
|
|
Created: Jamie Zawinski <jwz@netscape.com>, 15-May-96.
|
|
*/
|
|
|
|
#ifndef _MIMELEAF_H_
|
|
#define _MIMELEAF_H_
|
|
|
|
#include "mimeobj.h"
|
|
#include "mimeenc.h"
|
|
|
|
/* MimeLeaf is the class for the objects representing all MIME types which
|
|
are not containers for other MIME objects. The implication of this is
|
|
that they are MIME types which can have Content-Transfer-Encodings
|
|
applied to their data. This class provides that service in its
|
|
parse_buffer() method:
|
|
|
|
int (*parse_decoded_buffer) (char *buf, int32 size, MimeObject *obj)
|
|
|
|
The `parse_buffer' method of MimeLeaf passes each block of data through
|
|
the appropriate decoder (if any) and then calls `parse_decoded_buffer'
|
|
on each block (not line) of output.
|
|
|
|
The default `parse_decoded_buffer' method of MimeLeaf line-buffers the
|
|
now-decoded data, handing each line to the `parse_line' method in turn.
|
|
If different behavior is desired (for example, if a class wants access
|
|
to the decoded data before it is line-buffered) the `parse_decoded_buffer'
|
|
method should be overridden. (MimeExternalObject does this.)
|
|
*/
|
|
|
|
typedef struct MimeLeafClass MimeLeafClass;
|
|
typedef struct MimeLeaf MimeLeaf;
|
|
|
|
struct MimeLeafClass {
|
|
MimeObjectClass object;
|
|
/* This is the callback that is handed to the decoder. */
|
|
int (*parse_decoded_buffer) (char *buf, int32 size, MimeObject *obj);
|
|
};
|
|
|
|
extern MimeLeafClass mimeLeafClass;
|
|
|
|
struct MimeLeaf {
|
|
MimeObject object; /* superclass variables */
|
|
|
|
/* If we're doing Base64, Quoted-Printable, or UU decoding, this is the
|
|
state object for the decoder. */
|
|
MimeDecoderData *decoder_data;
|
|
};
|
|
|
|
#endif /* _MIMELEAF_H_ */
|