-
-
Notifications
You must be signed in to change notification settings - Fork 356
/
class.i
258 lines (225 loc) · 8.75 KB
/
class.i
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
/* ===========================================================================
Project: MapServer
Purpose: SWIG interface file for mapscript classObj extensions
Author: Steve Lime
Sean Gillies, sgillies@frii.com
Seth Girvin
===========================================================================
Copyright (c) 1996-2019 Regents of the University of Minnesota.
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 or substantial portions of the 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.
===========================================================================
*/
%extend classObj {
/// Create a new child classObj instance at the tail (highest index) of the
/// class array of the parent_layer. A class can be created outside the
/// context of a parent layer by omitting the layerObj constructor argument
classObj(layerObj *layer=NULL)
{
classObj *new_class=NULL;
if (!layer)
{
new_class = (classObj *) malloc(sizeof(classObj));
if (!new_class)
{
msSetError(MS_MEMERR,
"Could not allocate memory for new classObj instance",
"classObj()");
return NULL;
}
if (initClass(new_class) == -1) return NULL;
new_class->layer = NULL;
return new_class;
}
else
{
if(msGrowLayerClasses(layer) == NULL)
return NULL;
if (initClass(layer->class[layer->numclasses]) == -1)
return NULL;
layer->class[layer->numclasses]->layer = layer;
MS_REFCNT_INCR(layer->class[layer->numclasses]);
layer->numclasses++;
return (layer->class[layer->numclasses-1]);
}
return NULL;
}
~classObj()
{
if (self)
{
if (freeClass(self)==MS_SUCCESS) {
free(self);
self=NULL;
}
}
}
/// Update a class from a string snippet. Returns :data:`MS_SUCCESS` or :data:`MS_FAILURE`
int updateFromString(char *snippet)
{
return msUpdateClassFromString(self, snippet, MS_FALSE);
}
%newobject convertToString;
/// Output the CLASS as a Mapfile string
char* convertToString()
{
return msWriteClassToString(self);
}
#if defined (SWIGJAVA) || defined (SWIGPHP)
%newobject cloneClass;
classObj *cloneClass()
#else
%newobject clone;
/// Return an independent copy of the class without a parent layer
classObj *clone()
#endif
{
classObj *new_class;
new_class = (classObj *) malloc(sizeof(classObj));
if (!new_class)
{
msSetError(MS_MEMERR,
"Could not allocate memory for new classObj instance",
"clone()");
return NULL;
}
if (initClass(new_class) == -1)
{
msSetError(MS_MEMERR, "Failed to initialize Class",
"clone()");
return NULL;
}
new_class->layer = NULL;
if (msCopyClass(new_class, self, self->layer) != MS_SUCCESS) {
freeClass(new_class);
free(new_class);
new_class = NULL;
}
return new_class;
}
/// Set :ref:`EXPRESSION <mapfile-class-expression>` string where `expression` is a MapServer regular,
/// logical or string expression. Returns :data:`MS_SUCCESS` or :data:`MS_FAILURE`
int setExpression(char *expression)
{
if (!expression || strlen(expression) == 0) {
msFreeExpression(&self->expression);
return MS_SUCCESS;
}
else return msLoadExpressionString(&self->expression, expression);
}
%newobject getExpressionString;
/// Return a string representation of the :ref:`EXPRESSION <mapfile-class-expression>` enclosed in
/// the quote characters appropriate to the expression type
char *getExpressionString() {
return msGetExpressionString(&(self->expression));
}
/// Set :ref:`TEXT <mapfile-class-text>` string where `text` is a MapServer text expression.
/// Returns :data:`MS_SUCCESS` or :data:`MS_FAILURE`
int setText(char *text) {
if (!text || strlen(text) == 0) {
msFreeExpression(&self->text);
return MS_SUCCESS;
}
else return msLoadExpressionString(&self->text, text);
}
%newobject getTextString;
/// Return a string representation of :ref:`TEXT <mapfile-class-text>`
char *getTextString() {
return msGetExpressionString(&(self->text));
}
/// Draw the legend icon onto *image* at *dstx*, *dsty*. Returns :data:`MS_SUCCESS` or :data:`MS_FAILURE`
int drawLegendIcon(mapObj *map, layerObj *layer, int width, int height, imageObj *dstImage, int dstX, int dstY) {
if(layer->sizeunits != MS_PIXELS) {
map->cellsize = msAdjustExtent(&(map->extent), map->width, map->height);
layer->scalefactor = (msInchesPerUnit(layer->sizeunits,0)/msInchesPerUnit(map->units,0)) / map->cellsize;
}
else
layer->scalefactor = map->resolution/map->defresolution;
return msDrawLegendIcon(map, layer, self, width, height, dstImage, dstX, dstY, MS_TRUE, NULL);
}
%newobject createLegendIcon;
/// Draw and return a new legend icon
imageObj *createLegendIcon(mapObj *map, layerObj *layer, int width, int height) {
return msCreateLegendIcon(map, layer, self, width, height, MS_TRUE);
}
%newobject getLabel;
/// Return a reference to the :class:`labelObj` at *index* in the labels array
labelObj *getLabel(int i) {
if (i >= 0 && i < self->numlabels) {
MS_REFCNT_INCR(self->labels[i]);
return self->labels[i];
} else {
msSetError(MS_CHILDERR, "Invalid index: %d.", "getLabel()", i);
return NULL;
}
}
#ifdef SWIGCSHARP
%apply SWIGTYPE *SETREFERENCE {labelObj *label};
#endif
/// Add a :class:`labelObj` to the :class:`classObj` and return its index in the labels array
int addLabel(labelObj *label) {
return msAddLabelToClass(self, label);
}
#ifdef SWIGCSHARP
%clear labelObj *label;
#endif
%newobject removeLabel;
/// Remove the :class:`labelObj` at *index* from the labels array and return a
/// reference to the :class:`labelObj`. numlabels is decremented, and the array is updated
labelObj *removeLabel(int index) {
labelObj* label = (labelObj *) msRemoveLabelFromClass(self, index);
if (label) MS_REFCNT_INCR(label);
return label;
}
// See https://github.com/mapserver/mapserver/issues/548 for more details about the Style methods
%newobject getStyle;
/// Return a reference to the :class:`styleObj` at *index* in the styles array
styleObj *getStyle(int i) {
if (i >= 0 && i < self->numstyles) {
MS_REFCNT_INCR(self->styles[i]);
return self->styles[i];
} else {
msSetError(MS_CHILDERR, "Invalid index: %d", "getStyle()", i);
return NULL;
}
}
#ifdef SWIGCSHARP
%apply SWIGTYPE *SETREFERENCE {styleObj *style};
#endif
/// Insert a **copy** of *style* into the styles array at index *index*
/// Default is -1, or the end of the array. Returns the index at which the style was inserted.
int insertStyle(styleObj *style, int index=-1) {
return msInsertStyle(self, style, index);
}
#ifdef SWIGCSHARP
%clear styleObj *style;
#endif
%newobject removeStyle;
/// Remove the :class:`styleObj` at *index* from the styles array and return a copy.
styleObj *removeStyle(int index) {
styleObj* style = (styleObj *) msRemoveStyle(self, index);
if (style) MS_REFCNT_INCR(style);
return style;
}
/// Swap the :class:`styleObj` at *index* with the styleObj at *index* - 1
int moveStyleUp(int index) {
return msMoveStyleUp(self, index);
}
/// Swap the :class:`styleObj` at *index* with the :class:`styleObj` at *index* + 1
int moveStyleDown(int index) {
return msMoveStyleDown(self, index);
}
}