You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					164 lines
				
				5.8 KiB
			
		
		
			
		
	
	
					164 lines
				
				5.8 KiB
			| 
								 
											6 years ago
										 
									 | 
							
								/*  =========================================================================
							 | 
						||
| 
								 | 
							
								    zchunk - work with memory chunks
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    Copyright (c) the Contributors as noted in the AUTHORS file.
							 | 
						||
| 
								 | 
							
								    This file is part of CZMQ, the high-level C binding for 0MQ:
							 | 
						||
| 
								 | 
							
								    http://czmq.zeromq.org.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    This Source Code Form is subject to the terms of the Mozilla Public
							 | 
						||
| 
								 | 
							
								    License, v. 2.0. If a copy of the MPL was not distributed with this
							 | 
						||
| 
								 | 
							
								    file, You can obtain one at http://mozilla.org/MPL/2.0/.
							 | 
						||
| 
								 | 
							
								    =========================================================================
							 | 
						||
| 
								 | 
							
								*/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef __ZCHUNK_H_INCLUDED__
							 | 
						||
| 
								 | 
							
								#define __ZCHUNK_H_INCLUDED__
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								extern "C" {
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  @warning THE FOLLOWING @INTERFACE BLOCK IS AUTO-GENERATED BY ZPROJECT
							 | 
						||
| 
								 | 
							
								//  @warning Please edit the model at "api/zchunk.api" to make changes.
							 | 
						||
| 
								 | 
							
								//  @interface
							 | 
						||
| 
								 | 
							
								//  This is a stable class, and may not change except for emergencies. It
							 | 
						||
| 
								 | 
							
								//  is provided in stable builds.
							 | 
						||
| 
								 | 
							
								//  Create a new chunk of the specified size. If you specify the data, it   
							 | 
						||
| 
								 | 
							
								//  is copied into the chunk. If you do not specify the data, the chunk is  
							 | 
						||
| 
								 | 
							
								//  allocated and left empty, and you can then add data using zchunk_append.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zchunk_t *
							 | 
						||
| 
								 | 
							
								    zchunk_new (const void *data, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Destroy a chunk
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT void
							 | 
						||
| 
								 | 
							
								    zchunk_destroy (zchunk_t **self_p);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Resizes chunk max_size as requested; chunk_cur size is set to zero
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT void
							 | 
						||
| 
								 | 
							
								    zchunk_resize (zchunk_t *self, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return chunk cur size
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_size (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return chunk max size
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_max_size (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return chunk data
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT byte *
							 | 
						||
| 
								 | 
							
								    zchunk_data (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Set chunk data from user-supplied data; truncate if too large. Data may
							 | 
						||
| 
								 | 
							
								//  be null. Returns actual size of chunk                                  
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_set (zchunk_t *self, const void *data, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Fill chunk data from user-supplied octet
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_fill (zchunk_t *self, byte filler, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Append user-supplied data to chunk, return resulting chunk size. If the 
							 | 
						||
| 
								 | 
							
								//  data would exceeded the available space, it is truncated. If you want to
							 | 
						||
| 
								 | 
							
								//  grow the chunk to accommodate new data, use the zchunk_extend method.   
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_append (zchunk_t *self, const void *data, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Append user-supplied data to chunk, return resulting chunk size. If the
							 | 
						||
| 
								 | 
							
								//  data would exceeded the available space, the chunk grows in size.      
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_extend (zchunk_t *self, const void *data, size_t size);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Copy as much data from 'source' into the chunk as possible; returns the  
							 | 
						||
| 
								 | 
							
								//  new size of chunk. If all data from 'source' is used, returns exhausted  
							 | 
						||
| 
								 | 
							
								//  on the source chunk. Source can be consumed as many times as needed until
							 | 
						||
| 
								 | 
							
								//  it is exhausted. If source was already exhausted, does not change chunk. 
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT size_t
							 | 
						||
| 
								 | 
							
								    zchunk_consume (zchunk_t *self, zchunk_t *source);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Returns true if the chunk was exhausted by consume methods, or if the
							 | 
						||
| 
								 | 
							
								//  chunk has a size of zero.                                            
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT bool
							 | 
						||
| 
								 | 
							
								    zchunk_exhausted (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Read chunk from an open file descriptor
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zchunk_t *
							 | 
						||
| 
								 | 
							
								    zchunk_read (FILE *handle, size_t bytes);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Write chunk to an open file descriptor
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT int
							 | 
						||
| 
								 | 
							
								    zchunk_write (zchunk_t *self, FILE *handle);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Try to slurp an entire file into a chunk. Will read up to maxsize of  
							 | 
						||
| 
								 | 
							
								//  the file. If maxsize is 0, will attempt to read the entire file and   
							 | 
						||
| 
								 | 
							
								//  fail with an assertion if that cannot fit into memory. Returns a new  
							 | 
						||
| 
								 | 
							
								//  chunk containing the file data, or NULL if the file could not be read.
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zchunk_t *
							 | 
						||
| 
								 | 
							
								    zchunk_slurp (const char *filename, size_t maxsize);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Create copy of chunk, as new chunk object. Returns a fresh zchunk_t   
							 | 
						||
| 
								 | 
							
								//  object, or null if there was not enough heap memory. If chunk is null,
							 | 
						||
| 
								 | 
							
								//  returns null.                                                         
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zchunk_t *
							 | 
						||
| 
								 | 
							
								    zchunk_dup (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return chunk data encoded as printable hex string. Caller must free
							 | 
						||
| 
								 | 
							
								//  string when finished with it.                                      
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT char *
							 | 
						||
| 
								 | 
							
								    zchunk_strhex (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return chunk data copied into freshly allocated string
							 | 
						||
| 
								 | 
							
								//  Caller must free string when finished with it.        
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT char *
							 | 
						||
| 
								 | 
							
								    zchunk_strdup (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Return TRUE if chunk body is equal to string, excluding terminator
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT bool
							 | 
						||
| 
								 | 
							
								    zchunk_streq (zchunk_t *self, const char *string);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Transform zchunk into a zframe that can be sent in a message.
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zframe_t *
							 | 
						||
| 
								 | 
							
								    zchunk_pack (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Transform a zframe into a zchunk.
							 | 
						||
| 
								 | 
							
								//  Caller owns return value and must destroy it when done.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT zchunk_t *
							 | 
						||
| 
								 | 
							
								    zchunk_unpack (zframe_t *frame);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Calculate SHA1 digest for chunk, using zdigest class.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT const char *
							 | 
						||
| 
								 | 
							
								    zchunk_digest (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Dump chunk to FILE stream, for debugging and tracing.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT void
							 | 
						||
| 
								 | 
							
								    zchunk_fprint (zchunk_t *self, FILE *file);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Dump message to stderr, for debugging and tracing.
							 | 
						||
| 
								 | 
							
								//  See zchunk_fprint for details                     
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT void
							 | 
						||
| 
								 | 
							
								    zchunk_print (zchunk_t *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Probe the supplied object, and report if it looks like a zchunk_t.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT bool
							 | 
						||
| 
								 | 
							
								    zchunk_is (void *self);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Self test of this class.
							 | 
						||
| 
								 | 
							
								CZMQ_EXPORT void
							 | 
						||
| 
								 | 
							
								    zchunk_test (bool verbose);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  @end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef __cplusplus
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 |