/* * %CopyrightBegin% * * Copyright Ericsson AB 2001-2009. All Rights Reserved. * * The contents of this file are subject to the Erlang Public License, * Version 1.1, (the "License"); you may not use this file except in * compliance with the License. You should have received a copy of the * Erlang Public License along with this software. If not, it can be * retrieved online at http://www.erlang.org/. * * 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. * * %CopyrightEnd% * */ #include int oe_encode_erlang_binary(CORBA_Environment *ev, erlang_binary *binary) { int size = ev->_iout; (int) ei_encode_binary(0, &size, binary->_buffer, binary->_length); if (size >= ev->_outbufsz) { char *buf = ev->_outbuf; int bufsz = ev->_outbufsz + ev->_memchunk; while (size >= bufsz) bufsz += ev->_memchunk; if ((buf = realloc(buf, bufsz)) == NULL) { CORBA_exc_set(ev, CORBA_SYSTEM_EXCEPTION, NO_MEMORY, "End of heap memory while encoding"); return -1; /* OUT OF MEMORY */ } ev->_outbuf = buf; ev->_outbufsz = bufsz; } return ei_encode_binary(ev->_outbuf, &ev->_iout, binary->_buffer, binary->_length); } int oe_sizecalc_erlang_binary(CORBA_Environment *ev, int* _index, int* _size) { long _malloc_size = 0; int _error = 0; if(*_size == 0) *_size = ((*_size + sizeof(erlang_binary))+sizeof(double)-1)&~(sizeof(double)-1); if ((_error = ei_decode_binary(ev->_inbuf, _index, 0, &_malloc_size)) < 0) return _error; *_size = ((*_size + (int)_malloc_size)+sizeof(double)-1)&~(sizeof(double)-1); return 0; } int oe_decode_erlang_binary(CORBA_Environment *ev, char *_first, int* _index, erlang_binary *binary) { long _length = 0; int _error = 0; if((char*) binary == _first) *_index = ((*_index + sizeof(erlang_binary))+sizeof(double)-1)&~(sizeof(double)-1); binary->_buffer = (CORBA_octet *)(_first+*_index); if ((_error = ei_decode_binary(ev->_inbuf, &ev->_iin, binary->_buffer, &_length)) < 0) return _error; binary->_length = (CORBA_unsigned_long)_length; *_index = ((*_index)+_length+sizeof(double)-1)&~(sizeof(double)-1); return 0; } int print_erlang_binary(erlang_binary *binary) { int i=0; if (binary == NULL) return -1; fprintf(stdout,"binary->_length : %ld\n",binary->_length); fprintf(stdout,"binary->_buffer : "); if(binary->_buffer != NULL) { for (i=0; i_length; i++) fprintf(stdout,"%c",binary->_buffer[i]); fprintf(stdout,"\n"); } else fprintf(stdout,"NULL\n"); return 0; }