Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

wml_compiler.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * wml_compiler.h - compiling WML to WML binary
00059  *
00060  * This is a header for WML compiler for compiling the WML text 
00061  * format to WML binary format, which is used for transmitting the 
00062  * decks to the mobile terminal to decrease the use of the bandwidth.
00063  *
00064  * See comments below for explanations on individual functions.
00065  *
00066  * Tuomas Luttinen for Wapit Ltd.
00067  */
00068 
00069 
00070 #ifndef WML_COMPILER_H
00071 #define WML_COMPILER_H
00072 
00073 /*
00074  * wml_compile - the interface to wml_compiler
00075  * 
00076  * This function compiles the WML to WML binary. The arguments are 
00077  * the following: 
00078  *   wml_text: the WML text to be compiled
00079  *   charset: the character set as HTTP headers declare it
00080  *   wml_binary: buffer for the compiled WML binary
00081  *   version: max wbxml version supported by device, or NULL for default
00082  *
00083  * The wml_text and charset are allocated by the caller and should also be
00084  * freed by the caller. The function takes care for memory allocation for
00085  * the wml_binary. The caller is responsible for freeing this space. 
00086  * 
00087  * Return: 0 for ok, -1 for an error
00088  * 
00089  * Errors are logged with a little explanation and error number.
00090  */
00091 int wml_compile(Octstr *wml_text,
00092         Octstr *charset,
00093         Octstr **wml_binary,
00094         Octstr *version);
00095 
00096 /*
00097  * A function to initialize the wml compiler for use. Allocates memory 
00098  * for the tables wml compiler uses.
00099  * 
00100  * The passed boolean defines if our internal wml_compiler will be forcing
00101  * libxml2 parser to be strict, hence not to recover from XML parsing
00102  * errors, or if we let the parset be relax and recover from errors.
00103  * 
00104  * Beware that a related XML parsing mode is considered to be a vulnerability
00105  * to your wapbox if huge WML/XML bogus is injected and the wml_compiler
00106  * runs all his string sorting/matching things on this.
00107  */
00108 void wml_init(int wml_xml_strict);
00109 
00110 /*
00111  * A function for shutting down the wml_compiler. Frees the memory used 
00112  * by the wml compiler.
00113  */
00114 void wml_shutdown(void);
00115 
00116 
00117 #endif
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.