📄 htchunk.h
字号:
/* W3C Sample Code Library libwww Chunk Class! The Chunk Class!*//*** (c) COPYRIGHT MIT 1995.** Please first read the full copyright statement in the file COPYRIGH.*//*The Chunk Class defines a way to automatically handle dynamic strings andother data types. You create a chunk with an initial size and it will thenautomatically grow to accomodate added data to the chunk. It is a generalutility module. It is garanteed that the array is '\0' terminatedat all times (and hence is a valid C type string). The methodHTChunkTerminate can be used to explicitlyadd a terminating '\0' and then to include this character inthe chunk size. If left out, the terminating character is not consideredpart of the chunk.Note: The names without a "_" (made as a #define's) areonly provided for backwards compatibility and should not be used.This module is implemented by HTChunk.c, and it isa part of the W3C Sample CodeLibrary.*/#ifndef HTCHUNK_H#define HTCHUNK_H/*. Create new chunk.Create a new chunk and specify the number of bytes to allocate at a timewhen the chunk is later extended. Arbitrary but normally a trade-off timevs. memory*/typedef struct _HTChunk HTChunk;extern HTChunk * HTChunk_new (int growby);/*. Free a chunk.Free a chunk created by HTChunkCreatefrom memory*/extern void HTChunk_delete (HTChunk * ch);/*. Clear a chunk.Keep the chunk in memory but clear all data kept inside. This can be usedif you know that you can reuse the allocated memory instead of allocatingnew memory.*/extern void HTChunk_clear (HTChunk * ch);/*. Ensure a Chunk has a Certain Amount of Free Space.Make sure that a chunk has a certain size. If this is not the case then thechunk is expanded. Nothing is done if the current size if bigger than thesize requested.*/extern void HTChunk_ensure (HTChunk * ch, int s);/*. Append a character to a chunk.Add the character and increment the size of the chunk by one character*/extern void HTChunk_putc (HTChunk * ch, char c);/*. Append a string to a chunk.Add the string and increment the size of the chunk by the length of the string(without the trailing zero)*/extern void HTChunk_puts (HTChunk * ch, const char *str);/*. Append a block to a chunk.Add the block and increment the size of the chunk by the len*/extern void HTChunk_putb (HTChunk * ch, const char *block, int len);/*. Return Pointer to Data.This define converts a chunk to a normal char pointer so that it can be parsedto any ANSI C string function.*/extern char * HTChunk_data (HTChunk * ch);/*. Return Current Size.Returns the current size of the chunk*/extern int HTChunk_size (HTChunk * ch);/*. Truncate Chunk.If for some reason you want to cut off a piece of a chunk then you canuse this function. It sets the size of the chunk to beposition. Clearing the chunk is equivalent to a positionof 0.*/extern BOOL HTChunk_truncate (HTChunk * ch, int position);/*. Zero Terminate a chunk.As a chunk often is a dynamic string, it needs to be terminated by a zeroin order to be used in C. However, by default any chunk isalways zero terminated, so the only purpose of this function is toincrement the size counter with one corresponding to the zero.*/extern void HTChunk_terminate (HTChunk * ch);/*. CString Conversions.A Chunk may be build from an allocated string. The chunk assumes controlof the passes string, elminating the need for additional allocations andstring copies.Once a string is built, the chunk may be destroyed and the string kept around.*/extern HTChunk * HTChunk_fromCString (char * str, int grow);extern char * HTChunk_toCString (HTChunk * ch);/*. Old Interface Names.Don't use these in new applications*/#define HTChunkCreate(growby) HTChunk_new(growby)#define HTChunkFree(ch) HTChunk_delete(ch)#define HTChunkClear(ch) HTChunk_clear(ch)#define HTChunkEnsure(ch, s) HTChunk_ensure((ch), (s))#define HTChunkPutc(ch, c) HTChunk_putc((ch), (c))#define HTChunkPuts(ch, str) HTChunk_puts((ch), (str))#define HTChunkTerminate(ch) HTChunk_terminate(ch)#define HTChunkData(ch) HTChunk_data(ch)#define HTChunkSize(ch) HTChunk_size(ch)/**/#endif/* @(#) $Id: HTChunk.html,v 2.36 1999/02/05 21:35:50 frystyk Exp $*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -