--- libaitio/src/Attic/array.c 2011/04/20 08:09:13 1.1.2.4 +++ libaitio/src/Attic/array.c 2011/05/19 02:22:46 1.2.4.1 @@ -3,7 +3,7 @@ * by Michael Pounov * * $Author: misho $ -* $Id: array.c,v 1.1.2.4 2011/04/20 08:09:13 misho Exp $ +* $Id: array.c,v 1.2.4.1 2011/05/19 02:22:46 misho Exp $ * ************************************************************************** The ELWIX and AITNET software is distributed under the following @@ -27,11 +27,11 @@ are met: must display the following acknowledgement: This product includes software developed by Michael Pounov ELWIX - Embedded LightWeight unIX and its contributors. -4. Neither the name of the University nor the names of its contributors +4. Neither the name of AITNET nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. -THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND +THIS SOFTWARE IS PROVIDED BY AITNET AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE @@ -75,7 +75,7 @@ io_arrayInit(int numItems) } /* - * io_arrayFree() - Free all data in dynamic array + * io_arrayFree() - Free all data in dynamic array items * (WARNING! If assign static array dont use this!!!) * @arr = Array * return: none @@ -97,7 +97,7 @@ io_arrayFree(array_t * __restrict arr) } /* - * io_arrayDestroy() - Free all data in dynamic array and Destroy dynamic array + * io_arrayDestroy() - Free and destroy dynamic array * @parr = Array * return: none */ @@ -275,6 +275,30 @@ io_arrayPop(array_t * __restrict arr, void ** __restri } return ret; +} + +/* + * io_arrayConcat() Concat source array to destination array + * @dest = Destination array + * @src = Source array + * return: -1 error; >0 new count of destination array + */ +int +io_arrayConcat(array_t * __restrict dest, array_t * __restrict src) +{ + int n; + + assert(dest); + assert(src); + if (!dest || !src) + return -1; + + n = dest->arr_num; + if (io_arrayGrow(dest, n + src->arr_num)) + return -1; + memcpy(dest->arr_data + n, src->arr_data, src->arr_num * sizeof(void*)); + + return io_arraySize(dest); } /*