|
version 1.7.2.4, 2011/04/20 08:09:13
|
version 1.9, 2011/05/03 15:41:00
|
|
Line 27 are met:
|
Line 27 are met:
|
| must display the following acknowledgement: |
must display the following acknowledgement: |
| This product includes software developed by Michael Pounov <misho@elwix.org> |
This product includes software developed by Michael Pounov <misho@elwix.org> |
| ELWIX - Embedded LightWeight unIX and its contributors. |
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 |
may be used to endorse or promote products derived from this software |
| without specific prior written permission. |
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 |
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE |
ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE |
|
Line 55 SUCH DAMAGE.
|
Line 55 SUCH DAMAGE.
|
| #define VACUUM_BETWEEN 2 |
#define VACUUM_BETWEEN 2 |
| |
|
| |
|
| |
typedef void ** sarr_seg_t; |
| |
typedef struct _tagSplitArray { |
| |
int sarr_num; |
| |
int sarr_seg; |
| |
int sarr_siz; |
| |
sarr_seg_t *sarr_data; |
| |
} sarr_t; |
| |
|
| typedef struct _tagArray { |
typedef struct _tagArray { |
| int arr_num; |
int arr_num; |
| void **arr_data; |
void **arr_data; |
|
Line 252 int io_arrayVacuum(array_t * __restrict arr, int fromW
|
Line 260 int io_arrayVacuum(array_t * __restrict arr, int fromW
|
| assert(_arr && _arr->arr_num > _d); \ |
assert(_arr && _arr->arr_num > _d); \ |
| *(_arr->arr_data + _d) = (void*) _ptr; \ |
*(_arr->arr_data + _d) = (void*) _ptr; \ |
| } while (0) |
} while (0) |
| |
#define io_arrayDel(_arr, _d) do { \ |
| |
assert(_arr && _arr->arr_num > _d); \ |
| |
*(_arr->arr_data + _d) = NULL; \ |
| |
} while (0) |
| |
|
| /* |
/* |
| * io_arrayPush() - Push element into dynamic array like stack manner, place at first empty position |
* io_arrayPush() - Push element into dynamic array like stack manner, place at first empty position |
|
Line 302 int io_arrayMake(char * __restrict psArgs, int nargs,
|
Line 314 int io_arrayMake(char * __restrict psArgs, int nargs,
|
| int io_MakeAV(const char * __restrict csArgs, const char *csDelim, |
int io_MakeAV(const char * __restrict csArgs, const char *csDelim, |
| char * __restrict psAttr, int attrLen, char * __restrict psValue, int valLen); |
char * __restrict psAttr, int attrLen, char * __restrict psValue, int valLen); |
| |
|
| |
/* |
| |
* io_sarrInit() - Create and initialize dynamic split-order array |
| |
* @numItems = Number of Items |
| |
* @segLen = Length of segment |
| |
* return: NULL error, != NULL allocated memory for array |
| |
*/ |
| |
inline sarr_t *io_sarrInit(int numItems, int segLen); |
| |
/* |
| |
* io_sarrDestroy() - Free all data in dynamic split-order array and Destroy array |
| |
* @parr = Array |
| |
* return: none |
| |
*/ |
| |
inline void io_sarrDestroy(sarr_t ** __restrict parr); |
| |
/* |
| |
* io_sarrGrow() - Grow/Shrink dynamic split-order array, Use with care when it shrink!!! |
| |
* @arr = Array |
| |
* @newNumItems = Number of Items |
| |
* return: -1 error, 0 ok |
| |
*/ |
| |
int io_sarrGrow(sarr_t * __restrict arr, int newNumItems); |
| |
/* |
| |
* io_sarrVacuum() - Vacuum dynamic split-order array, empty segments will be freed |
| |
* @arr = Array |
| |
* return: -1 error, >-1 freed segments |
| |
*/ |
| |
inline int io_sarrVacuum(sarr_t * __restrict arr); |
| |
#define io_sarrSize(_arr) ((assert(_arr)), _arr->sarr_num) |
| |
/* |
| |
* io_sarrGet() - Get element from dynamic split-order array |
| |
* @arr = Array |
| |
* @idx = Index (warning 1st element is at position 1) |
| |
* return: NULL not found, !=NULL element |
| |
*/ |
| |
inline void *io_sarrGet(sarr_t * __restrict arr, unsigned int idx); |
| |
/* |
| |
* io_sarrGet2() - Always get element from dynamic split-order array |
| |
* Function automatic grow array. Good use for Hash tables! |
| |
* @arr = Array |
| |
* @idx = Index (warning 1st element is at position 1) |
| |
* return: NULL not found, !=NULL element |
| |
*/ |
| |
void *io_sarrGet2(sarr_t * __restrict arr, unsigned int idx); |
| |
/* |
| |
* io_sarrSet() - Set element to dynamic split-order array |
| |
* @arr = Array |
| |
* @idx = Index (warning 1st element is at position 1) |
| |
* @data = Value |
| |
* return: NULL error or empty, !=NULL old value in element |
| |
*/ |
| |
inline void *io_sarrSet(sarr_t * __restrict arr, unsigned int idx, void *data); |
| |
#define io_sarrDel(_arr, _idx) io_sarrSet(_arr, _idx, NULL) |
| |
#define io_sarr(_arr, _idx, _type) (_type)io_sarrGet(_arr, _idx) |
| |
|
| /* |
/* |
| * ioURLGet() Parse and get data from input URL |
* ioURLGet() Parse and get data from input URL |