summaryrefslogtreecommitdiffstats
path: root/util/include/axutil_param_container.h
diff options
context:
space:
mode:
Diffstat (limited to 'util/include/axutil_param_container.h')
-rw-r--r--util/include/axutil_param_container.h134
1 files changed, 134 insertions, 0 deletions
diff --git a/util/include/axutil_param_container.h b/util/include/axutil_param_container.h
new file mode 100644
index 0000000..e61b9d5
--- /dev/null
+++ b/util/include/axutil_param_container.h
@@ -0,0 +1,134 @@
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.
+ */
+
+#ifndef AXUTIL_PARAM_CONTAINER_H
+#define AXUTIL_PARAM_CONTAINER_H
+
+/** @defgroup axutil_param_container Parameter Container
+ * @ingroup axis2_descript
+ * @{
+ */
+
+/**
+ * @file axutil_param_container.h
+ * @brief Axis2 Param container interface
+ */
+
+#include <axutil_utils.h>
+#include <axutil_error.h>
+#include <axutil_utils_defines.h>
+#include <axutil_env.h>
+#include <axutil_allocator.h>
+#include <axutil_string.h>
+#include <axutil_array_list.h>
+#include <axutil_hash.h>
+
+/*#include <axiom_element.h>*/
+#include <axutil_qname.h>
+#include <axutil_param.h>
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+ typedef struct axutil_param_container axutil_param_container_t;
+
+ /**
+ * Creates param container struct
+ * @return pointer to newly created param container
+ */
+ AXIS2_EXTERN axutil_param_container_t *AXIS2_CALL
+
+ axutil_param_container_create(
+ const axutil_env_t * env);
+
+ /**
+ * Free param_container passed as void pointer. This will be
+ * cast into appropriate type and then pass the cast object
+ * into the param_container structure's free method
+ */
+ AXIS2_EXTERN void AXIS2_CALL
+ axutil_param_container_free_void_arg(
+ void *param_container,
+ const axutil_env_t * env);
+
+ /** De-allocate memory
+ * @return status code
+ */
+ AXIS2_EXTERN void AXIS2_CALL
+ axutil_param_container_free(
+ axutil_param_container_t * param_container,
+ const axutil_env_t * env);
+
+ /** Add a param
+ * @param param param to be added
+ * @return status code
+ */
+ AXIS2_EXTERN axis2_status_t AXIS2_CALL
+ axutil_param_container_add_param(
+ axutil_param_container_t * param_container,
+ const axutil_env_t * env,
+ axutil_param_t * param);
+
+ /** To get a param in a given description
+ * @param name param name
+ * @return param
+ */
+ AXIS2_EXTERN axutil_param_t *AXIS2_CALL
+ axutil_param_container_get_param(
+ axutil_param_container_t * param_container,
+ const axutil_env_t * env,
+ const axis2_char_t * name);
+
+ /** To get all the params in a given description
+ * @return all the params contained
+ */
+ AXIS2_EXTERN axutil_array_list_t *AXIS2_CALL
+
+ axutil_param_container_get_params(
+ axutil_param_container_t * param_container,
+ const axutil_env_t * env);
+
+ /** To check whether the paramter is locked at any level
+ * @param param_name name of the param
+ * @return whether param is locked
+ */
+ AXIS2_EXTERN axis2_bool_t AXIS2_CALL
+
+ axutil_param_container_is_param_locked(
+ axutil_param_container_t * param_container,
+ const axutil_env_t * env,
+ const axis2_char_t * param_name);
+
+ /** Remove parameter from the param container
+ * @param parameter name of the param to be removed
+ * @return status of AXIS2_SUCCESS or AXIS2_FAILURE
+ */
+ AXIS2_EXTERN axis2_status_t AXIS2_CALL
+ axutil_param_container_delete_param(
+ axutil_param_container_t *param_container,
+ const axutil_env_t *env,
+ const axis2_char_t *param_name);
+
+ /** @} */
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* AXIS2_PARAM_CONTAINER_H */