version 1.5, 2011/09/07 07:24:21
|
version 1.5.2.2, 2011/11/03 14:57:56
|
Line 47 SUCH DAMAGE.
|
Line 47 SUCH DAMAGE.
|
|
|
|
|
/* |
/* |
* rpc_srv_allocVars() Allocate array for call variables, | * rpc_srv_allocVars() Allocate array for call variables |
if already allocated memory for RPC call reallocate used space | |
* @call = RPC function call |
* @call = RPC function call |
* @varnum = Number of variables, if ==0 free previous allocated variables | * @varnum = Number of variables, if ==0 return already allocated variables number |
* return: -1 error, !=-1 return varnum value |
* return: -1 error, !=-1 return varnum value |
*/ |
*/ |
inline int |
inline int |
rpc_srv_allocVars(rpc_func_t * __restrict call, int varnum) |
rpc_srv_allocVars(rpc_func_t * __restrict call, int varnum) |
{ |
{ |
register int i; |
|
ait_val_t *v; |
|
|
|
if (!call || varnum < 0) { |
if (!call || varnum < 0) { |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t allocate variables for RPC call...\n"); |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t allocate variables for RPC call...\n"); |
return -1; |
return -1; |
} |
} |
|
|
if (varnum) { |
if (varnum) { |
call->func_vars = io_arrayInit(varnum); | call->func_vars = io_allocVars(varnum); |
if (!call->func_vars) |
if (!call->func_vars) |
return -1; |
return -1; |
|
|
/* allocate ait_val_t elements & add to array */ |
|
for (i = 0; i < io_arraySize(call->func_vars); i++) { |
|
v = malloc(sizeof(ait_val_t)); |
|
if (!v) { |
|
LOGERR; |
|
rpc_srv_destroyVars(call); |
|
return -1; |
|
} else { |
|
memset(v, 0, sizeof(ait_val_t)); |
|
io_arraySet(call->func_vars, i, v); |
|
} |
|
} |
|
} |
} |
|
|
return io_arraySize(call->func_vars); |
return io_arraySize(call->func_vars); |
} |
} |
|
|
/* |
/* |
* rpc_srv_destroyVars() Destroy variables of array & array | * rpc_srv_freeVars() Clean values from variables of array |
* @call = RPC function call |
* @call = RPC function call |
* return: -1 error, !=-1 Returne remained variables |
|
*/ |
|
inline int |
|
rpc_srv_destroyVars(rpc_func_t * __restrict call) |
|
{ |
|
if (!call) { |
|
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t delete variables ...\n"); |
|
return -1; |
|
} |
|
|
|
if (call->func_vars) { |
|
rpc_srv_freeVals(call); |
|
|
|
io_arrayFree(call->func_vars); |
|
io_arrayDestroy(&call->func_vars); |
|
} |
|
|
|
return io_arraySize(call->func_vars); |
|
} |
|
|
|
/* |
|
* rpc_srv_freeVals() Clean values from variables of array |
|
* @call = RPC function call |
|
* return: -1 error, !=-1 Returned number of cleaned variables |
* return: -1 error, !=-1 Returned number of cleaned variables |
*/ |
*/ |
inline int |
inline int |
rpc_srv_freeVals(rpc_func_t * __restrict call) | rpc_srv_freeVars(rpc_func_t * __restrict call) |
{ |
{ |
register int i; |
|
|
|
if (!call) { |
if (!call) { |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t delete variables ...\n"); |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t delete variables ...\n"); |
return -1; |
return -1; |
} |
} |
|
|
if (call->func_vars) { | return io_clrVars(call->func_vars); |
for (i = 0; i < io_arraySize(call->func_vars); i++) | |
if (io_arrayGet(call->func_vars, i)) | |
AIT_FREE_VAL(io_array(call->func_vars, i, ait_val_t*)); | |
} | |
| |
return io_arraySize(call->func_vars); | |
} |
} |
|
|
/* |
/* |
Line 265 rpc_srv_unregisterCall(rpc_srv_t * __restrict srv, con
|
Line 217 rpc_srv_unregisterCall(rpc_srv_t * __restrict srv, con
|
for (curr = srv->srv_funcs; curr->func_next != f; curr = curr->func_next); |
for (curr = srv->srv_funcs; curr->func_next != f; curr = curr->func_next); |
curr->func_next = curr->func_next->func_next; |
curr->func_next = curr->func_next->func_next; |
} |
} |
rpc_srv_destroyVars(f); | io_freeVars(&f->func_vars); |
free(f); |
free(f); |
pthread_mutex_unlock(&srv->srv_mtx); |
pthread_mutex_unlock(&srv->srv_mtx); |
|
|