| <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
| <html> |
| <head> |
| <title>modules/mod_log/mod_log.c</title> |
| <meta name="generator" content="c2html 1.1.0" > |
| <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1" > |
| <meta http-equiv="Content-Script-Type" content="text/javascript" > |
| <meta http-equiv="Content-Style-Type" content="text/css" > |
| </head> |
| <body text="#000000"> |
| <font face="Monospace"> |
| <font color="#808080"><i>/*<br> |
| * Licensed to the Apache Software Foundation (ASF) under one or more<br> |
| * contributor license agreements. See the NOTICE file distributed with<br> |
| * this work for additional information regarding copyright ownership.<br> |
| * The ASF licenses this file to You under the Apache License, Version 2.0<br> |
| * (the "License"); you may not use this file except in compliance with<br> |
| * the License. You may obtain a copy of the License at<br> |
| *<br> |
| * http://www.apache.org/licenses/LICENSE-2.0<br> |
| *<br> |
| * Unless required by applicable law or agreed to in writing, software<br> |
| * distributed under the License is distributed on an "AS IS" BASIS,<br> |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<br> |
| * See the License for the specific language governing permissions and<br> |
| * limitations under the License.<br> |
| */</i></font><br> |
| <font color="#008000">#include <axis2_module.h><br></font> |
| <font color="#008000">#include <axis2_conf_ctx.h><br></font> |
| <br> |
| <font color="#008000">#include "mod_log.h"<br></font> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_shutdown</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>);<br> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_init</font>(<br> |
| <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br> |
| <font color="#000000">axis2_conf_ctx_t</font> *<font color="#000000">conf_ctx</font>,<br> |
| <font color="#000000">axis2_module_desc_t</font> *<font color="#000000">module_desc</font>);<br> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_fill_handler_create_func_map</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>);<br> |
| <br> |
| <font color="#808080"><i>/**<br> |
| * Module operations struct variable with functions assigned to members<br> |
| */</i></font><br> |
| <font color="#800000">static</font> <font color="#800000">const</font> <font color="#000000">axis2_module_ops_t</font> <font color="#000000">log_module_ops_var</font> = {<br> |
| <font color="#000000">axis2_mod_log_init</font>,<br> |
| <font color="#000000">axis2_mod_log_shutdown</font>,<br> |
| <font color="#000000">axis2_mod_log_fill_handler_create_func_map</font><br> |
| };<br> |
| <br> |
| <font color="#000000">axis2_module_t</font> *<br> |
| <font color="#000000">axis2_mod_log_create</font>(<font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br> |
| {<br> |
| <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font> = <font color="#000000">NULL</font>;<br> |
| <font color="#000000">module</font> = <font color="#000000">AXIS2_MALLOC</font>(<font color="#000000">env</font>-><font color="#000000">allocator</font>, <br> |
| <font color="#000000"><b>sizeof</b></font>(<font color="#000000">axis2_module_t</font>));<br> |
| <br> |
| <font color="#808080"><i>/* initialize operations */</i></font><br> |
| <font color="#000000">module</font>-><font color="#000000">ops</font> = &<font color="#000000">log_module_ops_var</font>;<br> |
| <br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">module</font>;<br> |
| }<br> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_init</font>(<br> |
| <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br> |
| <font color="#000000">axis2_conf_ctx_t</font> *<font color="#000000">conf_ctx</font>,<br> |
| <font color="#000000">axis2_module_desc_t</font> *<font color="#000000">module_desc</font>)<br> |
| {<br> |
| <font color="#808080"><i>/* Any initialization stuff related to this module can be here */</i></font><br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br> |
| }<br> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_shutdown</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br> |
| {<br> |
| <font color="#000000"><b>if</b></font>(<font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font>)<br> |
| {<br> |
| <font color="#000000">axutil_hash_free</font>(<font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font>, <font color="#000000">env</font>);<br> |
| }<br> |
| <br> |
| <font color="#000000"><b>if</b></font>(<font color="#000000">module</font>)<br> |
| {<br> |
| <font color="#000000">AXIS2_FREE</font>(<font color="#000000">env</font>-><font color="#000000">allocator</font>, <font color="#000000">module</font>);<br> |
| }<br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>; <br> |
| }<br> |
| <br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br> |
| <font color="#000000">axis2_mod_log_fill_handler_create_func_map</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br> |
| {<br> |
| <font color="#000000">AXIS2_ENV_CHECK</font>(<font color="#000000">env</font>, <font color="#000000">AXIS2_FAILURE</font>);<br> |
| <br> |
| <font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font> = <font color="#000000">axutil_hash_make</font>(<font color="#000000">env</font>);<br> |
| <font color="#000000"><b>if</b></font>(!<font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font>)<br> |
| {<br> |
| <font color="#000000">AXIS2_ERROR_SET</font>(<font color="#000000">env</font>-><font color="#000000">error</font>, <font color="#000000">AXIS2_ERROR_NO_MEMORY</font>, <br> |
| <font color="#000000">AXIS2_FAILURE</font>);<br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_FAILURE</font>;<br> |
| }<br> |
| <br> |
| <font color="#808080"><i>/* add in handler */</i></font><br> |
| <font color="#000000">axutil_hash_set</font>(<font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font>, <font color="#FF0000">"LoggingInHandler"</font>, <br> |
| <font color="#000000">AXIS2_HASH_KEY_STRING</font>, <font color="#000000">axutil_log_in_handler_create</font>);<br> |
| <br> |
| <font color="#808080"><i>/* add out handler */</i></font><br> |
| <font color="#000000">axutil_hash_set</font>(<font color="#000000">module</font>-><font color="#000000">handler_create_func_map</font>, <font color="#FF0000">"LoggingOutHandler"</font>, <br> |
| <font color="#000000">AXIS2_HASH_KEY_STRING</font>, <font color="#000000">axutil_log_out_handler_create</font>);<br> |
| <br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br> |
| }<br> |
| <br> |
| <font color="#808080"><i>/**<br> |
| * Following functions are expected to be there in the module lib <br> |
| * that helps to create and remove module instances <br> |
| */</i></font><br> |
| <br> |
| <font color="#000000">AXIS2_EXPORT</font> <font color="#800000">int</font> <br> |
| <font color="#000000">axis2_get_instance</font>(<font color="#000000">axis2_module_t</font> **<font color="#000000">inst</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br> |
| {<br> |
| *<font color="#000000">inst</font> = <font color="#000000">axis2_mod_log_create</font>(<font color="#000000">env</font>);<br> |
| <font color="#000000"><b>if</b></font>(!(*<font color="#000000">inst</font>))<br> |
| {<br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_FAILURE</font>;<br> |
| }<br> |
| <br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br> |
| }<br> |
| <br> |
| <font color="#000000">AXIS2_EXPORT</font> <font color="#800000">int</font> <br> |
| <font color="#000000">axis2_remove_instance</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">inst</font>,<br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br> |
| {<br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">status</font> = <font color="#000000">AXIS2_FAILURE</font>;<br> |
| <font color="#000000"><b>if</b></font> (<font color="#000000">inst</font>)<br> |
| {<br> |
| <font color="#000000">status</font> = <font color="#000000">axis2_mod_log_shutdown</font>(<font color="#000000">inst</font>, <font color="#000000">env</font>);<br> |
| }<br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">status</font>;<br> |
| }<br> |
| <br> |
| <br> |
| </font> |
| </body> |
| </html> |