blob: a18eb8907341452b64f28099b9f584636b81ce10 [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html><head><title>Apache Axis2/C - Apache Axis2/C - modules/mod_log/mod_log.c</title><style type="text/css" media="all">
@import url("../../style/maven-base.css");
@import url("../../style/maven-classic.css");</style><link rel="stylesheet" href="../../style/print.css" type="text/css" media="print"></link><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"></meta></head><body class="composite"><div id="banner"><a href="http://www.apache.org/" id="organizationLogo"><img alt="Apache Software Foundation" src="http://www.apache.org/images/asf-logo.gif"></img></a><a href="http://ws.apache.org/axis2/c" id="projectLogo"><img alt="Apache Axis2/C" src="http://ws.apache.org/axis2/images/axis.jpg"></img></a><div class="clear"><hr></hr></div></div><div id="breadcrumbs"><div class="xleft">
Last published: 21 July 2008
| Doc for 1.5.0</div><div class="xright"></div><div class="clear"><hr></hr></div></div><div id="leftColumn"><div id="navcolumn"><div id="menuApache_Axis2_C"><h5>Apache Axis2/C</h5><ul><li class="none"><a href="../../index.html">Apache Axis2/C Home</a></li><li class="expanded"><a href="../../download.cgi">Download Axis2/C</a><ul><li class="none"><a href="../../download.cgi">Releases</a></li></ul></li><li class="expanded"><a href="../../docs/index.html">Documentation</a><ul><li class="none"><a href="../../docs/installationguide.html">Installation Guide</a></li><li class="none"><a href="../../docs/axis2c_manual.html">Axis2/C manual</a></li><li class="none"><a href="../../docs/faq.html">Axis2/C FAQ</a></li></ul></li><li class="expanded"><a href="../../lists_issues.html">Get Involved</a><ul><li class="none"><a href="../../lists_issues.html">Mailing Lists &amp; Issue Tracking</a></li><li class="none"><a href="../../svn.html">Checkout Source Code</a></li></ul></li><li class="expanded"><a href="../../coding_conventions.html">Developer Guidelines</a><ul><li class="none"><a href="../../coding_conventions.html">Coding Convention</a></li><li class="none"><a href="../../versioning.html">Versionning</a></li></ul></li><li class="expanded"><a href="../../team-list.html">Project Information</a><ul><li class="none"><a href="../../team-list.html">Project Team</a></li><li class="none"><a href="http://svn.apache.org/viewcvs.cgi/webservices/axis2/trunk/c/" class="externalLink" title="External Link">Source Code</a></li></ul></li></ul></div><a href="http://maven.apache.org/" title="Built by Maven" id="poweredBy"><img alt="Built by Maven" src="../../images/logos/maven-button-1.png"></img></a></div></div><div id="bodyColumn"><div class="contentBox"><div class="section"><div class="contentBox"><div class="section"><font face="Monospace">
<font color="#808080"><i>/*<br></br>
 * Licensed to the Apache Software Foundation (ASF) under one or more<br></br>
 * contributor license agreements.  See the NOTICE file distributed with<br></br>
 * this work for additional information regarding copyright ownership.<br></br>
 * The ASF licenses this file to You under the Apache License, Version 2.0<br></br>
 * (the "License"); you may not use this file except in compliance with<br></br>
 * the License.  You may obtain a copy of the License at<br></br>
 *<br></br>
 *      http://www.apache.org/licenses/LICENSE-2.0<br></br>
 *<br></br>
 * Unless required by applicable law or agreed to in writing, software<br></br>
 * distributed under the License is distributed on an "AS IS" BASIS,<br></br>
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<br></br>
 * See the License for the specific language governing permissions and<br></br>
 * limitations under the License.<br></br>
 */</i></font><br></br>
<font color="#008000">#include &lt;axis2_module.h&gt;<br></br></font>
<font color="#008000">#include &lt;axis2_conf_ctx.h&gt;<br></br></font>
<br></br>
<font color="#008000">#include "mod_log.h"<br></br></font>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br>
<font color="#000000">axis2_mod_log_shutdown</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br></br>
    <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>);<br></br>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br>
<font color="#000000">axis2_mod_log_init</font>(<br></br>
    <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br></br>
    <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br></br>
    <font color="#000000">axis2_conf_ctx_t</font> *<font color="#000000">conf_ctx</font>,<br></br>
    <font color="#000000">axis2_module_desc_t</font> *<font color="#000000">module_desc</font>);<br></br>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></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></br>
    <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>);<br></br>
<br></br>
<font color="#808080"><i>/**<br></br>
 * Module operations struct variable with functions assigned to members<br></br>
 */</i></font><br></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></br>
    <font color="#000000">axis2_mod_log_init</font>,<br></br>
    <font color="#000000">axis2_mod_log_shutdown</font>,<br></br>
    <font color="#000000">axis2_mod_log_fill_handler_create_func_map</font><br></br>
};<br></br>
<br></br>
<font color="#000000">axis2_module_t</font> *<br></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>
{<br></br>
    <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font> = <font color="#000000">NULL</font>;<br></br>
    <font color="#000000">module</font> = <font color="#000000">AXIS2_MALLOC</font>(<font color="#000000">env</font>-&gt;<font color="#000000">allocator</font><br></br>
        <font color="#000000"><b>sizeof</b></font>(<font color="#000000">axis2_module_t</font>));<br></br>
<br></br>
    <font color="#808080"><i>/* initialize operations */</i></font><br></br>
    <font color="#000000">module</font>-&gt;<font color="#000000">ops</font> = &amp;<font color="#000000">log_module_ops_var</font>;<br></br>
<br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">module</font>;<br></br>
}<br></br>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br>
<font color="#000000">axis2_mod_log_init</font>(<br></br>
        <font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br></br>
        <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br></br>
        <font color="#000000">axis2_conf_ctx_t</font> *<font color="#000000">conf_ctx</font>,<br></br>
        <font color="#000000">axis2_module_desc_t</font> *<font color="#000000">module_desc</font>)<br></br>
{<br></br>
    <font color="#808080"><i>/* Any initialization stuff related to this module can be here */</i></font><br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br></br>
}<br></br>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br>
<font color="#000000">axis2_mod_log_shutdown</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">module</font>,<br></br>
                        <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br></br>
{<br></br>
    <font color="#000000"><b>if</b></font>(<font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font>)<br></br>
    {<br></br>
        <font color="#000000">axutil_hash_free</font>(<font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font><font color="#000000">env</font>);<br></br>
    }<br></br>
    <br></br>
    <font color="#000000"><b>if</b></font>(<font color="#000000">module</font>)<br></br>
    {<br></br>
        <font color="#000000">AXIS2_FREE</font>(<font color="#000000">env</font>-&gt;<font color="#000000">allocator</font><font color="#000000">module</font>);<br></br>
    }<br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font><br></br>
}<br></br>
<br></br>
<font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></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></br>
                                            <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br></br>
{<br></br>
    <font color="#000000">AXIS2_ENV_CHECK</font>(<font color="#000000">env</font><font color="#000000">AXIS2_FAILURE</font>);<br></br>
    <br></br>
    <font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font> = <font color="#000000">axutil_hash_make</font>(<font color="#000000">env</font>);<br></br>
    <font color="#000000"><b>if</b></font>(!<font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font>)<br></br>
    {<br></br>
        <font color="#000000">AXIS2_ERROR_SET</font>(<font color="#000000">env</font>-&gt;<font color="#000000">error</font><font color="#000000">AXIS2_ERROR_NO_MEMORY</font><br></br>
            <font color="#000000">AXIS2_FAILURE</font>);<br></br>
        <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_FAILURE</font>;<br></br>
    }<br></br>
<br></br>
    <font color="#808080"><i>/* add in handler */</i></font><br></br>
    <font color="#000000">axutil_hash_set</font>(<font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font><font color="#FF0000">"LoggingInHandler"</font><br></br>
        <font color="#000000">AXIS2_HASH_KEY_STRING</font><font color="#000000">axutil_log_in_handler_create</font>);<br></br>
<br></br>
    <font color="#808080"><i>/* add out handler */</i></font><br></br>
    <font color="#000000">axutil_hash_set</font>(<font color="#000000">module</font>-&gt;<font color="#000000">handler_create_func_map</font><font color="#FF0000">"LoggingOutHandler"</font><br></br>
        <font color="#000000">AXIS2_HASH_KEY_STRING</font><font color="#000000">axutil_log_out_handler_create</font>);<br></br>
    <br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br></br>
}<br></br>
<br></br>
<font color="#808080"><i>/**<br></br>
 * Following functions are expected to be there in the module lib <br></br>
 * that helps to create and remove module instances <br></br>
 */</i></font><br></br>
<br></br>
<font color="#000000">AXIS2_EXPORT</font> <font color="#800000">int</font> <br></br>
<font color="#000000">axis2_get_instance</font>(<font color="#000000">axis2_module_t</font> **<font color="#000000">inst</font>,<br></br>
                   <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br></br>
{<br></br>
   *<font color="#000000">inst</font> = <font color="#000000">axis2_mod_log_create</font>(<font color="#000000">env</font>);<br></br>
    <font color="#000000"><b>if</b></font>(!(*<font color="#000000">inst</font>))<br></br>
    {<br></br>
        <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_FAILURE</font>;<br></br>
    }<br></br>
<br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br></br>
}<br></br>
<br></br>
<font color="#000000">AXIS2_EXPORT</font> <font color="#800000">int</font> <br></br>
<font color="#000000">axis2_remove_instance</font>(<font color="#000000">axis2_module_t</font> *<font color="#000000">inst</font>,<br></br>
                      <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>)<br></br>
{<br></br>
    <font color="#000000">axis2_status_t</font> <font color="#000000">status</font> = <font color="#000000">AXIS2_FAILURE</font>;<br></br>
   <font color="#000000"><b>if</b></font> (<font color="#000000">inst</font>)<br></br>
   {<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>
    }<br></br>
    <font color="#000000"><b>return</b></font> <font color="#000000">status</font>;<br></br>
}<br></br>
<br></br>
<br></br>
</font></div></div><div class="clear"><hr></hr></div></div></div></div><div class="clear"><hr></hr></div><div id="footer"><div class="xright">© 2005-2008, Apache Software Foundation</div><div class="clear"><hr></hr></div></div></body></html>