diff options
Diffstat (limited to 'WWW/Library/Implementation')
-rw-r--r-- | WWW/Library/Implementation/HTAccess.c | 1 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTAnchor.c | 2 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTAnchor.h | 2 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTChunk.c | 83 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTChunk.h | 32 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTFTP.c | 6 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTFormat.c | 14 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTStream.h | 29 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTTCP.c | 7 | ||||
-rw-r--r-- | WWW/Library/Implementation/HTTP.c | 6 | ||||
-rw-r--r-- | WWW/Library/Implementation/SGML.c | 28 | ||||
-rw-r--r-- | WWW/Library/Implementation/SGML.h | 16 |
12 files changed, 164 insertions, 62 deletions
diff --git a/WWW/Library/Implementation/HTAccess.c b/WWW/Library/Implementation/HTAccess.c index 8deb5162..4f4ebd8e 100644 --- a/WWW/Library/Implementation/HTAccess.c +++ b/WWW/Library/Implementation/HTAccess.c @@ -637,7 +637,6 @@ void LYUCPushAssumed(HTParentAnchor *anchor) */ int LYUCPopAssumed(void) { - if (pushed_assume_LYhndl >= 0) { /* some diagnostics */ if (UCLYhndl_for_unspec != pushed_assume_LYhndl) diff --git a/WWW/Library/Implementation/HTAnchor.c b/WWW/Library/Implementation/HTAnchor.c index 347c0f62..8c6a6304 100644 --- a/WWW/Library/Implementation/HTAnchor.c +++ b/WWW/Library/Implementation/HTAnchor.c @@ -13,7 +13,7 @@ * (c) Copyright CERN 1991 - See Copyright.html */ -#define HASH_SIZE 101 /* Arbitrary prime. Memory/speed tradeoff */ +#define HASH_SIZE 1001 /* Arbitrary prime. Memory/speed tradeoff */ #include <HTUtils.h> #include <HTAnchor.h> diff --git a/WWW/Library/Implementation/HTAnchor.h b/WWW/Library/Implementation/HTAnchor.h index 2cbe0d4a..e1a15784 100644 --- a/WWW/Library/Implementation/HTAnchor.h +++ b/WWW/Library/Implementation/HTAnchor.h @@ -32,7 +32,7 @@ extern "C" { #endif /* Main definition of anchor * ========================= - */ struct _HTAnchor { + */ struct _HTAnchor { /* Generic anchor */ HTParentAnchor0 *parent; /* Parent of this anchor (self for adults) */ }; diff --git a/WWW/Library/Implementation/HTChunk.c b/WWW/Library/Implementation/HTChunk.c index dc187c3f..7f41c687 100644 --- a/WWW/Library/Implementation/HTChunk.c +++ b/WWW/Library/Implementation/HTChunk.c @@ -83,13 +83,19 @@ void HTChunkClear(HTChunk *ch) ch->allocated = 0; } -/* Free a chunk - * ------------ +/* Free a chunk (and it's chain, if any) + * ------------------------------------- */ void HTChunkFree(HTChunk *ch) { - FREE(ch->data); - FREE(ch); + HTChunk *next; + + do { + next = ch->next; + FREE(ch->data); + FREE(ch); + ch = next; + } while (ch != NULL); } /* Realloc the chunk @@ -119,8 +125,6 @@ BOOL HTChunkRealloc(HTChunk *ch, int growby) /* Append a character * ------------------ */ -/* Warning: the code of this function is defined as macro in SGML.c. Change - the macro or undefine it in SGML.c when changing this function. -VH */ void HTChunkPutc(HTChunk *ch, char c) { if (ch->size >= ch->allocated) { @@ -130,6 +134,20 @@ void HTChunkPutc(HTChunk *ch, char c) ch->data[ch->size++] = c; } +/* like above but no realloc: extend to another chunk if necessary */ +HTChunk *HTChunkPutc2(HTChunk *ch, char c) +{ + if (ch->size >= ch->allocated) { + HTChunk *chunk = HTChunkCreateMayFail(ch->growby, ch->failok); + + ch->next = chunk; + HTChunkPutc(chunk, c); + return chunk; + } + ch->data[ch->size++] = c; + return ch; +} + /* Ensure a certain size * --------------------- */ @@ -139,13 +157,17 @@ void HTChunkEnsure(HTChunk *ch, int needed) return; ch->allocated = needed - 1 - ((needed - 1) % ch->growby) + ch->growby; /* Round up */ - ch->data = ch->data ? (char *) realloc(ch->data, ch->allocated) - : typecallocn(char, ch->allocated); + ch->data = (ch->data + ? (char *) realloc(ch->data, ch->allocated) + : typecallocn(char, ch->allocated)); if (ch->data == NULL) outofmem(__FILE__, "HTChunkEnsure"); } +/* + * Append a block of characters. + */ void HTChunkPutb(HTChunk *ch, const char *b, int l) { if (l <= 0) @@ -160,9 +182,34 @@ void HTChunkPutb(HTChunk *ch, const char *b, int l) ch->size += l; } +/* like above but no realloc: extend to another chunk if necessary */ +HTChunk *HTChunkPutb2(HTChunk *ch, const char *b, int l) +{ + if (l <= 0) + return ch; + if (ch->size + l > ch->allocated) { + HTChunk *chunk; + int m = ch->allocated - ch->size; + + memcpy(ch->data + ch->size, b, m); + ch->size += m; + + chunk = HTChunkCreateMayFail(ch->growby, ch->failok); + ch->next = chunk; + HTChunkPutb(chunk, b + m, l - m); + return chunk; + } + memcpy(ch->data + ch->size, b, l); + ch->size += l; + return ch; +} + #define PUTC(code) ch->data[ch->size++] = (char)(code) #define PUTC2(code) ch->data[ch->size++] = (char)(0x80|(0x3f &(code))) +/* + * Append a character encoded as UTF-8. + */ void HTChunkPutUtf8Char(HTChunk *ch, UCode_t code) { int utflen; @@ -255,3 +302,23 @@ void HTChunkPuts(HTChunk *ch, const char *s) } } } + +/* like above but no realloc: extend to another chunk if necessary */ +HTChunk *HTChunkPuts2(HTChunk *ch, const char *s) +{ + const char *p; + + if (s != NULL) { + for (p = s; *p; p++) { + if (ch->size >= ch->allocated) { + HTChunk *chunk = HTChunkCreateMayFail(ch->growby, ch->failok); + + ch->next = chunk; + HTChunkPuts(chunk, p); + return chunk; + } + ch->data[ch->size++] = *p; + } + } + return ch; +} diff --git a/WWW/Library/Implementation/HTChunk.h b/WWW/Library/Implementation/HTChunk.h index 8a5ade18..18e2b8f3 100644 --- a/WWW/Library/Implementation/HTChunk.h +++ b/WWW/Library/Implementation/HTChunk.h @@ -19,13 +19,16 @@ #ifdef __cplusplus extern "C" { #endif - typedef struct { + typedef struct _HTChunk HTChunk; + + struct _HTChunk { int size; /* In bytes */ int growby; /* Allocation unit in bytes */ int allocated; /* Current size of *data */ char *data; /* Pointer to malloc'd area or 0 */ int failok; /* allowed to fail without exiting program? */ - } HTChunk; + HTChunk *next; /* pointer to the next chunk */ + }; /* * Initialize a chunk's allocation data and allocation-increment. @@ -191,6 +194,31 @@ extern "C" { extern void HTChunkTerminate(HTChunk *ch); +/* like the above but no realloc: extend to another chunk if necessary */ +/* + * + * Append a character (string, data) to a chunk + * + * ON ENTRY, + * + * ch A valid chunk pointer made by HTChunkCreate() + * + * c The character to be appended + * + * ON EXIT, + * + * returns original chunk or a pointer to the new chunk + * (orginal chunk is referenced to the new one + * by the field 'next') + * + */ + extern HTChunk *HTChunkPutc2(HTChunk *ch, char c); + extern HTChunk *HTChunkPuts2(HTChunk *ch, const char *str); + extern HTChunk *HTChunkPutb2(HTChunk *ch, const char *b, int l); + +/* New pool infrastructure: UNlike the above, store data using alignment */ + extern HTChunk *HTChunkPutb0(HTChunk *ch, const char *b, int l); + #ifdef __cplusplus } #endif diff --git a/WWW/Library/Implementation/HTFTP.c b/WWW/Library/Implementation/HTFTP.c index a6242d42..2319043d 100644 --- a/WWW/Library/Implementation/HTFTP.c +++ b/WWW/Library/Implementation/HTFTP.c @@ -130,7 +130,7 @@ typedef struct _connection { #elif defined(SYS_HPUX) # if defined(_XOPEN_SOURCE_EXTENDED) && defined(SO_PROTOTYPE) # define LY_SOCKLEN socklen_t -# else /* HPUX 10.20, etc. */ +# else /* HPUX 10.20, etc. */ # define LY_SOCKLEN int # endif #elif defined(SYS_TRU64) @@ -1278,11 +1278,7 @@ static int get_listen_socket(void) /* Cast to generic sockaddr */ sizeof(soc_address) #ifndef SHORTENED_RBIND -#ifdef INET6 - socks_bind_remoteAddr -#else ,socks_bind_remoteAddr -#endif /* INET6 */ #endif /* !SHORTENED_RBIND */ ); else diff --git a/WWW/Library/Implementation/HTFormat.c b/WWW/Library/Implementation/HTFormat.c index 85bca424..7f52a81e 100644 --- a/WWW/Library/Implementation/HTFormat.c +++ b/WWW/Library/Implementation/HTFormat.c @@ -968,24 +968,18 @@ int HTMemCopy(HTChunk *chunk, HTStream *sink) { HTStreamClass targetClass; int bytes = 0; - const char *data = chunk->data; int rv = HT_OK; targetClass = *(sink->isa); HTReadProgress(0, 0); - for (;;) { + for (; chunk != NULL; chunk = chunk->next) { + /* Push the data down the stream a piece at a time, in case we're * running a large document on a slow machine. */ - int n = INPUT_BUFFER_SIZE; + (*targetClass.put_block) (sink, chunk->data, chunk->size); + bytes += chunk->size; - if (n > chunk->size - bytes) - n = chunk->size - bytes; - if (n == 0) - break; - (*targetClass.put_block) (sink, data, n); - bytes += n; - data += n; HTReadProgress(bytes, 0); HTDisplayPartial(); diff --git a/WWW/Library/Implementation/HTStream.h b/WWW/Library/Implementation/HTStream.h index 43ce9725..7a6d79ff 100644 --- a/WWW/Library/Implementation/HTStream.h +++ b/WWW/Library/Implementation/HTStream.h @@ -1,14 +1,14 @@ /* The Stream class definition -- libwww STREAM OBJECT DEFINITION - + A Stream object is something which accepts a stream of text. - + The creation methods will vary on the type of Stream Object. All creation methods return a pointer to the stream type below. - + As you can see, but the methods used to write to the stream and close it are pointed to be the object itself. - + */ #ifndef HTSTREAM_H #define HTSTREAM_H @@ -25,12 +25,8 @@ extern "C" { /* These are the common methods of all streams. They should be - self-explanatory, except for end_document which must be called before free. - It should be merged with free in fact: it should be dummy for new streams. - - The put_block method was write, but this upset systems which had macros for - write(). - + self-explanatory. + */ typedef struct _HTStreamClass { @@ -38,18 +34,13 @@ extern "C" { void (*_free) (HTStream *me); - void (*_abort) (HTStream *me, - HTError e); + void (*_abort) (HTStream *me, HTError e); - void (*put_character) (HTStream *me, - char ch); + void (*put_character) (HTStream *me, char ch); - void (*put_string) (HTStream *me, - const char *str); + void (*put_string) (HTStream *me, const char *str); - void (*put_block) (HTStream *me, - const char *str, - int len); + void (*put_block) (HTStream *me, const char *str, int len); } HTStreamClass; diff --git a/WWW/Library/Implementation/HTTCP.c b/WWW/Library/Implementation/HTTCP.c index 5b938571..452dfae7 100644 --- a/WWW/Library/Implementation/HTTCP.c +++ b/WWW/Library/Implementation/HTTCP.c @@ -1643,11 +1643,10 @@ int HTDoConnect(const char *url, #else status = Rconnect(*s, (struct sockaddr *) &soc_address, sizeof(soc_address)); -#endif /* INET6 */ - /* - * For long Rbind. - */ +#ifndef SHORTENED_RBIND socks_bind_remoteAddr = soc_address.sin_addr.s_addr; +#endif +#endif /* INET6 */ } else #endif /* SOCKS */ #ifdef INET6 diff --git a/WWW/Library/Implementation/HTTP.c b/WWW/Library/Implementation/HTTP.c index 27c0dcc0..0743cffc 100644 --- a/WWW/Library/Implementation/HTTP.c +++ b/WWW/Library/Implementation/HTTP.c @@ -304,11 +304,13 @@ int ws_netread(int fd, char *buf, int len) HTInfoMsg("Thread terminate Failed"); } now_TickCount = GetTickCount(); - if (now_TickCount > save_TickCount) + if (now_TickCount >= save_TickCount) process_time = now_TickCount - save_TickCount; else process_time = now_TickCount + (0xffffffff - save_TickCount); + if (process_time == 0) + process_time = 1; g_total_times += process_time; g_total_bytes += exitcode; @@ -326,7 +328,7 @@ int ws_netread(int fd, char *buf, int len) LeaveCriticalSection(&critSec_READ); return ret_val; } -#endif +#endif /* _WINDOWS */ /* * Strip any username from the given string so we retain only the host. diff --git a/WWW/Library/Implementation/SGML.c b/WWW/Library/Implementation/SGML.c index eae3db3d..c73d312c 100644 --- a/WWW/Library/Implementation/SGML.c +++ b/WWW/Library/Implementation/SGML.c @@ -20,7 +20,8 @@ #include <SGML.h> #include <HTMLDTD.h> -#include <HTCJK.h> +#include <HTAccess.h> +#include <HTCJK.h> /* FIXME: this doesn't belong in SGML.c */ #include <UCMap.h> #include <UCDefs.h> #include <UCAux.h> @@ -33,6 +34,7 @@ #include <LYGlobalDefs.h> #include <LYStrings.h> #include <LYLeaks.h> +#include <LYUtils.h> #ifdef USE_COLOR_STYLE # include <LYStyle.h> @@ -43,6 +45,8 @@ #define INVALID (-1) +static int sgml_offset; + #ifdef USE_PRETTYSRC static char *entity_string; /* this is used for printing entity name. @@ -854,9 +858,9 @@ static void handle_marked(HTStream *context) charset once it is in include - kw */ } else if (!strncmp(context->string->data, "![CDATA[", 8)) { - (*context->actions->_write) (context->target, - context->string->data + 8, - context->string->size - 11); + (*context->actions->put_block) (context->target, + context->string->data + 8, + context->string->size - 11); } return; @@ -1499,6 +1503,8 @@ static void SGML_character(HTStream *context, char c_in) #endif char saved_char_in = '\0'; + ++sgml_offset; + /* * Now some fun with the preprocessor. Use copies for c and unsign_c == * clong, so that we can revert back to the unchanged c_in. - KW @@ -4474,9 +4480,23 @@ HTStream *SGML_new(const SGML_dtd * dtd, } #endif + sgml_offset = 0; return context; } +/* + * Return the offset within the document where we're parsing. This is used + * to help identify anchors which shift around while reparsing. + */ +int SGML_offset(void) +{ +#ifdef USE_PRETTYSRC + return sgml_offset + psrc_view; +#else + return sgml_offset; +#endif +} + /* Asian character conversion functions * ==================================== * diff --git a/WWW/Library/Implementation/SGML.h b/WWW/Library/Implementation/SGML.h index c595dc91..836d1377 100644 --- a/WWW/Library/Implementation/SGML.h +++ b/WWW/Library/Implementation/SGML.h @@ -25,9 +25,9 @@ extern "C" { #endif /* - -SGML content types - + * + * SGML content types + * */ typedef enum { SGML_EMPTY, /* No content. */ SGML_LITTERAL, /* Literal character data. Recognize exact close tag only. @@ -203,8 +203,9 @@ Structured Object definition void (*put_string) (HTStructured * me, const char *str); - void (*_write) (HTStructured * me, const char *str, - int len); + void (*put_block) (HTStructured * me, const char *str, int len); + + /* HTStreamClass ends here */ int (*start_element) (HTStructured * me, int element_number, const BOOL *attribute_present, @@ -239,6 +240,11 @@ Find a Tag by Name const char *string); /* + * Return the current offset within the file that SGML is parsing + */ + extern int SGML_offset(void); + +/* Create an SGML parser |