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

wsp_strings.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 /* wsp-strings.h: interface to tables defined by WSP standard
00058  *
00059  * This file defines an interface to the Assigned Numbers tables
00060  * in appendix A of the WSP specification.  For each supported
00061  * table there is a function to convert from number to string and
00062  * a function to convert from string to number.
00063  *
00064  * The tables are in wsp-strings.def, in a special format suitable for
00065  * use with the C preprocessor, which we abuse liberally to get the
00066  * interface we want. 
00067  *
00068  * For a table named foo, these functions will be declared:
00069  *
00070  * Octstr *wsp_foo_to_string(long number);
00071  *   - return NULL if the number has no assigned string.
00072  * 
00073  * unsigned char *wsp_foo_to_cstr(long number);
00074  *   - return NULL if the number has no assigned string.
00075  *
00076  * long wsp_string_to_foo(Octstr *ostr);
00077  *   - case-insensitive lookup.
00078  *   - Return -1 if the string has no assigned number.
00079  *
00080  * Richard Braakman
00081  */
00082 
00083 #ifndef WSP_STRINGS_H
00084 #define WSP_STRINGS_H
00085 
00086 #include "gwlib/gwlib.h"
00087 #include "wap/wsp.h"
00088 
00089 /* Must be called before any of the other functions in this file.
00090  * Can be called more than once, in which case multiple shutdowns
00091  * are also required. */
00092 void wsp_strings_init(void);
00093 
00094 /* Call this to clean up memory allocations */
00095 void wsp_strings_shutdown(void);
00096 
00097 /* Declare the functions */
00098 #define LINEAR(name, strings) \
00099 Octstr *wsp_##name##_to_string(long number); \
00100 unsigned char *wsp_##name##_to_cstr(long number); \
00101 long wsp_string_to_##name(Octstr *ostr); \
00102 long wsp_string_to_versioned_##name(Octstr *ostr, int version); 
00103 #define STRING(string)
00104 #include "wsp_strings.def"
00105 
00106 /* Define the enumerated types */
00107 #define LINEAR(name, strings)
00108 #define STRING(string)
00109 #define NAMED(name, strings) enum name##_enum { strings name##_dummy };
00110 #define NSTRING(string, name) name,
00111 #define VNSTRING(version, string, name) name,
00112 #include "wsp_strings.def"
00113 
00114 #endif
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.