maplibxml2.c 3.79 KB
Newer Older
1
/******************************************************************************
2
 * $Id$
3 4 5
 *
 * Project:  MapServer
 * Purpose:  libxml2 convenience wrapper functions
6
 * Author:   Tom Kralidis (tomkralidis@gmail.com)
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
 *
 ******************************************************************************
 * Copyright (c) 2007, Tom Kralidis
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies of this Software or works derived from this Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 * DEALINGS IN THE SOFTWARE.
 ****************************************************************************/

#include "mapserver.h"

#ifdef USE_LIBXML2

#include<libxml/parser.h>
#include<libxml/tree.h>
#include<libxml/xpath.h>
#include<libxml/xpathInternals.h>

39

40 41 42 43 44 45 46 47 48 49 50 51 52 53

/**
 * msLibXml2GenerateList()
 *
 * Convenience function to produce a series of XML elements from a delimited list
 *
 * @param xmlNodePtr psParent the encompassing node
 * @param xmlNsPtr psNs the namespace object
 * @param const char *elname the list member element name
 * @param const char *values the list member element values
 * @param char delim the delimiter
 *
 */

54 55
void msLibXml2GenerateList(xmlNodePtr psParent, xmlNsPtr psNs, const char *elname, const char *values, char delim)
{
56 57 58 59
  char **tokens = NULL;
  int n = 0;
  int i = 0;
  tokens = msStringSplit(values, delim, &n);
60
  for (i=0; i<n; i++) {
61 62 63 64 65 66
    // Not sure we really need to distinguish empty vs non-empty case, but
    // this does change the result of msautotest/wxs/expected/wcs_empty_cap111.xml otherwise
    if( tokens[i] && tokens[i][0] != '\0' )
      xmlNewTextChild(psParent, psNs, BAD_CAST elname, BAD_CAST tokens[i]);
    else
      xmlNewChild(psParent, psNs, BAD_CAST elname, BAD_CAST tokens[i]);
67
  }
68
  msFreeCharArray(tokens, n);
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
}

/**
 * msLibXml2GetXPath()
 *
 * Convenience function to fetch an XPath
 *
 * @param xmlDocPtr doc the XML doc pointer
 * @param xmlXPathContextPtr the context pointer
 * @param xmlChar *xpath the xpath value
 *
 * @return result xmlXPathObjectPtr pointer
 *
 */

84 85
xmlXPathObjectPtr msLibXml2GetXPath(xmlDocPtr doc, xmlXPathContextPtr context, xmlChar *xpath)
{
86 87 88 89 90
  xmlXPathObjectPtr result;
  result = xmlXPathEval(xpath, context);
  if (result == NULL) {
    return NULL;
  }
91
  if(xmlXPathNodeSetIsEmpty(result->nodesetval)) {
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
    xmlXPathFreeObject(result);
    return NULL;
  }
  return result;
}

/**
 * msLibXml2GetXPathTree
 *
 * Convenience function to fetch an XPath and children
 *
 * @param xmlDocPtr doc the XML doc pointer
 * @param xmlXPathObjectPtr the xpath object
 *
 * @return result string
 *
 */

110
char *msLibXml2GetXPathTree(xmlDocPtr doc, xmlXPathObjectPtr xpath)
111
{
112
  xmlBufferPtr xbuf;
113
  char *result = NULL;
114 115 116 117 118 119 120

  xbuf = xmlBufferCreate();

  if (xpath) {
    if (xmlNodeDump(xbuf, doc, xpath->nodesetval->nodeTab[0], 0, 0) == -1) {
      return NULL;
    }
121
    result = msStrdup((char *)xbuf->content);
122 123 124 125 126 127
  }
  xmlBufferFree(xbuf);
  return result;
}

#endif /* defined(USE_LIBXML2) */