File: datatypes.c

package info (click to toggle)
virtuoso-opensource 7.2.5.1%2Bdfsg1-0.3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 285,240 kB
  • sloc: ansic: 641,220; sql: 490,413; xml: 269,570; java: 83,893; javascript: 79,900; cpp: 36,927; sh: 31,653; cs: 25,702; php: 12,690; yacc: 10,227; lex: 7,601; makefile: 7,129; jsp: 4,523; awk: 1,697; perl: 1,013; ruby: 1,003; python: 326
file content (106 lines) | stat: -rw-r--r-- 3,360 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 *  datatypes.c
 *
 *  $Id$
 *
 *  This file is part of the OpenLink Software Virtuoso Open-Source (VOS)
 *  project.
 *
 *  Copyright (C) 1998-2018 OpenLink Software
 *
 *  This project is free software; you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License as published by the
 *  Free Software Foundation; only version 2 of the License, dated June 1991.
 *
 *  This program is distributed in the hope that it will be useful, but
 *  WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 *  General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License along
 *  with this program; if not, write to the Free Software Foundation, Inc.,
 *  51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 *
 */

#include "xmlparser_impl.h"
#include "schema.h"
#include "pcre.h"

ptrlong
xs_get_primitive_typeidx (vxml_parser_t * parser, xs_component_t *type)
{
  xs_component_t *base_type;
  if (!IS_BOX_POINTER (type))
    base_type = type;
  else
    {
      xs_component_t *type_cm = (xs_component_t *) type;
      xs_component_t *root = get_root_type (parser, type_cm);
      if (!root)
	{
	  xs_set_error (parser, XCFG_DETAILS, 200,
	      "Could not resolve base type for '%s'", type_cm->cm_qname);
	  return -1;
	}
      base_type = root->cm_typename;
    }
  return (ptrlong)base_type;
}

extern caddr_t regexp_match_01 (const char* pattern, const char* str, int c_opts);

int
xs_check_type_compliance (vxml_parser_t * parser, xs_component_t *type,
    const char * value, int err_options)
{
  ptrlong base_type_idx;
  const char *basetype_regexp;
/*  XS_ASSERT(IS_COMPLEX_TYPE((type) || IS_SIMPLE_TYPE(type)); */

  base_type_idx = xs_get_primitive_typeidx (parser, type);
  if (base_type_idx == -1)
    {
      xmlparser_logprintf (parser, XCFG_ERROR | err_options, 200 + utf8len (value),
	  "Value '%s' could not be checked due to undefined type", value);
      return XS_ROOT_TYPE_ERROR;
    }
  basetype_regexp = xs_builtin_type_info_dict[base_type_idx].binfo_regexp_or_null;
  if (NULL != basetype_regexp)
    {
      int match_len = 1;
      caddr_t match = regexp_match_01 (basetype_regexp, (const char *) value, PCRE_UTF8);
      if (match)
	{
	  match_len = box_length (match);
          dk_free_box (match);
          if ((strlen ((caddr_t) value) + 1) == match_len)
            match_len = 0;
        }
      if (match_len)
	{
	  if ('\0' == value[0])
	    {
	      xs_set_error (parser, XCFG_ERROR | err_options, 300,
		"Empty string does not match expected pattern '%s' for type '%s'",
		basetype_regexp,
		xs_builtin_type_info_dict[base_type_idx].binfo_name );
	    }
	  else
	    {
	      char *err_line = dk_alloc_box (match_len + 1, DV_SHORT_STRING);
	      memset (err_line, '-', match_len - 1);
	      err_line[match_len - 1] = '^';
	      err_line[match_len] = '\0';
	      xs_set_error (parser, XCFG_ERROR | err_options, 300 + utf8len (value) + match_len,
		"Value does not match expected pattern '%s' for type '%s':\nValue='%s'\n-------%s",
		basetype_regexp,
		xs_builtin_type_info_dict[base_type_idx].binfo_name, value, err_line);
	      dk_free_box (err_line);
	      SHOULD_BE_CHANGED;	/* errors handling */
	    }
	}
      return match_len;
    }
  return 0;
}