annotate GEMBASSY-1.0.3/gsoap/custom/long_double.c @ 1:84a17b3fad1f draft

Uploaded
author ktnyt
date Fri, 26 Jun 2015 05:20:29 -0400
parents 8300eb051bea
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
1 /*
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
2 long_double.c
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
3
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
4 Custom serializer for the long double (extended double) type as
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
5 xsd:decimal.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
6
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
7 Compile this file and link it with your code.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
8
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
9 gSOAP XML Web services tools
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
10 Copyright (C) 2000-2007, Robert van Engelen, Genivia Inc., All Rights Reserved.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
11 This part of the software is released under ONE of the following licenses:
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
12 GPL, the gSOAP public license, OR Genivia's license for commercial use.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
13 --------------------------------------------------------------------------------
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
14 gSOAP public license.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
15
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
16 The contents of this file are subject to the gSOAP Public License Version 1.3
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
17 (the "License"); you may not use this file except in compliance with the
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
18 License. You may obtain a copy of the License at
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
19 http://www.cs.fsu.edu/~engelen/soaplicense.html
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
20 Software distributed under the License is distributed on an "AS IS" basis,
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
21 WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
22 for the specific language governing rights and limitations under the License.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
23
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
24 The Initial Developer of the Original Code is Robert A. van Engelen.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
25 Copyright (C) 2000-2007, Robert van Engelen, Genivia, Inc., All Rights Reserved.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
26 --------------------------------------------------------------------------------
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
27 GPL license.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
28
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
29 This program is free software; you can redistribute it and/or modify it under
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
30 the terms of the GNU General Public License as published by the Free Software
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
31 Foundation; either version 2 of the License, or (at your option) any later
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
32 version.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
33
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
34 This program is distributed in the hope that it will be useful, but WITHOUT ANY
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
35 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
36 PARTICULAR PURPOSE. See the GNU General Public License for more details.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
37
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
38 You should have received a copy of the GNU General Public License along with
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
39 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
40 Place, Suite 330, Boston, MA 02111-1307 USA
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
41
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
42 Author contact information:
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
43 engelen@genivia.com / engelen@acm.org
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
44
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
45 This program is released under the GPL with the additional exemption that
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
46 compiling, linking, and/or using OpenSSL is allowed.
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
47 --------------------------------------------------------------------------------
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
48 A commercial use license is available from Genivia, Inc., contact@genivia.com
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
49 --------------------------------------------------------------------------------
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
50 */
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
51
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
52 /* soapH.h generated by soapcpp2: */
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
53 #include "soapH.h"
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
54 #include <float.h>
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
55
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
56 int soap_s2decimal(struct soap *soap, const char *s, long double *p)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
57 { if (s)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
58 { if (!*s)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
59 return soap->error = SOAP_TYPE;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
60 if (!soap_tag_cmp(s, "INF"))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
61 *p = (long double)DBL_PINFTY;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
62 else if (!soap_tag_cmp(s, "+INF"))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
63 *p = (long double)DBL_PINFTY;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
64 else if (!soap_tag_cmp(s, "-INF"))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
65 *p = (long double)DBL_NINFTY;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
66 else if (!soap_tag_cmp(s, "NaN"))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
67 *p = (long double)DBL_NAN;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
68 else
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
69 {
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
70 #if defined(HAVE_STRTOLD_L)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
71 char *r;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
72 *p = strtold_l(s, &r, NULL);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
73 if (*r)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
74 #elif defined(HAVE_STRTOLD)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
75 char *r;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
76 *p = strtold(s, &r);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
77 if (*r)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
78 #endif
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
79 #if defined(HAVE_SSCANF_L)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
80 if (sscanf_l(s, NULL, "%Lg", p) != 1)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
81 soap->error = SOAP_TYPE;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
82 #elif defined(HAVE_SSCANF)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
83 if (sscanf(s, "%Lg", p) != 1)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
84 soap->error = SOAP_TYPE;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
85 #else
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
86 soap->error = SOAP_TYPE;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
87 #endif
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
88 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
89 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
90 return soap->error;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
91 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
92
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
93 const char *soap_decimal2s(struct soap *soap, long double n)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
94 { char *s;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
95 if (soap_isnan(n))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
96 return "NaN";
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
97 if (soap_ispinfd(n))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
98 return "INF";
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
99 if (soap_isninfd(n))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
100 return "-INF";
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
101 s = soap->tmpbuf;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
102 #if defined(HAVE_SPRINTF_L)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
103 sprintf_l(s, NULL, "%.*Lg", LDBL_DIG, n);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
104 #else
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
105 sprintf(s, "%.*Lg", LDBL_DIG, n);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
106 s = strchr(s, ','); /* convert decimal comma to DP */
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
107 if (s)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
108 *s = '.';
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
109 #endif
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
110 return soap->tmpbuf;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
111 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
112
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
113 int
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
114 soap_outdecimal(struct soap *soap, const char *tag, int id, const long double *p, const char *type, int n)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
115 { if (soap_element_begin_out(soap, tag, soap_embedded_id(soap, id, p, n), type)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
116 || soap_string_out(soap, soap_decimal2s(soap, *p), 0))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
117 return soap->error;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
118 return soap_element_end_out(soap, tag);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
119 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
120
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
121 long double *
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
122 soap_indecimal(struct soap *soap, const char *tag, long double *p, const char *type, int t)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
123 { if (soap_element_begin_in(soap, tag, 0, type))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
124 return NULL;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
125 p = (long double*)soap_id_enter(soap, soap->id, p, t, sizeof(long double), 0, NULL, NULL, NULL);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
126 if (*soap->href)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
127 p = (long double*)soap_id_forward(soap, soap->href, p, 0, t, 0, sizeof(long double), 0, NULL);
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
128 else if (p)
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
129 { if (soap_s2decimal(soap, soap_value(soap), p))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
130 return NULL;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
131 }
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
132 if (soap->body && soap_element_end_in(soap, tag))
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
133 return NULL;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
134 return p;
8300eb051bea Initial upload
ktnyt
parents:
diff changeset
135 }