blob: c796dcdcb4b0b81aaa822e48feb525dcc5dc3894 [file] [log] [blame]
/*
* Copyright 2004,2005 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "axis2_svc_skeleton.h"
#include "math.h"
#include <axis2_array_list.h>
#include <stdio.h>
int AXIS2_CALL
math_free(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env);
/*
* This method invokes the right service method
*/
axis2_om_node_t* AXIS2_CALL
math_invoke(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env,
axis2_om_node_t *node,
axis2_msg_ctx_t *msg_ctx);
int AXIS2_CALL math_init(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env);
AXIS2_DECLARE(axis2_svc_skeleton_t *)
axis2_math_create(axis2_env_t **env)
{
axis2_svc_skeleton_t *svc_skeleton = NULL;
svc_skeleton = AXIS2_MALLOC((*env)->allocator,
sizeof(axis2_svc_skeleton_t));
svc_skeleton->ops = AXIS2_MALLOC(
(*env)->allocator, sizeof(axis2_svc_skeleton_ops_t));
svc_skeleton->func_array = NULL;
svc_skeleton->ops->free = math_free;
svc_skeleton->ops->init = math_init;
svc_skeleton->ops->invoke = math_invoke;
/*svc_skeleton->ops->on_fault = math_on_fault;*/
return svc_skeleton;
}
int AXIS2_CALL
math_init(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env)
{
svc_skeleton->func_array = axis2_array_list_create(env, 0);
AXIS2_ARRAY_LIST_ADD(svc_skeleton->func_array, env, "add");
AXIS2_ARRAY_LIST_ADD(svc_skeleton->func_array, env, "sub");
AXIS2_ARRAY_LIST_ADD(svc_skeleton->func_array, env, "mul");
AXIS2_ARRAY_LIST_ADD(svc_skeleton->func_array, env, "div");
/* Any initialization stuff of math goes here */
return AXIS2_SUCCESS;
}
int AXIS2_CALL
math_free(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env)
{
/*if(svc_skeleton->func_array)
{
AXIS2_ARRAY_LIST_FREE(svc_skeleton->func_array, env);
svc_skeleton->func_array = NULL;
}*/
if(svc_skeleton->ops)
{
AXIS2_FREE((*env)->allocator, svc_skeleton->ops);
svc_skeleton->ops = NULL;
}
if(svc_skeleton)
{
AXIS2_FREE((*env)->allocator, svc_skeleton);
svc_skeleton = NULL;
}
return AXIS2_SUCCESS;
}
/*
* This method invokes the right service method
*/
axis2_om_node_t* AXIS2_CALL
math_invoke(axis2_svc_skeleton_t *svc_skeleton,
axis2_env_t **env,
axis2_om_node_t *node,
axis2_msg_ctx_t *msg_ctx)
{
/* Depending on the function name invoke the
* corresponding math method
*/
if (node)
{
if (AXIS2_OM_NODE_GET_NODE_TYPE(node, env) == AXIS2_OM_ELEMENT)
{
axis2_om_element_t *element = NULL;
element = (axis2_om_element_t *)AXIS2_OM_NODE_GET_DATA_ELEMENT(node, env);
if (element)
{
axis2_char_t *op_name = AXIS2_OM_ELEMENT_GET_LOCALNAME(element, env);
if (op_name)
{
if ( AXIS2_STRCMP(op_name, "add") == 0 )
return axis2_math_add(env, node);
if ( AXIS2_STRCMP(op_name, "sub") == 0 )
return axis2_math_sub(env, node);
if ( AXIS2_STRCMP(op_name, "mul") == 0 )
return axis2_math_mul(env, node);
if ( AXIS2_STRCMP(op_name, "div") == 0 )
return axis2_math_div(env, node);
}
}
}
}
printf("Math service ERROR: invalid OM parameters in request\n");
/** TODO: return a SOAP fault here */
return node;
}
/**
* Following block distinguish the exposed part of the dll.
*/
AXIS2_EXPORT int axis2_get_instance(struct axis2_svc_skeleton **inst,
axis2_env_t **env)
{
*inst = axis2_math_create(env);
/*if(NULL != *inst)
{
status = *inst->init();
}*/
if(!(*inst))
{
return AXIS2_FAILURE;
}
return AXIS2_SUCCESS;
}
AXIS2_EXPORT int axis2_remove_instance(axis2_svc_skeleton_t *inst,
axis2_env_t **env)
{
axis2_status_t status = AXIS2_FAILURE;
if (inst)
{
status = AXIS2_SVC_SKELETON_FREE(inst, env);
}
return status;
}