home *** CD-ROM | disk | FTP | other *** search
/ Tools / WinSN5.0Ver.iso / NETSCAP.50 / WIN1998.ZIP / ns / lib / libmime / mimemrel.h < prev    next >
Encoding:
C/C++ Source or Header  |  1998-04-08  |  2.4 KB  |  78 lines

  1. /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
  2.  *
  3.  * The contents of this file are subject to the Netscape Public License
  4.  * Version 1.0 (the "NPL"); you may not use this file except in
  5.  * compliance with the NPL.  You may obtain a copy of the NPL at
  6.  * http://www.mozilla.org/NPL/
  7.  *
  8.  * Software distributed under the NPL is distributed on an "AS IS" basis,
  9.  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
  10.  * for the specific language governing rights and limitations under the
  11.  * NPL.
  12.  *
  13.  * The Initial Developer of this code under the NPL is Netscape
  14.  * Communications Corporation.  Portions created by Netscape are
  15.  * Copyright (C) 1998 Netscape Communications Corporation.  All Rights
  16.  * Reserved.
  17.  */
  18.  
  19. /* mimemrel.h --- definition of the MimeMultipartRelated class (see mimei.h)
  20.    Created: Jamie Zawinski <jwz@netscape.com>, 15-May-96.
  21.  */
  22.  
  23. #ifndef _MIMEMREL_H_
  24. #define _MIMEMREL_H_
  25.  
  26. #include "mimemult.h"
  27. #include "xp_hash.h"
  28.  
  29.  
  30. /* The MimeMultipartRelated class implements the multipart/related MIME 
  31.    container, which allows `sibling' sub-parts to refer to each other.
  32.  */
  33.  
  34. typedef struct MimeMultipartRelatedClass MimeMultipartRelatedClass;
  35. typedef struct MimeMultipartRelated      MimeMultipartRelated;
  36.  
  37. struct MimeMultipartRelatedClass {
  38.     MimeMultipartClass multipart;
  39. };
  40.  
  41. extern MimeMultipartRelatedClass mimeMultipartRelatedClass;
  42.  
  43. struct MimeMultipartRelated {
  44.     MimeMultipart multipart;    /* superclass variables */
  45.  
  46.     char* base_url;                /* Base URL (if any) for the whole
  47.                                    multipart/related. */
  48.  
  49.     char* head_buffer;            /* Buffer used to remember the text/html 'head'
  50.                                    part. */
  51.     int32 head_buffer_fp;        /* Active length. */
  52.     int32 head_buffer_size;        /* How big it is. */
  53.     
  54.     char *file_buffer_name;        /* The name of a temp file used when we
  55.                                    run out of room in the head_buffer. */
  56.     XP_File file_stream;        /* A stream to it. */
  57.  
  58.     MimeHeaders* buffered_hdrs;    /* The headers of the 'head' part. */
  59.  
  60.     XP_Bool head_loaded;        /* Whether we've already passed the 'head'
  61.                                    part. */
  62.     MimeObject* headobj;        /* The actual text/html head object. */
  63.  
  64.     XP_HashTable hash;            /* Conversion between URLs and part URLs. */
  65.  
  66.     int (*real_output_fn) (char *buf, int32 size, void *stream_closure);
  67.     void* real_output_closure;
  68.  
  69.     char* curtag;
  70.     int32 curtag_max;
  71.     int32 curtag_length;
  72.  
  73.  
  74.  
  75. };
  76.  
  77. #endif /* _MIMEMREL_H_ */
  78.