|  |  |  | libsoup Reference Manual |  | 
|---|---|---|---|---|
                    SoupBuffer;
enum                SoupMemoryUse;
SoupBuffer*         soup_buffer_new                     (SoupMemoryUse use,
                                                         gconstpointer data,
                                                         gsize length);
SoupBuffer*         soup_buffer_new_subbuffer           (SoupBuffer *parent,
                                                         gsize offset,
                                                         gsize length);
SoupBuffer*         soup_buffer_new_with_owner          (gconstpointer data,
                                                         gsize length,
                                                         gpointer owner,
                                                         GDestroyNotify owner_dnotify);
gpointer            soup_buffer_get_owner               (SoupBuffer *buffer);
SoupBuffer*         soup_buffer_copy                    (SoupBuffer *buffer);
void                soup_buffer_free                    (SoupBuffer *buffer);
                    SoupMessageBody;
SoupMessageBody*    soup_message_body_new               (void);
void                soup_message_body_free              (SoupMessageBody *body);
void                soup_message_body_set_accumulate    (SoupMessageBody *body,
                                                         gboolean accumulate);
gboolean            soup_message_body_get_accumulate    (SoupMessageBody *body);
void                soup_message_body_append            (SoupMessageBody *body,
                                                         SoupMemoryUse use,
                                                         gconstpointer data,
                                                         gsize length);
void                soup_message_body_append_buffer     (SoupMessageBody *body,
                                                         SoupBuffer *buffer);
void                soup_message_body_truncate          (SoupMessageBody *body);
void                soup_message_body_complete          (SoupMessageBody *body);
SoupBuffer*         soup_message_body_flatten           (SoupMessageBody *body);
SoupBuffer*         soup_message_body_get_chunk         (SoupMessageBody *body,
                                                         goffset offset);
void                soup_message_body_got_chunk         (SoupMessageBody *body,
                                                         SoupBuffer *chunk);
void                soup_message_body_wrote_chunk       (SoupMessageBody *body,
                                                         SoupBuffer *chunk);
SoupMessageBody represents the request or response body of a SoupMessage.
In addition to SoupMessageBody, libsoup also defines a "smaller" data buffer type, SoupBuffer, which is primarily used as a component of SoupMessageBody. In particular, when using chunked encoding to transmit or receive a message, each chunk is represented as a SoupBuffer.
typedef struct {
	const char *data;
	gsize       length;
} SoupBuffer;
A data buffer, generally used to represent a chunk of a SoupMessageBody.
data is a char because that's generally convenient; in some
situations you may need to cast it to guchar or another type.
| const char * | the data | 
| gsize  | length of data | 
typedef enum {
	SOUP_MEMORY_STATIC,
	SOUP_MEMORY_TAKE,
	SOUP_MEMORY_COPY,
	SOUP_MEMORY_TEMPORARY
} SoupMemoryUse;
Describes how SoupBuffer should use the data passed in by the caller.
See also soup_buffer_new_with_owner(), which allows to you create a
buffer containing data which is owned by another object.
| The memory is statically allocated and constant; libsoup can use the passed-in buffer directly and not need to worry about it being modified or freed. | |
| The caller has allocated the memory for the
SoupBuffer's use; libsoup will assume ownership of it and free it
(with g_free()) when it is done with it. | |
| The passed-in data belongs to the caller; the SoupBuffer will copy it into new memory, leaving the caller free to reuse the original memory. | |
| The passed-in data belongs to the caller,
but will remain valid for the lifetime of the SoupBuffer. The
difference between this and SOUP_MEMORY_STATICis that if you copy
aSOUP_MEMORY_TEMPORARYbuffer, it will make a copy of the memory
as well, rather than reusing the original memory. | 
SoupBuffer* soup_buffer_new (SoupMemoryUse use, gconstpointer data, gsize length);
Creates a new SoupBuffer containing length bytes from data.
| 
 | how datais to be used by the buffer | 
| 
 | data | 
| 
 | length of data | 
| Returns : | the new SoupBuffer. | 
SoupBuffer* soup_buffer_new_subbuffer (SoupBuffer *parent, gsize offset, gsize length);
Creates a new SoupBuffer containing length bytes "copied" from
parent starting at offset. (Normally this will not actually copy
any data, but will instead simply reference the same data as
parent does.)
| 
 | the parent SoupBuffer | 
| 
 | offset within parentto start at | 
| 
 | number of bytes to copy from parent | 
| Returns : | the new SoupBuffer. | 
SoupBuffer* soup_buffer_new_with_owner (gconstpointer data, gsize length, gpointer owner, GDestroyNotify owner_dnotify);
Creates a new SoupBuffer containing length bytes from data. When
the SoupBuffer is freed, it will call owner_dnotify, passing
owner to it. You must ensure that data will remain valid until
owner_dnotify is called.
For example, you could use this to create a buffer containing data returned from libxml without needing to do an extra copy:
xmlDocDumpMemory (doc, &xmlbody, &len);
return soup_buffer_new_with_owner (xmlbody, len, xmlbody,
                                   (GDestroyNotify)xmlFree);
In this example, data and owner are the same, but in other cases
they would be different (eg, owner would be a object, and data
would be a pointer to one of the object's fields).
| 
 | data | 
| 
 | length of data | 
| 
 | pointer to an object that owns data | 
| 
 | a function to free/unref ownerwhen the buffer is
freed | 
| Returns : | the new SoupBuffer. | 
gpointer soup_buffer_get_owner (SoupBuffer *buffer);
Gets the "owner" object for a buffer created with
soup_buffer_new_with_owner().
| 
 | a SoupBuffer created with soup_buffer_new_with_owner() | 
| Returns : | the owner pointer | 
SoupBuffer* soup_buffer_copy (SoupBuffer *buffer);
Makes a copy of buffer. In reality, SoupBuffer is a refcounted
type, and calling soup_buffer_copy() will normally just increment
the refcount on buffer and return it. However, if buffer was
created with SOUP_MEMORY_TEMPORARY memory, then soup_buffer_copy()
will actually return a copy of it, so that the data in the copy
will remain valid after the temporary buffer is freed.
| 
 | a SoupBuffer | 
| Returns : | the new (or newly-reffed) buffer | 
void soup_buffer_free (SoupBuffer *buffer);
Frees buffer. (In reality, as described in the documentation for
soup_buffer_copy(), this is actually an "unref" operation, and may
or may not actually free buffer.)
| 
 | a SoupBuffer | 
typedef struct {
	const char *data;
	goffset     length;
} SoupMessageBody;
A SoupMessage request or response body.
Note that while length always reflects the full length of the
message body, data is normally NULL, and will only be filled in
after soup_message_body_flatten() is called. For client-side
messages, this automatically happens for the response body after it
has been fully read, unless you set the
SOUP_MESSAGE_OVERWRITE_CHUNKS flags. Likewise, for server-side
messages, the request body is automatically filled in after being
read.
As an added bonus, when data is filled in, it is always terminated
with a '\0' byte (which is not reflected in length).
| const char * | the data | 
| goffset  | length of data | 
SoupMessageBody* soup_message_body_new (void);
Creates a new SoupMessageBody. SoupMessage uses this internally; you will not normally need to call it yourself.
| Returns : | a new SoupMessageBody. | 
void soup_message_body_free (SoupMessageBody *body);
Frees body. You will not normally need to use this, as
SoupMessage frees its associated message bodies automatically.
| 
 | a SoupMessageBody | 
void soup_message_body_set_accumulate (SoupMessageBody *body, gboolean accumulate);
Sets or clears the accumulate flag on body. (The default value
is TRUE.)
If you set this flag to FALSE on an "incoming" message body (that
is, the response_body of a client-side message, or request_body
of a server-side message), this will cause each chunk of the body
to be discarded after its corresponding "got_chunk"
signal is emitted. (This is equivalent to setting the deprecated
SOUP_MESSAGE_OVERWRITE_CHUNKS flag on the message.)
If you set this flag to FALSE on an "outgoing" message body (the
request_body of a client-side message, or response_body of a
server-side message), it will cause each chunk of the body to be
discarded after its corresponding "wrote_chunk" signal
is emitted.
In either case, body's data field will not be filled in after the
body is fully sent/received, since the body data will no longer be
available
| 
 | a SoupMessageBody | 
| 
 | whether or not to accumulate body chunks in body | 
gboolean soup_message_body_get_accumulate (SoupMessageBody *body);
Gets the accumulate flag on body; see
soup_message_body_set_accumulate() for details.
| 
 | a SoupMessageBody | 
| Returns : | the accumulate flag for body. | 
void soup_message_body_append (SoupMessageBody *body, SoupMemoryUse use, gconstpointer data, gsize length);
Appends length bytes from data to body according to use.
| 
 | a SoupMessageBody | 
| 
 | how to use data | 
| 
 | data to append | 
| 
 | length of data | 
void soup_message_body_append_buffer (SoupMessageBody *body, SoupBuffer *buffer);
Appends the data from buffer to body. (SoupMessageBody uses
SoupBuffers internally, so this is normally a constant-time
operation that doesn't actually require copying the data in
buffer.)
| 
 | a SoupMessageBody | 
| 
 | a SoupBuffer | 
void soup_message_body_truncate (SoupMessageBody *body);
Deletes all of the data in body.
| 
 | a SoupMessageBody | 
void soup_message_body_complete (SoupMessageBody *body);
Tags body as being complete; Call this when using chunked encoding
after you have appended the last chunk.
| 
 | a SoupMessageBody | 
SoupBuffer* soup_message_body_flatten (SoupMessageBody *body);
Fills in body's data field with a buffer containing all of the
data in body (plus an additional '\0' byte not counted by body's
length field).
| 
 | a SoupMessageBody | 
| Returns : | a SoupBuffer containing the same data as body.
(You must free this buffer if you do not want it.) | 
SoupBuffer* soup_message_body_get_chunk (SoupMessageBody *body, goffset offset);
Gets a SoupBuffer containing data from body starting at offset.
The size of the returned chunk is unspecified. You can iterate
through the entire body by first calling
soup_message_body_get_chunk() with an offset of 0, and then on each
successive call, increment the offset by the length of the
previously-returned chunk.
If offset is greater than or equal to the total length of body,
then the return value depends on whether or not
soup_message_body_complete() has been called or not; if it has,
then soup_message_body_get_chunk() will return a 0-length chunk
(indicating the end of body). If it has not, then
soup_message_body_get_chunk() will return NULL (indicating that
body may still potentially have more data, but that data is not
currently available).
| 
 | a SoupMessageBody | 
| 
 | an offset | 
| Returns : | a SoupBuffer, or NULL. | 
void soup_message_body_got_chunk (SoupMessageBody *body, SoupBuffer *chunk);
Handles the SoupMessageBody part of receiving a chunk of data from
the network. Normally this means appending chunk to body, exactly
as with soup_message_body_append_buffer(), but if you have set
body's accumulate flag to FALSE, then that will not happen.
This is a low-level method which you should not normally need to use.
| 
 | a SoupMessageBody | 
| 
 | a SoupBuffer received from the network | 
void soup_message_body_wrote_chunk (SoupMessageBody *body, SoupBuffer *chunk);
Handles the SoupMessageBody part of writing a chunk of data to the
network. Normally this is a no-op, but if you have set body's
accumulate flag to FALSE, then this will cause chunk (and any
chunks preceding it in body) to be discarded to free up memory.
This is a low-level method which you should not normally need to use.
| 
 | a SoupMessageBody | 
| 
 | a SoupBuffer received from the network |