1998-06-23 02:39:40 +04:00
|
|
|
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
1999-11-06 06:43:54 +03:00
|
|
|
* 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/
|
1998-06-23 02:39:40 +04:00
|
|
|
*
|
1999-11-06 06:43:54 +03:00
|
|
|
* 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.
|
1998-06-23 02:39:40 +04:00
|
|
|
*
|
1999-11-06 06:43:54 +03:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
1998-06-23 02:39:40 +04:00
|
|
|
* Communications Corporation. Portions created by Netscape are
|
1999-11-06 06:43:54 +03:00
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
1998-06-23 02:39:40 +04:00
|
|
|
*/
|
|
|
|
/* msgutils.h --- various and sundry
|
|
|
|
*/
|
|
|
|
|
|
|
|
XP_BEGIN_PROTOS
|
|
|
|
|
|
|
|
/* Interface to FE_GetURL, which should never be called directly by anything
|
|
|
|
else in libmsg. The "issafe" argument is TRUE if this is a URL which we
|
|
|
|
consider very safe, and will never screw up or be screwed by any activity
|
|
|
|
going on in the foreground. Be very very sure of yourself before ever
|
|
|
|
passing TRUE to the "issafe" argument. */
|
|
|
|
|
|
|
|
extern int msg_GetURL(MWContext* context, URL_Struct* url, XP_Bool issafe);
|
|
|
|
|
|
|
|
|
|
|
|
/* Interface to XP_InterruptContext(), which should never be called directly
|
|
|
|
by anything else in libmsg. The "safetoo" argument is TRUE if we really
|
|
|
|
want to interrupt everything, even "safe" background streams. In most
|
|
|
|
cases, it should be False.*/
|
|
|
|
|
|
|
|
extern void msg_InterruptContext(MWContext* context, XP_Bool safetoo);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extern int msg_GrowBuffer (uint32 desired_size,
|
|
|
|
uint32 element_size, uint32 quantum,
|
|
|
|
char **buffer, uint32 *size);
|
|
|
|
|
|
|
|
extern int msg_LineBuffer (const char *net_buffer, int32 net_buffer_size,
|
|
|
|
char **bufferP, uint32 *buffer_sizeP,
|
|
|
|
uint32 *buffer_fpP,
|
|
|
|
XP_Bool convert_newlines_p,
|
|
|
|
int32 (*per_line_fn) (char *line, uint32
|
|
|
|
line_length, void *closure),
|
|
|
|
void *closure);
|
|
|
|
|
|
|
|
extern int msg_ReBuffer (const char *net_buffer, int32 net_buffer_size,
|
|
|
|
uint32 desired_buffer_size,
|
|
|
|
char **bufferP, uint32 *buffer_sizeP,
|
|
|
|
uint32 *buffer_fpP,
|
|
|
|
int32 (*per_buffer_fn) (char *buffer,
|
|
|
|
uint32 buffer_size,
|
|
|
|
void *closure),
|
|
|
|
void *closure);
|
|
|
|
|
|
|
|
extern NET_StreamClass *msg_MakeRebufferingStream (NET_StreamClass *next,
|
|
|
|
URL_Struct *url,
|
|
|
|
MWContext *context);
|
|
|
|
|
|
|
|
/* Given a string and a length, removes any "Re:" strings from the front.
|
|
|
|
(If the length is not given, then XP_STRLEN() is used on the string.)
|
|
|
|
It also deals with that "Re[2]:" thing that some mailers do.
|
|
|
|
|
|
|
|
Returns TRUE if it made a change, FALSE otherwise.
|
|
|
|
|
|
|
|
The string is not altered: the pointer to its head is merely advanced,
|
|
|
|
and the length correspondingly decreased.
|
|
|
|
*/
|
|
|
|
extern XP_Bool msg_StripRE(const char **stringP, uint32 *lengthP);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Does in-place modification of input param to conform with son-of-1036 rules
|
|
|
|
*/
|
|
|
|
extern void msg_MakeLegalNewsgroupComponent (char *name);
|
|
|
|
|
|
|
|
extern void MSG_SetPercentProgress(MWContext *context, int32 numerator, int32 denominator);
|
|
|
|
|
|
|
|
XP_END_PROTOS
|