1
0
forked from pool/mapserver
mapserver/5461.patch

8837 lines
312 KiB
Diff
Raw Normal View History

From 9dbfe1b23d9c9529c9c980bd3de79dbf2033f388 Mon Sep 17 00:00:00 2001
From: bjoernboldt <mapscript@pixaweb.net>
Date: Mon, 3 Jul 2017 09:32:20 +0200
Subject: [PATCH 1/5] Add PHP7.x-support
---
mapscript/php/class.c | 184 +++++++++++-----
mapscript/php/cluster.c | 81 +++++--
mapscript/php/color.c | 68 +++++-
mapscript/php/error.c | 96 ++++++--
mapscript/php/grid.c | 82 ++++++-
mapscript/php/hashtable.c | 73 ++++++-
mapscript/php/image.c | 67 +++++-
mapscript/php/label.c | 141 +++++++++---
mapscript/php/labelcache.c | 56 ++++-
mapscript/php/labelcachemember.c | 104 +++++++--
mapscript/php/labelleader.c | 58 ++++-
mapscript/php/layer.c | 438 ++++++++++++++++++++++++-------------
mapscript/php/legend.c | 76 ++++++-
mapscript/php/line.c | 101 +++++++--
mapscript/php/map.c | 378 +++++++++++++++++++++-----------
mapscript/php/mapscript_error.c | 13 ++
mapscript/php/outputformat.c | 81 ++++++-
mapscript/php/owsrequest.c | 174 ++++++++++++---
mapscript/php/php_mapscript.c | 80 +++++--
mapscript/php/php_mapscript.h | 326 ++++++++++++++++++++++++++-
mapscript/php/php_mapscript_util.c | 77 ++++---
mapscript/php/php_mapscript_util.h | 89 +++++++-
mapscript/php/point.c | 121 ++++++++--
mapscript/php/projection.c | 83 ++++++-
mapscript/php/querymap.c | 73 ++++++-
mapscript/php/rect.c | 108 +++++++--
mapscript/php/referencemap.c | 75 ++++++-
mapscript/php/result.c | 59 ++++-
mapscript/php/scalebar.c | 81 ++++++-
mapscript/php/shape.c | 199 +++++++++++------
mapscript/php/shapefile.c | 79 +++++--
mapscript/php/style.c | 158 +++++++++----
mapscript/php/symbol.c | 92 ++++++--
mapscript/php/web.c | 75 ++++++-
34 files changed, 3259 insertions(+), 787 deletions(-)
diff --git a/mapscript/php/class.c b/mapscript/php/class.c
index 48f2f812a..a256ac9bd 100644
--- a/mapscript/php/class.c
+++ b/mapscript/php/class.c
@@ -143,10 +143,10 @@ PHP_METHOD(classObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if (zclass)
- php_class2 = (php_class_object *) zend_object_store_get_object(zclass TSRMLS_CC);
+ php_class2 = MAPSCRIPT_OBJ_P(php_class_object, zclass);
if ((class = classObj_new(php_layer->layer, (zclass ? php_class2->class:NULL))) == NULL) {
@@ -177,7 +177,7 @@ PHP_METHOD(classObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
IF_GET_STRING("name", php_class->class->name)
else IF_GET_STRING("title", php_class->class->title)
@@ -213,7 +213,7 @@ PHP_METHOD(classObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
/* special case for "template" which we want to set to NULL and not an empty string */
if(Z_TYPE_P(value)==IS_NULL && !strcmp(property,"template")) {
@@ -258,8 +258,8 @@ PHP_METHOD(classObj, addLabel)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_label = (php_label_object *) zend_object_store_get_object(zlabel TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zlabel);
status = classObj_addLabel(php_class->class, php_label->label);
php_label->is_ref = 1;
@@ -287,7 +287,7 @@ PHP_METHOD(classObj, removeLabel)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
if ((label = classObj_removeLabel(php_class->class, index)) == NULL) {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -318,7 +318,7 @@ PHP_METHOD(classObj, getLabel)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
if ((label = classObj_getLabel(php_class->class, index)) == NULL) {
mapscript_throw_exception("Invalid label index." TSRMLS_CC);
@@ -349,7 +349,7 @@ PHP_METHOD(classObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
status = classObj_updateFromString(php_class->class, snippet);
@@ -378,14 +378,14 @@ PHP_METHOD(classObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
value = classObj_convertToString(php_class->class);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -408,7 +408,7 @@ PHP_METHOD(classObj, setExpression)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
status = classObj_setExpression(php_class->class, expression);
@@ -437,14 +437,14 @@ PHP_METHOD(classObj, getExpressionString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
value = classObj_getExpressionString(php_class->class);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -468,8 +468,8 @@ PHP_METHOD(classObj, setText)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(php_class->parent.val TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_class->parent.val);
status = classObj_setText(php_class->class, php_layer->layer, text);
@@ -498,14 +498,14 @@ PHP_METHOD(classObj, getTextString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
value = classObj_getTextString(php_class->class);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -528,7 +528,7 @@ PHP_METHOD(classObj, getStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
if (index < 0 || index >= php_class->class->numstyles) {
mapscript_throw_exception("Invalid style index." TSRMLS_CC);
@@ -560,8 +560,8 @@ PHP_METHOD(classObj, insertStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_style = (php_style_object *) zend_object_store_get_object(zstyle TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zstyle);
RETURN_LONG(msInsertStyle(php_class->class, php_style->style, index));
}
@@ -585,7 +585,7 @@ PHP_METHOD(classObj, removeStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
style = msRemoveStyle(php_class->class, index);
@@ -615,7 +615,7 @@ PHP_METHOD(classObj, moveStyleUp)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
status = classObj_moveStyleUp(php_class->class, index);
@@ -643,7 +643,7 @@ PHP_METHOD(classObj, moveStyleDown)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
status = classObj_moveStyleDown(php_class->class, index);
@@ -669,7 +669,7 @@ PHP_METHOD(classObj, deleteStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
status = classObj_deleteStyle(php_class->class, index);
@@ -684,7 +684,7 @@ PHP_METHOD(classObj, getMetaData)
zval *zname;
zval *zobj = getThis();
php_class_object *php_class;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -694,12 +694,15 @@ PHP_METHOD(classObj, getMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_class->metadata, &php_class->class->metadata);
-
MAPSCRIPT_CALL_METHOD_1(php_class->metadata, "get", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_STRING(Z_STRVAL_P(retval),1);
+#else
+ RETURN_STRING(Z_STRVAL(retval));
+#endif
}
/* }}} */
@@ -710,7 +713,7 @@ PHP_METHOD(classObj, setMetaData)
zval *zname, *zvalue;
zval *zobj = getThis();
php_class_object *php_class;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz",
@@ -720,12 +723,16 @@ PHP_METHOD(classObj, setMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_class->metadata, &php_class->class->metadata);
MAPSCRIPT_CALL_METHOD_2(php_class->metadata, "set", retval, zname, zvalue);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -736,7 +743,7 @@ PHP_METHOD(classObj, removeMetaData)
zval *zname;
zval *zobj = getThis();
php_class_object *php_class;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -746,12 +753,16 @@ PHP_METHOD(classObj, removeMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_class->metadata, &php_class->class->metadata);
MAPSCRIPT_CALL_METHOD_1(php_class->metadata, "remove", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -774,15 +785,15 @@ PHP_METHOD(classObj, createLegendIcon)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(php_class->parent.val TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_class->parent.val);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this class object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((image = classObj_createLegendIcon(php_class->class,
php_map->map,
@@ -820,17 +831,17 @@ PHP_METHOD(classObj, drawLegendIcon)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(php_class->parent.val TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_class->parent.val);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this class object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if (!MS_RENDERER_PLUGIN(php_image->image->format)) {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -865,7 +876,7 @@ PHP_METHOD(classObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zobj);
MAPSCRIPT_DELREF(php_class->metadata);
}
@@ -905,13 +916,87 @@ void mapscript_create_class(classObj *class, parent_object parent, zval *return_
{
php_class_object * php_class;
object_init_ex(return_value, mapscript_ce_class);
- php_class = (php_class_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, return_value);
php_class->class = class;
php_class->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_class_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_class_object *php_class;
+
+ php_class = ecalloc(1, sizeof(*php_class) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_class->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_class->zobj, ce);
+
+ php_class->zobj.handlers = &mapscript_class_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_class->parent);
+ ZVAL_UNDEF(&php_class->metadata);
+ ZVAL_UNDEF(&php_class->leader);
+
+ return &php_class->zobj;
+}
+
+static void mapscript_class_free_object(zend_object *object)
+{
+ php_class_object *php_class;
+
+ php_class = (php_class_object *)((char *)object - XtOffsetOf(php_class_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_class->parent);
+
+ MAPSCRIPT_DELREF(php_class->metadata);
+ MAPSCRIPT_DELREF(php_class->leader);
+
+ /* We don't need to free the classObj */
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_class_clone_object(zval *zobj)
+{
+ php_class_object *php_class_old, *php_class_new;
+ php_layer_object *php_layer;
+ zend_object* zobj_new;
+
+ php_class_old = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_class_old->parent.val);
+
+ zobj_new = mapscript_class_create_object(mapscript_ce_class);
+ php_class_new = (php_class_object *)((char *)zobj_new - XtOffsetOf(php_class_object, zobj));
+
+ zend_objects_clone_members(&php_class_new->zobj, &php_class_old->zobj);
+
+ php_class_new->class = classObj_clone(php_class_old->class, php_layer->layer);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(class)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "classObj", class_functions);
+ mapscript_ce_class = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_class->create_object = mapscript_class_create_object;
+ mapscript_ce_class->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_class_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_class_object_handlers));
+ mapscript_class_object_handlers.free_obj = mapscript_class_free_object;
+ mapscript_class_object_handlers.clone_obj = mapscript_class_clone_object;
+ mapscript_class_object_handlers.offset = XtOffsetOf(php_class_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_class_object_destroy(void *object TSRMLS_DC)
{
php_class_object *php_class = (php_class_object *)object;
@@ -961,8 +1046,8 @@ static zend_object_value mapscript_class_object_clone(zval *zobj TSRMLS_DC)
php_layer_object *php_layer;
zend_object_value new_ov;
- php_class_old = (php_class_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(php_class_old->parent.val TSRMLS_CC);
+ php_class_old = MAPSCRIPT_OBJ_P(php_class_object, zobj);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, php_class_old->parent.val);
new_ov = mapscript_class_object_new_ex(mapscript_ce_class, &php_class_new TSRMLS_CC);
zend_objects_clone_members(&php_class_new->std, new_ov, &php_class_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -988,3 +1073,4 @@ PHP_MINIT_FUNCTION(class)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/cluster.c b/mapscript/php/cluster.c
index 1031c020a..48dce8ae4 100644
--- a/mapscript/php/cluster.c
+++ b/mapscript/php/cluster.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_cluster;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_cluster_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(cluster___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -78,7 +81,7 @@ PHP_METHOD(clusterObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
IF_GET_DOUBLE("maxdistance", php_cluster->cluster->maxdistance)
else IF_GET_DOUBLE("buffer", php_cluster->cluster->buffer)
@@ -104,7 +107,7 @@ PHP_METHOD(clusterObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
IF_SET_DOUBLE("maxdistance", php_cluster->cluster->maxdistance, value)
else IF_SET_DOUBLE("buffer", php_cluster->cluster->buffer, value)
@@ -132,7 +135,7 @@ PHP_METHOD(clusterObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
status = clusterObj_updateFromString(php_cluster->cluster, snippet);
@@ -161,14 +164,14 @@ PHP_METHOD(clusterObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
value = clusterObj_convertToString(php_cluster->cluster);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -191,7 +194,7 @@ PHP_METHOD(clusterObj, setGroup)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
if ((status = clusterObj_setGroup(php_cluster->cluster, group)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -217,14 +220,14 @@ PHP_METHOD(clusterObj, getGroupString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
value = clusterObj_getGroupString(php_cluster->cluster);
if (value == NULL) {
RETURN_NULL();
}
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -247,7 +250,7 @@ PHP_METHOD(clusterObj, setFilter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
if ((status = clusterObj_setFilter(php_cluster->cluster, filter)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -273,14 +276,14 @@ PHP_METHOD(clusterObj, getFilterString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_cluster = (php_cluster_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, zobj);
value = clusterObj_getFilterString(php_cluster->cluster);
if (value == NULL) {
RETURN_NULL();
}
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -304,16 +307,65 @@ void mapscript_create_cluster(clusterObj *cluster, parent_object parent, zval *r
{
php_cluster_object * php_cluster;
object_init_ex(return_value, mapscript_ce_cluster);
- php_cluster = (php_cluster_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_cluster = MAPSCRIPT_OBJ_P(php_cluster_object, return_value);
php_cluster->cluster = cluster;
- if (parent.val)
+ if (ZVAL_NOT_UNDEF(parent.val))
php_cluster->is_ref = 1;
php_cluster->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_cluster_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_cluster_object *php_cluster;
+
+ php_cluster = ecalloc(1, sizeof(*php_cluster) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_cluster->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_cluster->zobj, ce);
+
+ php_cluster->zobj.handlers = &mapscript_cluster_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_cluster->parent);
+
+ return &php_cluster->zobj;
+}
+
+static void mapscript_cluster_free_object(zend_object *object)
+{
+ php_cluster_object *php_cluster;
+
+ php_cluster = (php_cluster_object *)((char *)object - XtOffsetOf(php_cluster_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_cluster->parent);
+
+ /* We don't need to free the clusterObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(cluster)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "clusterObj", cluster_functions);
+ mapscript_ce_cluster = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_cluster->create_object = mapscript_cluster_create_object;
+ mapscript_ce_cluster->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_cluster_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_cluster_object_handlers));
+ mapscript_cluster_object_handlers.free_obj = mapscript_cluster_free_object;
+ mapscript_cluster_object_handlers.offset = XtOffsetOf(php_cluster_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_cluster_object_destroy(void *object TSRMLS_DC)
{
php_cluster_object *php_cluster = (php_cluster_object *)object;
@@ -356,3 +408,4 @@ PHP_MINIT_FUNCTION(cluster)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/color.c b/mapscript/php/color.c
index bc86f3b35..559ef5eb0 100644
--- a/mapscript/php/color.c
+++ b/mapscript/php/color.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_color;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_color_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(color___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -79,7 +82,7 @@ PHP_METHOD(colorObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_color = (php_color_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, zobj);
IF_GET_LONG("red", php_color->color->red)
else IF_GET_LONG("green", php_color->color->green)
@@ -106,7 +109,7 @@ PHP_METHOD(colorObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_color = (php_color_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, zobj);
IF_SET_COLOR("red", php_color->color->red, value)
else IF_SET_COLOR("green", php_color->color->green, value)
@@ -134,7 +137,7 @@ PHP_METHOD(colorObj, setRGB)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_color = (php_color_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, zobj);
MS_INIT_COLOR(*(php_color->color), red, green, blue, alpha);
@@ -173,7 +176,7 @@ PHP_METHOD(colorObj, setHex)
RETURN_LONG(MS_FAILURE);
}
- php_color = (php_color_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, zobj);
MS_INIT_COLOR(*(php_color->color), red, green, blue, alpha);
@@ -194,7 +197,7 @@ PHP_METHOD(colorObj, toHex)
php_color_object *php_color;
colorObj *color;
- php_color = (php_color_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, zobj);
color = php_color->color;
if (color->red < 0 || color->green < 0 || color->blue < 0) {
@@ -215,7 +218,7 @@ PHP_METHOD(colorObj, toHex)
return;
}
- RETURN_STRINGL(hex, strlen(hex), 0);
+ MAPSCRIPT_RETURN_STRINGL(hex, strlen(hex), 0);
}
/* }}} */
@@ -235,7 +238,7 @@ void mapscript_create_color(colorObj *color, parent_object parent, zval *return_
{
php_color_object * php_color;
object_init_ex(return_value, mapscript_ce_color);
- php_color = (php_color_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_color = MAPSCRIPT_OBJ_P(php_color_object, return_value);
php_color->color = color;
php_color->parent = parent;
@@ -243,6 +246,55 @@ void mapscript_create_color(colorObj *color, parent_object parent, zval *return_
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_color_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_color_object *php_color;
+
+ php_color = ecalloc(1, sizeof(*php_color) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_color->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_color->zobj, ce);
+
+ php_color->zobj.handlers = &mapscript_color_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_color->parent);
+
+ return &php_color->zobj;
+}
+
+static void mapscript_color_free_object(zend_object *object)
+{
+ php_color_object *php_color;
+
+ php_color = (php_color_object *)((char *)object - XtOffsetOf(php_color_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_color->parent);
+
+ /* We don't need to free the colorObj, the mapObj will do it */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(color)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "colorObj", color_functions);
+ mapscript_ce_color = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_color->create_object = mapscript_color_create_object;
+ mapscript_ce_color->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_color_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_color_object_handlers));
+ mapscript_color_object_handlers.free_obj = mapscript_color_free_object;
+ mapscript_color_object_handlers.offset = XtOffsetOf(php_color_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_color_object_destroy(void *object TSRMLS_DC)
{
php_color_object *php_color = (php_color_object *)object;
@@ -284,4 +336,4 @@ PHP_MINIT_FUNCTION(color)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/error.c b/mapscript/php/error.c
index 2e96eea27..881295ef4 100644
--- a/mapscript/php/error.c
+++ b/mapscript/php/error.c
@@ -31,7 +31,7 @@
#include "php_mapscript.h"
-#if PHP_VERSION_ID >= 50625
+#if PHP_VERSION_ID >= 50625 && PHP_VERSION_ID < 70000
#undef ZVAL_STRING
#define ZVAL_STRING(z, s, duplicate) do { \
const char *__s=(s); \
@@ -43,6 +43,9 @@
#endif
zend_class_entry *mapscript_ce_error;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_error_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(error___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -66,7 +69,8 @@ PHP_METHOD(errorObj, __get)
char *property;
long property_len = 0;
zval *zobj = getThis();
- php_error_object *php_error;
+ /* php_error is in PHP7 defined in php.h, so we use php_errobj instead */
+ php_error_object *php_errobj;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s",
@@ -76,12 +80,12 @@ PHP_METHOD(errorObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_error = (php_error_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_errobj = MAPSCRIPT_OBJ_P(php_error_object, zobj);
- IF_GET_LONG("code", php_error->error->code)
- else IF_GET_STRING("routine", php_error->error->routine)
- else IF_GET_STRING("message", php_error->error->message)
- else IF_GET_LONG("isreported", php_error->error->isreported)
+ IF_GET_LONG("code", php_errobj->error->code)
+ else IF_GET_STRING("routine", php_errobj->error->routine)
+ else IF_GET_STRING("message", php_errobj->error->message)
+ else IF_GET_LONG("isreported", php_errobj->error->isreported)
else {
mapscript_throw_exception("Property '%s' does not exist in this object." TSRMLS_CC, property);
}
@@ -92,8 +96,8 @@ PHP_METHOD(errorObj, __set)
char *property;
long property_len = 0;
zval *value;
- zval *zobj = getThis();
- php_error_object *php_error;
+ /* zval *zobj = getThis(); */
+ /* php_error_object *php_errobj; */
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "sz",
@@ -103,7 +107,7 @@ PHP_METHOD(errorObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_error = (php_error_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ /* php_errobj = MAPSCRIPT_OBJ_P(php_error_object, zobj); */
if ( (STRING_EQUAL("code", property)) ||
(STRING_EQUAL("routine", property)) ||
@@ -120,7 +124,7 @@ PHP_METHOD(errorObj, __set)
PHP_METHOD(errorObj, next)
{
zval *zobj = getThis();
- php_error_object *php_error;
+ php_error_object *php_errobj;
errorObj *error = NULL;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
@@ -130,15 +134,15 @@ PHP_METHOD(errorObj, next)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_error = (php_error_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_errobj = MAPSCRIPT_OBJ_P(php_error_object, zobj);
- if (php_error->error->next == NULL)
+ if (php_errobj->error->next == NULL)
RETURN_NULL();
/* Make sure 'self' is still valid. It may have been deleted by
* msResetErrorList() */
error = msGetErrorObj();
- while(error != php_error->error) {
+ while(error != php_errobj->error) {
if (error->next == NULL) {
mapscript_throw_exception("Trying to access an errorObj that has expired." TSRMLS_CC);
return;
@@ -146,7 +150,7 @@ PHP_METHOD(errorObj, next)
error = error->next;
}
- php_error->error = php_error->error->next;
+ php_errobj->error = php_errobj->error->next;
*return_value = *zobj;
zval_copy_ctor(return_value);
INIT_PZVAL(return_value);
@@ -164,17 +168,62 @@ zend_function_entry error_functions[] = {
void mapscript_create_error(errorObj *error, zval *return_value TSRMLS_DC)
{
- php_error_object * php_error;
+ php_error_object * php_errobj;
object_init_ex(return_value, mapscript_ce_error);
- php_error = (php_error_object *)zend_object_store_get_object(return_value TSRMLS_CC);
- php_error->error = error;
+ php_errobj = MAPSCRIPT_OBJ_P(php_error_object, return_value);
+ php_errobj->error = error;
+}
+
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_error_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_error_object *php_errobj;
+
+ php_errobj = ecalloc(1, sizeof(*php_errobj) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_errobj->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_errobj->zobj, ce);
+
+ php_errobj->zobj.handlers = &mapscript_error_object_handlers;
+
+ return &php_errobj->zobj;
}
+/*
+static void mapscript_error_free_object(zend_object *object)
+{
+ php_error_object *php_errobj;
+
+ php_errobj = (php_error_object *)((char *)object - XtOffsetOf(php_error_object, zobj));
+
+ zend_object_std_dtor(object);
+}
+*/
+
+PHP_MINIT_FUNCTION(error)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "errorObj", error_functions);
+ mapscript_ce_error = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_error->create_object = mapscript_error_create_object;
+ mapscript_ce_error->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_error_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_error_object_handlers));
+ /* mapscript_error_object_handlers.free_obj = mapscript_error_free_object; // nothing to do here -> use standard handler */
+ mapscript_error_object_handlers.offset = XtOffsetOf(php_error_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_error_object_destroy(void *object TSRMLS_DC)
{
- php_error_object *php_error = (php_error_object *)object;
+ php_error_object *php_errobj = (php_error_object *)object;
- MAPSCRIPT_FREE_OBJECT(php_error);
+ MAPSCRIPT_FREE_OBJECT(php_errobj);
/* We don't need to free the errorObj */
@@ -184,11 +233,11 @@ static void mapscript_error_object_destroy(void *object TSRMLS_DC)
static zend_object_value mapscript_error_object_new(zend_class_entry *ce TSRMLS_DC)
{
zend_object_value retval;
- php_error_object *php_error;
+ php_error_object *php_errobj;
- MAPSCRIPT_ALLOC_OBJECT(php_error, php_error_object);
+ MAPSCRIPT_ALLOC_OBJECT(php_errobj, php_error_object);
- retval = mapscript_object_new(&php_error->std, ce,
+ retval = mapscript_object_new(&php_errobj->std, ce,
&mapscript_error_object_destroy TSRMLS_CC);
return retval;
@@ -207,3 +256,4 @@ PHP_MINIT_FUNCTION(error)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/grid.c b/mapscript/php/grid.c
index 977b7600d..c13f54bc3 100644
--- a/mapscript/php/grid.c
+++ b/mapscript/php/grid.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_grid;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_grid_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(grid___construct_args, 0, 1, 1)
ZEND_ARG_OBJ_INFO(0, layer, layerObj, 0)
@@ -63,8 +66,8 @@ PHP_METHOD(gridObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_grid = (php_grid_object *) zend_object_store_get_object(getThis() TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_grid = MAPSCRIPT_OBJ_P(php_grid_object, getThis());
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
php_layer->layer->connectiontype = MS_GRATICULE;
@@ -78,17 +81,30 @@ PHP_METHOD(gridObj, __construct)
php_grid->grid = (graticuleObj *)php_layer->layer->layerinfo;
- if (php_layer->grid && (Z_TYPE_P(php_layer->grid) == IS_OBJECT)) {
- php_old_grid = (php_grid_object *) zend_object_store_get_object(php_layer->grid TSRMLS_CC);
+ if (ZVAL_NOT_UNDEF(php_layer->grid) && (MAPSCRIPT_TYPE(php_layer->grid) == IS_OBJECT)) {
+ php_old_grid = MAPSCRIPT_OBJ(php_grid_object, php_layer->grid);
php_old_grid->parent.child_ptr = NULL;
+#if PHP_VERSION_ID < 70000
zend_objects_store_del_ref(php_layer->grid TSRMLS_CC);
+#else
+/*
+ Z_SET_REFCOUNT(php_layer->grid, 0);
+ _zval_dtor_func_for_ptr(Z_COUNTED(php_layer->grid));
+ Z_UNDEF(&php_layer->grid);
+*/
+ MAPSCRIPT_DELREF(php_layer->grid);
+#endif
}
MAKE_STD_ZVAL(php_layer->grid);
MAPSCRIPT_MAKE_PARENT(zlayer, &php_layer->grid);
+#if PHP_VERSION_ID < 70000
mapscript_create_grid((graticuleObj *)(php_layer->layer->layerinfo), parent, php_layer->grid TSRMLS_CC);
-
return_value_ptr = &php_layer->grid;
+#else
+ mapscript_create_grid((graticuleObj *)(php_layer->layer->layerinfo), parent, &php_layer->grid TSRMLS_CC);
+ return_value = &php_layer->grid;
+#endif
}
/* }}} */
@@ -107,7 +123,7 @@ PHP_METHOD(gridObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_grid = (php_grid_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_grid = MAPSCRIPT_OBJ_P(php_grid_object, zobj);
IF_GET_DOUBLE("minsubdivide", php_grid->grid->minsubdivides)
else IF_GET_DOUBLE("maxsubdivide", php_grid->grid->maxsubdivides)
@@ -137,7 +153,7 @@ PHP_METHOD(gridObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_grid = (php_grid_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_grid = MAPSCRIPT_OBJ_P(php_grid_object, zobj);
IF_SET_DOUBLE("minsubdivide", php_grid->grid->minsubdivides, value)
else IF_SET_DOUBLE("maxsubdivide", php_grid->grid->maxsubdivides, value)
@@ -160,11 +176,60 @@ zend_function_entry grid_functions[] = {
}
};
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_grid_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_grid_object *php_grid;
+
+ php_grid = ecalloc(1, sizeof(*php_grid) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_grid->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_grid->zobj, ce);
+
+ php_grid->zobj.handlers = &mapscript_grid_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_grid->parent);
+
+ return &php_grid->zobj;
+}
+
+static void mapscript_grid_free_object(zend_object *object)
+{
+ php_grid_object *php_grid;
+
+ php_grid = (php_grid_object *)((char *)object - XtOffsetOf(php_grid_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_grid->parent);
+
+ /* We don't need to free the gridObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(grid)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "gridObj", grid_functions);
+ mapscript_ce_grid = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_grid->create_object = mapscript_grid_create_object;
+ mapscript_ce_grid->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_grid_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_grid_object_handlers));
+ mapscript_grid_object_handlers.free_obj = mapscript_grid_free_object;
+ mapscript_grid_object_handlers.offset = XtOffsetOf(php_grid_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
void mapscript_create_grid(graticuleObj *grid, parent_object parent, zval *return_value TSRMLS_DC)
{
php_grid_object * php_grid;
object_init_ex(return_value, mapscript_ce_grid);
- php_grid = (php_grid_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_grid = MAPSCRIPT_OBJ_P(php_grid_object, return_value);
php_grid->grid = grid;
php_grid->parent = parent;
@@ -212,3 +277,4 @@ PHP_MINIT_FUNCTION(grid)
return SUCCESS;
}
+#endif
\ No newline at end of file
diff --git a/mapscript/php/hashtable.c b/mapscript/php/hashtable.c
index 44f56805f..3e6c0c783 100644
--- a/mapscript/php/hashtable.c
+++ b/mapscript/php/hashtable.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_hashtable;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_hashtable_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(hashtable___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -82,7 +85,7 @@ PHP_METHOD(hashtableObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
IF_GET_LONG("numitems", php_hashtable->hashtable->numitems)
else {
@@ -129,14 +132,14 @@ PHP_METHOD(hashtableObj, get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
value = hashTableObj_get(php_hashtable->hashtable, key);
if (value == NULL) {
- RETURN_STRING("",1);
+ MAPSCRIPT_RETURN_STRING("",1);
}
- RETURN_STRING((char *)value, 1);
+ MAPSCRIPT_RETURN_STRING((char *)value, 1);
}
/* }}} */
@@ -158,7 +161,7 @@ PHP_METHOD(hashtableObj, set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
if ((status = hashTableObj_set(php_hashtable->hashtable, key, value)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -187,7 +190,7 @@ PHP_METHOD(hashtableObj, remove)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
if ((status = hashTableObj_remove(php_hashtable->hashtable, key)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -212,7 +215,7 @@ PHP_METHOD(hashtableObj, clear)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
hashTableObj_clear(php_hashtable->hashtable);
}
@@ -237,14 +240,14 @@ PHP_METHOD(hashtableObj, nextKey)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_hashtable = (php_hashtable_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, zobj);
value = hashTableObj_nextKey(php_hashtable->hashtable, key);
if (value == NULL)
RETURN_NULL();
- RETURN_STRING(value, 1);
+ MAPSCRIPT_RETURN_STRING(value, 1);
}
/* }}} */
@@ -265,7 +268,7 @@ void mapscript_create_hashtable(hashTableObj *hashtable, parent_object parent, z
{
php_hashtable_object * php_hashtable;
object_init_ex(return_value, mapscript_ce_hashtable);
- php_hashtable = (php_hashtable_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_hashtable = MAPSCRIPT_OBJ_P(php_hashtable_object, return_value);
php_hashtable->hashtable = hashtable;
php_hashtable->parent = parent;
@@ -273,6 +276,55 @@ void mapscript_create_hashtable(hashTableObj *hashtable, parent_object parent, z
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_hashtable_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_hashtable_object *php_hashtable;
+
+ php_hashtable = ecalloc(1, sizeof(*php_hashtable) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_hashtable->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_hashtable->zobj, ce);
+
+ php_hashtable->zobj.handlers = &mapscript_hashtable_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_hashtable->parent);
+
+ return &php_hashtable->zobj;
+}
+
+static void mapscript_hashtable_free_object(zend_object *object)
+{
+ php_hashtable_object *php_hashtable;
+
+ php_hashtable = (php_hashtable_object *)((char *)object - XtOffsetOf(php_hashtable_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_hashtable->parent);
+
+ /* We don't need to free the hashTableObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(hashtable)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "hashTableObj", hashtable_functions);
+ mapscript_ce_hashtable = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_hashtable->create_object = mapscript_hashtable_create_object;
+ mapscript_ce_hashtable->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_hashtable_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_hashtable_object_handlers));
+ mapscript_hashtable_object_handlers.free_obj = mapscript_hashtable_free_object;
+ mapscript_hashtable_object_handlers.offset = XtOffsetOf(php_hashtable_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_hashtable_object_destroy(void *object TSRMLS_DC)
{
php_hashtable_object *php_hashtable = (php_hashtable_object *)object;
@@ -314,3 +366,4 @@ PHP_MINIT_FUNCTION(hashtable)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/image.c b/mapscript/php/image.c
index f284e5936..719208866 100644
--- a/mapscript/php/image.c
+++ b/mapscript/php/image.c
@@ -34,6 +34,9 @@
#include "main/php_output.h"
zend_class_entry *mapscript_ce_image;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_image_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(image___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -81,7 +84,7 @@ PHP_METHOD(imageObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_image = (php_image_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zobj);
IF_GET_LONG("width", php_image->image->width)
else IF_GET_LONG("height", php_image->image->height)
@@ -111,7 +114,7 @@ PHP_METHOD(imageObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_image = (php_image_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zobj);
IF_SET_STRING("imagepath", php_image->image->imagepath, value)
else IF_SET_STRING("imageurl", php_image->image->imageurl, value)
@@ -144,7 +147,7 @@ PHP_METHOD(imageObj, saveWebImage)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_image = (php_image_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zobj);
imageFilename = msTmpFilename(php_image->image->format->extension);
imageFile = msBuildPath(path, php_image->image->imagepath, imageFilename);
@@ -157,7 +160,7 @@ PHP_METHOD(imageObj, saveWebImage)
imageUrlFull = msBuildPath(path, php_image->image->imageurl, imageFilename);
msFree(imageFilename);
- RETURN_STRING(imageUrlFull, 1);
+ MAPSCRIPT_RETURN_STRING(imageUrlFull, 1);
}
/* }}} */
@@ -194,8 +197,8 @@ PHP_METHOD(imageObj, pasteImage)
if (ZEND_NUM_ARGS() == 3)
mapscript_report_php_error(E_WARNING, "dstX parameter given but not dstY" TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_imageSrc = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zobj);
+ php_imageSrc = MAPSCRIPT_OBJ_P(php_image_object, zimage);
if (!MS_RENDERER_PLUGIN(php_imageSrc->image->format) ||
!MS_RENDERER_PLUGIN(php_image->image->format)) {
@@ -274,9 +277,9 @@ PHP_METHOD(imageObj, saveImage)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_image = (php_image_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zobj);
if (zmap)
- php_map = (php_map_object *) zend_object_store_get_object(zmap TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
if(filename_len > 0) {
if ((status = msSaveImage((zmap ? php_map->map:NULL), php_image->image, filename) != MS_SUCCESS)) {
@@ -339,10 +342,55 @@ void mapscript_create_image(imageObj *image, zval *return_value TSRMLS_DC)
{
php_image_object * php_image;
object_init_ex(return_value, mapscript_ce_image);
- php_image = (php_image_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, return_value);
php_image->image = image;
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_image_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_image_object *php_image;
+
+ php_image = ecalloc(1, sizeof(*php_image) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_image->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_image->zobj, ce);
+
+ php_image->zobj.handlers = &mapscript_image_object_handlers;
+
+ return &php_image->zobj;
+}
+
+static void mapscript_image_free_object(zend_object *object)
+{
+ php_image_object *php_image;
+
+ php_image = (php_image_object *)((char *)object - XtOffsetOf(php_image_object, zobj));
+
+ msFreeImage(php_image->image);
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(image)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "imageObj", image_functions);
+ mapscript_ce_image = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_image->create_object = mapscript_image_create_object;
+ mapscript_ce_image->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_image_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_image_object_handlers));
+ mapscript_image_object_handlers.free_obj = mapscript_image_free_object;
+ mapscript_image_object_handlers.offset = XtOffsetOf(php_image_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_image_object_destroy(void *object TSRMLS_DC)
{
php_image_object *php_image = (php_image_object *)object;
@@ -380,3 +428,4 @@ PHP_MINIT_FUNCTION(image)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/label.c b/mapscript/php/label.c
index 9fab6ec3e..214dfb19b 100644
--- a/mapscript/php/label.c
+++ b/mapscript/php/label.c
@@ -106,7 +106,7 @@ PHP_METHOD(labelObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, getThis());
if ((php_label->label = labelObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct labelObj." TSRMLS_CC);
@@ -130,7 +130,7 @@ PHP_METHOD(labelObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
IF_GET_STRING("font", php_label->label->font)
else IF_GET_STRING("encoding", php_label->label->encoding)
@@ -187,7 +187,7 @@ PHP_METHOD(labelObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
IF_SET_STRING("font", php_label->label->font, value)
else IF_SET_STRING("encoding", php_label->label->encoding, value)
@@ -248,7 +248,7 @@ PHP_METHOD(labelObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
if ((status = labelObj_updateFromString(php_label->label, snippet)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -274,14 +274,14 @@ PHP_METHOD(labelObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
value = labelObj_convertToString(php_label->label);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -304,7 +304,7 @@ PHP_METHOD(labelObj, setBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
if (bindingId < 0 || bindingId > MS_LABEL_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -347,7 +347,7 @@ PHP_METHOD(labelObj, getBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
if (bindingId < 0 || bindingId > MS_LABEL_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -355,7 +355,7 @@ PHP_METHOD(labelObj, getBinding)
}
if( (value = php_label->label->bindings[bindingId].item) != NULL) {
- RETURN_STRING(value, 1);
+ MAPSCRIPT_RETURN_STRING(value, 1);
}
RETURN_NULL();
@@ -379,7 +379,7 @@ PHP_METHOD(labelObj, removeBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
if (bindingId < 0 || bindingId > MS_LABEL_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -417,7 +417,7 @@ PHP_METHOD(labelObj, getStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
if (index < 0 || index >= php_label->label->numstyles) {
mapscript_throw_exception("Invalid style index." TSRMLS_CC);
@@ -449,8 +449,8 @@ PHP_METHOD(labelObj, insertStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_style = (php_style_object *) zend_object_store_get_object(zstyle TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zstyle);
RETURN_LONG(msInsertLabelStyle(php_label->label, php_style->style, index));
}
@@ -474,7 +474,7 @@ PHP_METHOD(labelObj, removeStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
style = msRemoveLabelStyle(php_label->label, index);
@@ -500,7 +500,7 @@ PHP_METHOD(labelObj, moveStyleUp)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
status = labelObj_moveStyleUp(php_label->label, index);
@@ -524,7 +524,7 @@ PHP_METHOD(labelObj, moveStyleDown)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
status = labelObj_moveStyleDown(php_label->label, index);
@@ -548,7 +548,7 @@ PHP_METHOD(labelObj, deleteStyle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
status = labelObj_deleteStyle(php_label->label, index);
@@ -570,7 +570,7 @@ PHP_METHOD(labelObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
MAPSCRIPT_DELREF(php_label->color);
MAPSCRIPT_DELREF(php_label->outlinecolor);
@@ -596,7 +596,7 @@ PHP_METHOD(labelObj, setExpression)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
status = labelObj_setExpression(php_label->label, expression);
@@ -625,14 +625,14 @@ PHP_METHOD(labelObj, getExpressionString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
value = labelObj_getExpressionString(php_label->label);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -656,8 +656,8 @@ PHP_METHOD(labelObj, setText)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(php_label->parent.val TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_label->parent.val);
status = labelObj_setText(php_label->label, php_layer->layer, text);
@@ -686,14 +686,14 @@ PHP_METHOD(labelObj, getTextString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_label = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zobj);
value = labelObj_getTextString(php_label->label);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -728,16 +728,93 @@ void mapscript_create_label(labelObj *label, parent_object parent, zval *return_
{
php_label_object * php_label;
object_init_ex(return_value, mapscript_ce_label);
- php_label = (php_label_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, return_value);
php_label->label = label;
- if (parent.val)
+ if(ZVAL_NOT_UNDEF(parent.val))
php_label->is_ref = 1;
php_label->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_label_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_label_object *php_label;
+
+ php_label = ecalloc(1, sizeof(*php_label) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_label->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_label->zobj, ce);
+
+ php_label->zobj.handlers = &mapscript_label_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_label->parent);
+ php_label->is_ref = 0;
+ ZVAL_UNDEF(&php_label->color);
+ ZVAL_UNDEF(&php_label->outlinecolor);
+ ZVAL_UNDEF(&php_label->shadowcolor);
+ ZVAL_UNDEF(&php_label->leader);
+
+
+ return &php_label->zobj;
+}
+
+static void mapscript_label_free_object(zend_object *object)
+{
+ php_label_object *php_label;
+
+ php_label = (php_label_object *)((char *)object - XtOffsetOf(php_label_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_label->parent);
+ MAPSCRIPT_DELREF(php_label->color);
+ MAPSCRIPT_DELREF(php_label->outlinecolor);
+ MAPSCRIPT_DELREF(php_label->shadowcolor);
+ MAPSCRIPT_DELREF(php_label->leader);
+
+ if (php_label->label && !php_label->is_ref) {
+ labelObj_destroy(php_label->label);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_label_clone_object(zval *zobj)
+{
+ php_label_object *php_label_old, *php_label_new;
+ zend_object* zobj_new;
+
+ php_label_old = MAPSCRIPT_OBJ_P(php_label_object, zobj);
+
+ zobj_new = mapscript_label_create_object(mapscript_ce_label);
+ php_label_new = (php_label_object *)((char *)zobj_new - XtOffsetOf(php_label_object, zobj));
+
+ php_label_new->label = labelObj_clone(php_label_old->label);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(label)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "labelObj", label_functions);
+ mapscript_ce_label = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_label->create_object = mapscript_label_create_object;
+ mapscript_ce_label->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_label_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_label_object_handlers));
+ mapscript_label_object_handlers.free_obj = mapscript_label_free_object;
+ mapscript_label_object_handlers.clone_obj = mapscript_label_clone_object;
+ mapscript_label_object_handlers.offset = XtOffsetOf(php_label_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_label_object_destroy(void *object TSRMLS_DC)
{
php_label_object *php_label = (php_label_object *)object;
@@ -791,7 +868,7 @@ static zend_object_value mapscript_label_object_clone(zval *zobj TSRMLS_DC)
php_label_object *php_label_old, *php_label_new;
zend_object_value new_ov;
- php_label_old = (php_label_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_label_old = MAPSCRIPT_OBJ_P(php_label_object, zobj);
new_ov = mapscript_label_object_new_ex(mapscript_ce_label, &php_label_new TSRMLS_CC);
zend_objects_clone_members(&php_label_new->std, new_ov, &php_label_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -817,4 +894,4 @@ PHP_MINIT_FUNCTION(label)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/labelcache.c b/mapscript/php/labelcache.c
index 43f6ef503..cd04b3cdf 100644
--- a/mapscript/php/labelcache.c
+++ b/mapscript/php/labelcache.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_labelcache;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_labelcache_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(labelcache___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -75,7 +78,7 @@ PHP_METHOD(labelCacheObj, freeCache)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_labelcache = (php_labelcache_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_labelcache = MAPSCRIPT_OBJ_P(php_labelcache_object, zobj);
labelCacheObj_freeCache(php_labelcache->labelcache);
@@ -96,13 +99,61 @@ void mapscript_create_labelcache(labelCacheObj *labelcache, parent_object parent
{
php_labelcache_object * php_labelcache;
object_init_ex(return_value, mapscript_ce_labelcache);
- php_labelcache = (php_labelcache_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_labelcache = MAPSCRIPT_OBJ_P(php_labelcache_object, return_value);
php_labelcache->labelcache = labelcache;
php_labelcache->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_labelcache_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_labelcache_object *php_labelcache;
+
+ php_labelcache = ecalloc(1, sizeof(*php_labelcache) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_labelcache->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_labelcache->zobj, ce);
+
+ php_labelcache->zobj.handlers = &mapscript_labelcache_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_labelcache->parent);
+
+ return &php_labelcache->zobj;
+}
+
+static void mapscript_labelcache_free_object(zend_object *object)
+{
+ php_labelcache_object *php_labelcache;
+
+ php_labelcache = (php_labelcache_object *)((char *)object - XtOffsetOf(php_labelcache_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_labelcache->parent);
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(labelcache)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "labelcacheObj", labelcache_functions);
+ mapscript_ce_labelcache = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_labelcache->create_object = mapscript_labelcache_create_object;
+ mapscript_ce_labelcache->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_labelcache_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_labelcache_object_handlers));
+ mapscript_labelcache_object_handlers.free_obj = mapscript_labelcache_free_object;
+ mapscript_labelcache_object_handlers.offset = XtOffsetOf(php_labelcache_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_labelcache_object_destroy(void *object TSRMLS_DC)
{
php_labelcache_object *php_labelcache = (php_labelcache_object *)object;
@@ -144,3 +195,4 @@ PHP_MINIT_FUNCTION(labelcache)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/labelcachemember.c b/mapscript/php/labelcachemember.c
index e34010673..6241b9528 100644
--- a/mapscript/php/labelcachemember.c
+++ b/mapscript/php/labelcachemember.c
@@ -29,10 +29,12 @@
* DEALINGS IN THE SOFTWARE.
**********************************************************************/
-#ifdef what_the_fxxx_is_this_for
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_labelcachemember;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_labelcachemember_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(labelcachemember___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -66,21 +68,21 @@ PHP_METHOD(labelCacheMemberObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_labelcachemember = (php_labelcachemember_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_labelcachemember = MAPSCRIPT_OBJ_P(php_labelcachemember_object, zobj);
IF_GET_LONG("classindex", php_labelcachemember->labelcachemember->classindex)
- else IF_GET_LONG("featuresize", php_labelcachemember->labelcachemember->featuresize)
+ /* else IF_GET_LONG("featuresize", php_labelcachemember->labelcachemember->featuresize) */
else IF_GET_LONG("layerindex", php_labelcachemember->labelcachemember->layerindex)
- else IF_GET_LONG("numstyles", php_labelcachemember->labelcachemember->numstyles)
- else IF_GET_LONG("numlabels", php_labelcachemember->labelcachemember->numlabels)
+ /* else IF_GET_LONG("numstyles", php_labelcachemember->labelcachemember->numstyles) */
+ /* else IF_GET_LONG("numlabels", php_labelcachemember->labelcachemember->numlabels) */
/* else IF_GET_LONG("shapeindex", php_labelcachemember->labelcachemember->shapeindex) */
else IF_GET_LONG("status", php_labelcachemember->labelcachemember->status)
else IF_GET_LONG("markerid", php_labelcachemember->labelcachemember->markerid)
/* else IF_GET_LONG("tileindex", php_labelcachemember->labelcachemember->tileindex) */
else IF_GET_OBJECT("point", mapscript_ce_point, php_labelcachemember->point, &php_labelcachemember->labelcachemember->point)
- else IF_GET_OBJECT("labels", mapscript_ce_label, php_labelcachemember->labels, &php_labelcachemember->labelcachemember->labels)
- else IF_GET_OBJECT("styles", mapscript_ce_style, php_labelcachemember->styles, php_labelcachemember->labelcachemember->styles)
- else IF_GET_OBJECT("poly", mapscript_ce_shape, php_labelcachemember->poly, php_labelcachemember->labelcachemember->poly)
+ /* else IF_GET_OBJECT("labels", mapscript_ce_label, php_labelcachemember->labels, &php_labelcachemember->labelcachemember->labels) */
+ /* else IF_GET_OBJECT("styles", mapscript_ce_style, php_labelcachemember->styles, php_labelcachemember->labelcachemember->styles) */
+ /* else IF_GET_OBJECT("poly", mapscript_ce_shape, php_labelcachemember->poly, php_labelcachemember->labelcachemember->poly) */
else {
mapscript_throw_exception("Property '%s' does not exist in this object." TSRMLS_CC, property);
}
@@ -91,8 +93,8 @@ PHP_METHOD(labelCacheMemberObj, __set)
char *property;
long property_len = 0;
zval *value;
- zval *zobj = getThis();
- php_labelcachemember_object *php_labelcachemember;
+ /* zval *zobj = getThis(); */
+ /* php_labelcachemember_object *php_labelcachemember; */
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "sz",
@@ -102,20 +104,20 @@ PHP_METHOD(labelCacheMemberObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_labelcachemember = (php_labelcachemember_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ /* php_labelcachemember = MAPSCRIPT_OBJ_P(php_labelcachemember_object, zobj); */
if ( (STRING_EQUAL("classindex", property)) ||
- (STRING_EQUAL("featuresize", property)) ||
+ /* (STRING_EQUAL("featuresize", property)) || */
(STRING_EQUAL("layerindex", property)) ||
- (STRING_EQUAL("numstyles", property)) ||
- (STRING_EQUAL("numlabels", property)) ||
- (STRING_EQUAL("shapeindex", property)) ||
+ /* (STRING_EQUAL("numstyles", property)) || */
+ /* (STRING_EQUAL("numlabels", property)) || */
+ /* (STRING_EQUAL("shapeindex", property)) || */
(STRING_EQUAL("status", property)) ||
(STRING_EQUAL("markerid", property)) ||
- (STRING_EQUAL("tileindex", property)) ||
- (STRING_EQUAL("labels", property)) ||
- (STRING_EQUAL("styles", property)) ||
- (STRING_EQUAL("poly", property)) ||
+ /* (STRING_EQUAL("tileindex", property)) || */
+ /* (STRING_EQUAL("labels", property)) || */
+ /* (STRING_EQUAL("styles", property)) || */
+ /* (STRING_EQUAL("poly", property)) || */
(STRING_EQUAL("point", property))) {
mapscript_throw_exception("Property '%s' is read-only and cannot be set." TSRMLS_CC, property);
} else {
@@ -137,7 +139,7 @@ PHP_METHOD(labelCacheMemberObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_labelcachemember = (php_labelcachemember_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_labelcachemember = MAPSCRIPT_OBJ_P(php_labelcachemember_object, zobj);
MAPSCRIPT_DELREF(php_labelcachemember->point);
MAPSCRIPT_DELREF(php_labelcachemember->labels);
@@ -162,7 +164,7 @@ void mapscript_create_labelcachemember(labelCacheMemberObj *labelcachemember,
{
php_labelcachemember_object * php_labelcachemember;
object_init_ex(return_value, mapscript_ce_labelcachemember);
- php_labelcachemember = (php_labelcachemember_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_labelcachemember = MAPSCRIPT_OBJ_P(php_labelcachemember_object, return_value);
php_labelcachemember->labelcachemember = labelcachemember;
php_labelcachemember->parent = parent;
@@ -170,6 +172,65 @@ void mapscript_create_labelcachemember(labelCacheMemberObj *labelcachemember,
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_labelcachemember_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_labelcachemember_object *php_labelcachemember;
+
+ php_labelcachemember = ecalloc(1, sizeof(*php_labelcachemember) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_labelcachemember->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_labelcachemember->zobj, ce);
+
+ php_labelcachemember->zobj.handlers = &mapscript_labelcachemember_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_labelcachemember->parent);
+ ZVAL_UNDEF(&php_labelcachemember->point);
+ ZVAL_UNDEF(&php_labelcachemember->labels);
+ ZVAL_UNDEF(&php_labelcachemember->styles);
+ ZVAL_UNDEF(&php_labelcachemember->poly);
+
+
+ return &php_labelcachemember->zobj;
+}
+
+static void mapscript_labelcachemember_free_object(zend_object *object)
+{
+ php_labelcachemember_object *php_labelcachemember;
+
+ php_labelcachemember = (php_labelcachemember_object *)((char *)object - XtOffsetOf(php_labelcachemember_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_labelcachemember->parent);
+ MAPSCRIPT_DELREF(php_labelcachemember->point);
+ MAPSCRIPT_DELREF(php_labelcachemember->labels);
+ MAPSCRIPT_DELREF(php_labelcachemember->styles);
+ MAPSCRIPT_DELREF(php_labelcachemember->poly);
+
+ /* We don't need to free the labelCacheMemberObj, the mapObj will do it */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(labelcachemember)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "labelCacheMemberObj", labelcachemember_functions);
+ mapscript_ce_labelcachemember = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_labelcachemember->create_object = mapscript_labelcachemember_create_object;
+ mapscript_ce_labelcachemember->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_labelcachemember_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_labelcachemember_object_handlers));
+ mapscript_labelcachemember_object_handlers.free_obj = mapscript_labelcachemember_free_object;
+ mapscript_labelcachemember_object_handlers.offset = XtOffsetOf(php_labelcachemember_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
+
static void mapscript_labelcachemember_object_destroy(void *object TSRMLS_DC)
{
php_labelcachemember_object *php_labelcachemember = (php_labelcachemember_object *)object;
@@ -220,4 +281,3 @@ PHP_MINIT_FUNCTION(labelcachemember)
return SUCCESS;
}
#endif
-
diff --git a/mapscript/php/labelleader.c b/mapscript/php/labelleader.c
index 343a531e8..edf4d113a 100644
--- a/mapscript/php/labelleader.c
+++ b/mapscript/php/labelleader.c
@@ -30,6 +30,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_labelleader;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_labelleader_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(labelleader___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -63,7 +66,7 @@ PHP_METHOD(labelLeaderObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_labelleader = (php_labelleader_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_labelleader = MAPSCRIPT_OBJ_P(php_labelleader_object, zobj);
IF_GET_LONG("maxdistance", php_labelleader->labelleader->maxdistance)
else IF_GET_LONG("gridstep", php_labelleader->labelleader->gridstep)
@@ -106,13 +109,63 @@ void mapscript_create_labelleader(labelLeaderObj *labelleader, parent_object par
{
php_labelleader_object * php_labelleader;
object_init_ex(return_value, mapscript_ce_labelleader);
- php_labelleader = (php_labelleader_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_labelleader = MAPSCRIPT_OBJ_P(php_labelleader_object, return_value);
php_labelleader->labelleader = labelleader;
php_labelleader->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_labelleader_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_labelleader_object *php_labelleader;
+
+ php_labelleader = ecalloc(1, sizeof(*php_labelleader) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_labelleader->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_labelleader->zobj, ce);
+
+ php_labelleader->zobj.handlers = &mapscript_labelleader_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_labelleader->parent);
+
+ return &php_labelleader->zobj;
+}
+
+static void mapscript_labelleader_free_object(zend_object *object)
+{
+ php_labelleader_object *php_labelleader;
+
+ php_labelleader = (php_labelleader_object *)((char *)object - XtOffsetOf(php_labelleader_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_labelleader->parent);
+
+ /* We don't need to free the labelLeaderObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(labelleader)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "labelLeaderObj", labelleader_functions);
+ mapscript_ce_labelleader = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_labelleader->create_object = mapscript_labelleader_create_object;
+ mapscript_ce_labelleader->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_labelleader_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_labelleader_object_handlers));
+ mapscript_labelleader_object_handlers.free_obj = mapscript_labelleader_free_object;
+ mapscript_labelleader_object_handlers.offset = XtOffsetOf(php_labelleader_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
+
static void mapscript_labelleader_object_destroy(void *object TSRMLS_DC)
{
php_labelleader_object *php_labelleader = (php_labelleader_object *)object;
@@ -154,3 +207,4 @@ PHP_MINIT_FUNCTION(labelleader)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/layer.c b/mapscript/php/layer.c
index 8567bc8e2..09c961173 100644
--- a/mapscript/php/layer.c
+++ b/mapscript/php/layer.c
@@ -220,10 +220,10 @@ PHP_METHOD(layerObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *)zend_object_store_get_object(zobj TSRMLS_CC);
- php_map = (php_map_object *)zend_object_store_get_object(zmap TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
if (zlayer)
- php_layer2 = (php_layer_object *)zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_layer2 = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if ((layer = layerObj_new(php_map->map)) == NULL) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -235,7 +235,7 @@ PHP_METHOD(layerObj, __construct)
MAPSCRIPT_MAKE_PARENT(zmap, NULL);
php_layer->parent = parent;
- MAPSCRIPT_ADDREF(zmap);
+ MAPSCRIPT_ADDREF_P(zmap);
/* if a layer is passed as argument, copy the layer into
the new one */
@@ -248,7 +248,11 @@ PHP_METHOD(layerObj, __construct)
if (layer->connectiontype != MS_GRATICULE || layer->layerinfo == NULL) {
MAKE_STD_ZVAL(php_layer->grid);
+#if PHP_VERSION_ID < 70000
ZVAL_NULL(php_layer->grid);
+#else
+ ZVAL_NULL(&php_layer->grid);
+#endif
}
}
/* }}} */
@@ -268,7 +272,7 @@ PHP_METHOD(layerObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
IF_GET_LONG("numclasses", php_layer->layer->numclasses)
else IF_GET_STRING("encoding", php_layer->layer->encoding)
@@ -345,7 +349,7 @@ PHP_METHOD(layerObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
/* special case for "template" which we want to set to NULL and not an empty string */
if(Z_TYPE_P(value)==IS_NULL && !strcmp(property,"template")) {
@@ -433,15 +437,15 @@ PHP_METHOD(layerObj, draw)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_draw(php_layer->layer, php_map->map, php_image->image)) != MS_SUCCESS)
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -469,15 +473,15 @@ PHP_METHOD(layerObj, drawQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_drawQuery(php_layer->layer, php_map->map, php_image->image)) != MS_SUCCESS)
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -508,15 +512,15 @@ PHP_METHOD(layerObj, queryByPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByPoint(php_layer->layer, php_map->map, php_point->point,
mode, buffer)) != MS_SUCCESS)
@@ -545,15 +549,15 @@ PHP_METHOD(layerObj, queryByRect)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_rect = (php_rect_object *) zend_object_store_get_object(zrect TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zrect);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByRect(php_layer->layer, php_map->map, *(php_rect->rect))) != MS_SUCCESS)
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -581,15 +585,15 @@ PHP_METHOD(layerObj, queryByShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByShape(php_layer->layer, php_map->map, php_shape->shape)) != MS_SUCCESS)
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -616,14 +620,14 @@ PHP_METHOD(layerObj, queryByFeatures)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByFeatures(php_layer->layer, php_map->map, slayer)) != MS_SUCCESS)
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -656,14 +660,14 @@ PHP_METHOD(layerObj, queryByAttributes)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByAttributes(php_layer->layer, php_map->map,
item, string, mode)) != MS_SUCCESS)
@@ -692,14 +696,14 @@ PHP_METHOD(layerObj, queryByFilter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByFilter(php_layer->layer, php_map->map,
string)) != MS_SUCCESS)
@@ -728,14 +732,14 @@ PHP_METHOD(layerObj, queryByIndex)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((status = layerObj_queryByIndex(php_layer->layer, php_map->map,
tileindex, shapeindex, addtoquery)) != MS_SUCCESS)
@@ -763,7 +767,7 @@ PHP_METHOD(layerObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((status = layerObj_updateFromString(php_layer->layer, snippet)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -789,14 +793,14 @@ PHP_METHOD(layerObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
value = layerObj_convertToString(php_layer->layer);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -819,7 +823,7 @@ PHP_METHOD(layerObj, getClass)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((class = layerObj_getClass(php_layer->layer, index)) == NULL) {
mapscript_throw_exception("Invalid class index." TSRMLS_CC);
@@ -837,7 +841,8 @@ PHP_METHOD(layerObj, getClass)
PHP_METHOD(layerObj, getClassIndex)
{
zval *zobj = getThis();
- zval *zshape, **ppzval, *zclassgroup = NULL;
+ zval *zshape, *zclassgroup = NULL;
+ MAPSCRIPT_ZVAL_P ppzval;
int numElements, *classGroups = NULL;
int retval = -1, i = 0;
long numClasses = 0;
@@ -856,15 +861,15 @@ PHP_METHOD(layerObj, getClassIndex)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if (zclassgroup) {
classgroup_hash = Z_ARRVAL_P(zclassgroup);
@@ -874,7 +879,11 @@ PHP_METHOD(layerObj, getClassIndex)
for(zend_hash_internal_pointer_reset(classgroup_hash);
zend_hash_has_more_elements(classgroup_hash) == SUCCESS;
zend_hash_move_forward(classgroup_hash), ++i) {
+#if PHP_VERSION_ID < 70000
zend_hash_get_current_data(classgroup_hash, (void **)&ppzval);
+#else
+ ppzval = zend_hash_get_current_data(classgroup_hash);
+#endif
classGroups[i] = Z_LVAL_PP(ppzval);
}
}
@@ -907,7 +916,7 @@ PHP_METHOD(layerObj, setFilter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((status = layerObj_setFilter(php_layer->layer, expression)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -933,14 +942,14 @@ PHP_METHOD(layerObj, getFilterString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
value = layerObj_getFilter(php_layer->layer);
if (value == NULL) {
RETURN_NULL();
}
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -964,16 +973,16 @@ PHP_METHOD(layerObj, setProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- if (php_layer->projection)
- php_projection = (php_projection_object *) zend_object_store_get_object(php_layer->projection TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ if (ZVAL_NOT_UNDEF(php_layer->projection))
+ php_projection = MAPSCRIPT_OBJ(php_projection_object, php_layer->projection);
if ((status = layerObj_setProjection(php_layer->layer, projection)) != MS_SUCCESS) {
mapscript_report_php_error(E_WARNING, "setProjection failed" TSRMLS_CC);
RETURN_LONG(status);
}
- if (php_layer->projection)
+ if (ZVAL_NOT_UNDEF(php_layer->projection))
php_projection->projection = &(php_layer->layer->projection);
RETURN_LONG(status);
@@ -995,14 +1004,14 @@ PHP_METHOD(layerObj, getProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
projection = layerObj_getProjection(php_layer->layer);
if (projection == NULL) {
RETURN_NULL();
}
- RETVAL_STRING(projection, 1);
+ MAPSCRIPT_RETVAL_STRING(projection, 1);
free(projection);
}
/* }}} */
@@ -1026,16 +1035,16 @@ PHP_METHOD(layerObj, setWKTProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- if (php_layer->projection)
- php_projection = (php_projection_object *) zend_object_store_get_object(php_layer->projection TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ if (ZVAL_NOT_UNDEF(php_layer->projection))
+ php_projection = MAPSCRIPT_OBJ(php_projection_object, php_layer->projection);
if ((status = layerObj_setWKTProjection(php_layer->layer, projection)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
return;
}
- if (php_layer->projection)
+ if (ZVAL_NOT_UNDEF(php_layer->projection))
php_projection->projection = &(php_layer->layer->projection);
RETURN_LONG(status);
@@ -1056,7 +1065,7 @@ PHP_METHOD(layerObj, getNumResults)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if (!php_layer->layer->resultcache)
@@ -1081,7 +1090,7 @@ PHP_METHOD(layerObj, getResultsBounds)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if (!php_layer->layer->resultcache)
RETURN_NULL();
@@ -1111,7 +1120,7 @@ PHP_METHOD(layerObj, getResult)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((result = layerObj_getResult(php_layer->layer, index)) == NULL) {
mapscript_throw_exception("Invalid result index." TSRMLS_CC);
@@ -1140,7 +1149,7 @@ PHP_METHOD(layerObj, open)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
status = layerObj_open(php_layer->layer);
@@ -1182,8 +1191,8 @@ PHP_METHOD(layerObj, whichShapes)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_rect = (php_rect_object *) zend_object_store_get_object(zrect TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zrect);
status = layerObj_whichShapes(php_layer->layer, php_rect->rect);
@@ -1207,7 +1216,7 @@ PHP_METHOD(layerObj, nextShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
shape = layerObj_nextShape(php_layer->layer);
@@ -1234,7 +1243,7 @@ PHP_METHOD(layerObj, close)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
layerObj_close(php_layer->layer);
}
@@ -1256,7 +1265,7 @@ PHP_METHOD(layerObj, getExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
/* Create a new rectObj to hold the result */
if ((rect = rectObj_new()) == NULL) {
@@ -1290,7 +1299,7 @@ PHP_METHOD(layerObj, setExtent)
return;
}
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if (minx > maxx || miny > maxy) {
mapscript_throw_mapserver_exception("Invalid min/max values" TSRMLS_CC);
@@ -1320,8 +1329,8 @@ PHP_METHOD(layerObj, addFeature)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
status = layerObj_addFeature(php_layer->layer, php_shape->shape);
@@ -1337,7 +1346,7 @@ PHP_METHOD(layerObj, getMetaData)
zval *zname;
zval *zobj = getThis();
php_layer_object *php_layer;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -1347,12 +1356,16 @@ PHP_METHOD(layerObj, getMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_layer->metadata, &php_layer->layer->metadata);
MAPSCRIPT_CALL_METHOD_1(php_layer->metadata, "get", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_STRING(Z_STRVAL_P(retval),1);
+#else
+ RETURN_STRING(Z_STRVAL(retval))
+#endif
}
/* }}} */
@@ -1363,7 +1376,7 @@ PHP_METHOD(layerObj, setMetaData)
zval *zname, *zvalue;
zval *zobj = getThis();
php_layer_object *php_layer;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz",
@@ -1373,12 +1386,16 @@ PHP_METHOD(layerObj, setMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_layer->metadata, &php_layer->layer->metadata);
MAPSCRIPT_CALL_METHOD_2(php_layer->metadata, "set", retval, zname, zvalue);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -1389,7 +1406,7 @@ PHP_METHOD(layerObj, removeMetaData)
zval *zname;
zval *zobj = getThis();
php_layer_object *php_layer;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -1399,12 +1416,16 @@ PHP_METHOD(layerObj, removeMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_layer->metadata, &php_layer->layer->metadata);
MAPSCRIPT_CALL_METHOD_1(php_layer->metadata, "remove", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -1429,14 +1450,14 @@ PHP_METHOD(layerObj, getWMSFeatureInfoURL)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
if ((value = layerObj_getWMSFeatureInfoURL(php_layer->layer, php_map->map,
clickx,
@@ -1444,10 +1465,10 @@ PHP_METHOD(layerObj, getWMSFeatureInfoURL)
featureCount,
infoFormat)) == NULL) {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -1467,7 +1488,7 @@ PHP_METHOD(layerObj, getItems)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
array_init(return_value);
status = msLayerGetItems(php_layer->layer);
@@ -1475,7 +1496,7 @@ PHP_METHOD(layerObj, getItems)
if (status != MS_FAILURE && php_layer->layer->numitems > 0) {
for (i=0; i<php_layer->layer->numitems; i++) {
/* add a copy of the group name to the PHP array */
- add_next_index_string(return_value, php_layer->layer->items[i], 1);
+ mapscript_add_next_index_string(return_value, php_layer->layer->items[i], 1);
}
}
}
@@ -1498,7 +1519,7 @@ PHP_METHOD(layerObj, setProcessing)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
php_layer->layer->numprocessing++;
if(php_layer->layer->numprocessing == 1)
@@ -1532,7 +1553,7 @@ PHP_METHOD(layerObj, setProcessingKey)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
msLayerSetProcessingKey( php_layer->layer, key, value );
@@ -1555,12 +1576,12 @@ PHP_METHOD(layerObj, getProcessing)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
array_init(return_value);
if (php_layer->layer->numprocessing > 0) {
for (i=0; i<php_layer->layer->numprocessing; i++) {
- add_next_index_string(return_value, php_layer->layer->processing[i], 1);
+ mapscript_add_next_index_string(return_value, php_layer->layer->processing[i], 1);
}
}
}
@@ -1581,7 +1602,7 @@ PHP_METHOD(layerObj, clearProcessing)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if (php_layer->layer->numprocessing > 0) {
for(i=0; i<php_layer->layer->numprocessing; i++)
@@ -1608,12 +1629,12 @@ PHP_METHOD(layerObj, executeWFSGetFeature)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((value=layerObj_executeWFSGetFeature(php_layer->layer)) == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -1642,7 +1663,7 @@ PHP_METHOD(layerObj, applySLD)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
status = layerObj_applySLD(php_layer->layer, sldxml, namedLayer);
@@ -1675,7 +1696,7 @@ PHP_METHOD(layerObj, applySLDURL)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
status = layerObj_applySLDURL(php_layer->layer, sldurl, namedLayer);
@@ -1699,16 +1720,16 @@ PHP_METHOD(layerObj, generateSLD)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
buffer = layerObj_generateSLD(php_layer->layer);
if (buffer) {
- RETVAL_STRING(buffer, 1);
+ MAPSCRIPT_RETVAL_STRING(buffer, 1);
free(buffer);
} else {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
}
/* }}} */
@@ -1731,7 +1752,7 @@ PHP_METHOD(layerObj, moveClassUp)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
status = layerObj_moveClassUp(php_layer->layer, index);
@@ -1757,7 +1778,7 @@ PHP_METHOD(layerObj, moveClassDown)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
status = layerObj_moveClassDown(php_layer->layer, index);
@@ -1784,7 +1805,7 @@ PHP_METHOD(layerObj, removeClass)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((class = layerObj_removeClass(php_layer->layer, index)) == NULL) {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
@@ -1814,14 +1835,14 @@ PHP_METHOD(layerObj, isVisible)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
retval = msLayerIsVisible(php_map->map, php_layer->layer);
@@ -1849,7 +1870,7 @@ PHP_METHOD(layerObj, setConnectionType)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if ((status = layerObj_setConnectionType(php_layer->layer,
type,
@@ -1859,10 +1880,14 @@ PHP_METHOD(layerObj, setConnectionType)
}
if (php_layer->layer->connectiontype != MS_GRATICULE || php_layer->layer->layerinfo == NULL) {
- if (php_layer->grid && Z_TYPE_P(php_layer->grid) == IS_OBJECT) {
+ if (ZVAL_NOT_UNDEF(php_layer->grid) && MAPSCRIPT_TYPE(php_layer->grid) == IS_OBJECT) {
MAPSCRIPT_DELREF(php_layer->grid);
MAKE_STD_ZVAL(php_layer->grid);
+#if PHP_VERSION_ID < 70000
ZVAL_NULL(php_layer->grid);
+#else
+ ZVAL_NULL(&php_layer->grid);
+#endif
}
}
@@ -1876,7 +1901,7 @@ PHP_METHOD(layerObj, getGridIntersectionCoordinates)
{
zval *zobj = getThis();
graticuleIntersectionObj *values=NULL;
- zval *tmp_arr1;
+ MAPSCRIPT_ZVAL tmp_arr1;
int i=0;
php_layer_object *php_layer;
php_map_object *php_map;
@@ -1888,14 +1913,14 @@ PHP_METHOD(layerObj, getGridIntersectionCoordinates)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
- if (!php_layer->parent.val) {
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this layer object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
array_init(return_value);
@@ -1914,92 +1939,118 @@ PHP_METHOD(layerObj, getGridIntersectionCoordinates)
add_assoc_double(return_value, "topnumpoints", values->nTop);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nTop; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(tmp_arr1, values->papszTopLabels[i],1);
+#else
+ add_next_index_string(&tmp_arr1, values->papszTopLabels[i]);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "toplabels", strlen("toplabels")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "toplabels", tmp_arr1);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nTop; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_double(tmp_arr1, values->pasTop[i].x);
add_next_index_double(tmp_arr1, values->pasTop[i].y);
+#else
+ add_next_index_double(&tmp_arr1, values->pasTop[i].x);
+ add_next_index_double(&tmp_arr1, values->pasTop[i].y);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "toppoints", strlen("toppoints")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "toppoints", tmp_arr1);
/*BOTTOM*/
add_assoc_double(return_value, "bottomnumpoints", values->nBottom);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nBottom; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(tmp_arr1, values->papszBottomLabels[i],1);
+#else
+ add_next_index_string(&tmp_arr1, values->papszBottomLabels[i]);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "bottomlabels", strlen("bottomlabels")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "bottomlabels", tmp_arr1);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nBottom; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_double(tmp_arr1, values->pasBottom[i].x);
add_next_index_double(tmp_arr1, values->pasBottom[i].y);
+#else
+ add_next_index_double(&tmp_arr1, values->pasBottom[i].x);
+ add_next_index_double(&tmp_arr1, values->pasBottom[i].y);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "bottompoints", strlen("bottompoints")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "bottompoints", tmp_arr1);
/*LEFT*/
add_assoc_double(return_value, "leftnumpoints", values->nLeft);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nLeft; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(tmp_arr1, values->papszLeftLabels[i],1);
+#else
+ add_next_index_string(&tmp_arr1, values->papszLeftLabels[i]);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "leftlabels", strlen("leftlabels")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "leftlabels", tmp_arr1);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nLeft; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_double(tmp_arr1, values->pasLeft[i].x);
add_next_index_double(tmp_arr1, values->pasLeft[i].y);
-
+#else
+ add_next_index_double(&tmp_arr1, values->pasLeft[i].x);
+ add_next_index_double(&tmp_arr1, values->pasLeft[i].y);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "leftpoints", strlen("leftpoints")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "leftpoints", tmp_arr1);
/*RIGHT*/
add_assoc_double(return_value, "rightnumpoints", values->nRight);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nRight; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(tmp_arr1, values->papszRightLabels[i],1);
+#else
+ add_next_index_string(&tmp_arr1, values->papszRightLabels[i]);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "rightlabels", strlen("rightlabels")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "rightlabels", tmp_arr1);
MAKE_STD_ZVAL(tmp_arr1);
- array_init(tmp_arr1);
+ mapscript_array_init(tmp_arr1);
for (i=0; i<values->nRight; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_double(tmp_arr1, values->pasRight[i].x);
add_next_index_double(tmp_arr1, values->pasRight[i].y);
-
+#else
+ add_next_index_double(&tmp_arr1, values->pasRight[i].x);
+ add_next_index_double(&tmp_arr1, values->pasRight[i].y);
+#endif
}
- zend_hash_update(Z_ARRVAL_P(return_value), "rightpoints", strlen("rightpoints")+1, &tmp_arr1,
- sizeof(tmp_arr1), NULL);
+ mapscript_hash_update(Z_ARRVAL_P(return_value), "rightpoints", tmp_arr1);
msGraticuleLayerFreeIntersectionPoints(values);
}
@@ -2024,8 +2075,8 @@ PHP_METHOD(layerObj, getShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_result = (php_result_object *) zend_object_store_get_object(zresult TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+ php_result = MAPSCRIPT_OBJ_P(php_result_object, zresult);
/* Create a new shapeObj to hold the result
* Note that the type used to create the shape (MS_NULL) does not matter
@@ -2062,13 +2113,13 @@ PHP_METHOD(layerObj, getGeomTransform)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
if (php_layer->layer->_geomtransform.type == MS_GEOMTRANSFORM_NONE ||
!php_layer->layer->_geomtransform.string)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETURN_STRING(php_layer->layer->_geomtransform.string, 1);
+ MAPSCRIPT_RETURN_STRING(php_layer->layer->_geomtransform.string, 1);
}
/* }}} */
@@ -2089,7 +2140,7 @@ PHP_METHOD(layerObj, setGeomTransform)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
msFree(php_layer->layer->_geomtransform.string);
if (transform_len > 0) {
@@ -2118,10 +2169,10 @@ PHP_METHOD(layerObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
MAPSCRIPT_DELREF(php_layer->offsite);
- if (php_layer->grid && Z_TYPE_P(php_layer->grid) == IS_OBJECT)
+ if (ZVAL_NOT_UNDEF(php_layer->grid) && MAPSCRIPT_TYPE(php_layer->grid) == IS_OBJECT)
MAPSCRIPT_DELREF(php_layer->grid);
MAPSCRIPT_DELREF(php_layer->metadata);
MAPSCRIPT_DELREF(php_layer->bindvals);
@@ -2195,21 +2246,110 @@ void mapscript_create_layer(layerObj *layer, parent_object parent, zval *return_
{
php_layer_object * php_layer;
object_init_ex(return_value, mapscript_ce_layer);
- php_layer = (php_layer_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, return_value);
php_layer->layer = layer;
if (layer->connectiontype != MS_GRATICULE || layer->layerinfo == NULL) {
MAKE_STD_ZVAL(php_layer->grid);
+#if PHP_VERSION_ID < 70000
ZVAL_NULL(php_layer->grid);
+#else
+ ZVAL_NULL(&php_layer->grid);
+#endif
}
- if (parent.val)
+ if(ZVAL_NOT_UNDEF(parent.val))
php_layer->is_ref = 1;
php_layer->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_layer_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_layer_object *php_layer;
+
+ php_layer = ecalloc(1, sizeof(*php_layer) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_layer->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_layer->zobj, ce);
+
+ php_layer->zobj.handlers = &mapscript_layer_object_handlers;
+
+ php_layer->is_ref = 0;
+ MAPSCRIPT_INIT_PARENT(php_layer->parent);
+ ZVAL_UNDEF(&php_layer->offsite);
+ ZVAL_UNDEF(&php_layer->grid);
+ ZVAL_UNDEF(&php_layer->metadata);
+ ZVAL_UNDEF(&php_layer->bindvals);
+ ZVAL_UNDEF(&php_layer->cluster);
+ ZVAL_UNDEF(&php_layer->projection);
+ ZVAL_UNDEF(&php_layer->extent);
+
+ return &php_layer->zobj;
+}
+
+static void mapscript_layer_free_object(zend_object *object)
+{
+ php_layer_object *php_layer;
+
+ php_layer = (php_layer_object *)((char *)object - XtOffsetOf(php_layer_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_layer->parent);
+ MAPSCRIPT_DELREF(php_layer->offsite);
+ if (ZVAL_NOT_UNDEF(php_layer->grid) && MAPSCRIPT_TYPE(php_layer->grid) == IS_OBJECT)
+ MAPSCRIPT_DELREF(php_layer->grid);
+ MAPSCRIPT_DELREF(php_layer->metadata);
+ MAPSCRIPT_DELREF(php_layer->bindvals);
+ MAPSCRIPT_DELREF(php_layer->cluster);
+ MAPSCRIPT_DELREF(php_layer->projection);
+ MAPSCRIPT_DELREF(php_layer->extent);
+
+ if (php_layer->layer && !php_layer->is_ref) {
+ layerObj_destroy(php_layer->layer);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_layer_clone_object(zval *zobj)
+{
+ php_layer_object *php_layer_old, *php_layer_new;
+ zend_object* zobj_new;
+
+ php_layer_old = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
+
+ zobj_new = mapscript_layer_create_object(mapscript_ce_layer);
+ php_layer_new = (php_layer_object *)((char *)zobj_new - XtOffsetOf(php_layer_object, zobj));
+
+ zend_objects_clone_members(&php_layer_new->zobj, &php_layer_old->zobj);
+
+ php_layer_new->layer = layerObj_clone(php_layer_old->layer);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(layer)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "layerObj", layer_functions);
+ mapscript_ce_layer = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_layer->create_object = mapscript_layer_create_object;
+ mapscript_ce_layer->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_layer_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_layer_object_handlers));
+ mapscript_layer_object_handlers.free_obj = mapscript_layer_free_object;
+ mapscript_layer_object_handlers.clone_obj = mapscript_layer_clone_object;
+ mapscript_layer_object_handlers.offset = XtOffsetOf(php_layer_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_layer_object_destroy(void *object TSRMLS_DC)
{
php_layer_object *php_layer = (php_layer_object *)object;
@@ -2269,7 +2409,7 @@ static zend_object_value mapscript_layer_object_clone(zval *zobj TSRMLS_DC)
php_layer_object *php_layer_old, *php_layer_new;
zend_object_value new_ov;
- php_layer_old = (php_layer_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_layer_old = MAPSCRIPT_OBJ_P(php_layer_object, zobj);
new_ov = mapscript_layer_object_new_ex(mapscript_ce_layer, &php_layer_new TSRMLS_CC);
zend_objects_clone_members(&php_layer_new->std, new_ov, &php_layer_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -2295,4 +2435,4 @@ PHP_MINIT_FUNCTION(layer)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/legend.c b/mapscript/php/legend.c
index 52258fec5..29e080df7 100644
--- a/mapscript/php/legend.c
+++ b/mapscript/php/legend.c
@@ -30,6 +30,9 @@
**********************************************************************/
#include "php_mapscript.h"
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_legend_object_handlers;
+#endif
zend_class_entry *mapscript_ce_legend;
@@ -69,7 +72,7 @@ PHP_METHOD(legendObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_legend = (php_legend_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, zobj);
IF_GET_LONG("height", php_legend->legend->height)
else IF_GET_LONG("width", php_legend->legend->width)
@@ -105,7 +108,7 @@ PHP_METHOD(legendObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_legend = (php_legend_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, zobj);
IF_SET_LONG("height", php_legend->legend->height, value)
else IF_SET_LONG("width", php_legend->legend->width, value)
@@ -144,7 +147,7 @@ PHP_METHOD(legendObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_legend = (php_legend_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, zobj);
status = legendObj_updateFromString(php_legend->legend, snippet);
@@ -172,14 +175,14 @@ PHP_METHOD(legendObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_legend = (php_legend_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, zobj);
value = legendObj_convertToString(php_legend->legend);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -198,7 +201,7 @@ PHP_METHOD(legendObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_legend = (php_legend_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, zobj);
MAPSCRIPT_DELREF(php_legend->outlinecolor);
MAPSCRIPT_DELREF(php_legend->imagecolor);
@@ -217,11 +220,67 @@ zend_function_entry legend_functions[] = {
}
};
+
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_legend_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_legend_object *php_legend;
+
+ php_legend = ecalloc(1, sizeof(*php_legend) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_legend->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_legend->zobj, ce);
+
+ php_legend->zobj.handlers = &mapscript_legend_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_legend->parent);
+ ZVAL_UNDEF(&php_legend->outlinecolor);
+ ZVAL_UNDEF(&php_legend->imagecolor);
+ ZVAL_UNDEF(&php_legend->label);
+
+ return &php_legend->zobj;
+}
+
+static void mapscript_legend_free_object(zend_object *object)
+{
+ php_legend_object *php_legend;
+
+ php_legend = (php_legend_object *)((char *)object - XtOffsetOf(php_legend_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_legend->parent);
+ MAPSCRIPT_DELREF(php_legend->outlinecolor);
+ MAPSCRIPT_DELREF(php_legend->imagecolor);
+ MAPSCRIPT_DELREF(php_legend->label);
+
+ /* We don't need to free the legendObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(legend)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "legendObj", legend_functions);
+ mapscript_ce_legend = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_legend->create_object = mapscript_legend_create_object;
+ mapscript_ce_legend->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_legend_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_legend_object_handlers));
+ mapscript_legend_object_handlers.free_obj = mapscript_legend_free_object;
+ mapscript_legend_object_handlers.offset = XtOffsetOf(php_legend_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
void mapscript_create_legend(legendObj *legend, parent_object parent, zval *return_value TSRMLS_DC)
{
php_legend_object * php_legend;
object_init_ex(return_value, mapscript_ce_legend);
- php_legend = (php_legend_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, return_value);
php_legend->legend = legend;
php_legend->parent = parent;
@@ -275,3 +334,4 @@ PHP_MINIT_FUNCTION(legend)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/line.c b/mapscript/php/line.c
index cf73316a2..44aeb583c 100644
--- a/mapscript/php/line.c
+++ b/mapscript/php/line.c
@@ -87,7 +87,7 @@ PHP_METHOD(lineObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, getThis());
if ((php_line->line = lineObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct lineObj." TSRMLS_CC);
@@ -111,7 +111,7 @@ PHP_METHOD(lineObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
IF_GET_LONG("numpoints", php_line->line->numpoints)
else {
@@ -158,8 +158,8 @@ PHP_METHOD(lineObj, add)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zobj_point TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj_point);
status = lineObj_add(php_line->line, php_point->point);
@@ -185,7 +185,7 @@ PHP_METHOD(lineObj, addXY)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
point.x = x;
point.y = y;
@@ -220,7 +220,7 @@ PHP_METHOD(lineObj, addXYZ)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
point.x = x;
point.y = y;
@@ -255,9 +255,9 @@ PHP_METHOD(lineObj, project)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_proj_in = (php_projection_object *) zend_object_store_get_object(zobj_proj_in TSRMLS_CC);
- php_proj_out = (php_projection_object *) zend_object_store_get_object(zobj_proj_out TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
+ php_proj_in = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_in);
+ php_proj_out = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_out);
status = lineObj_project(php_line->line, php_proj_in->projection, php_proj_out->projection);
if (status != MS_SUCCESS) {
@@ -284,7 +284,7 @@ PHP_METHOD(lineObj, point)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
if ( (index < 0) || (index >= php_line->line->numpoints)) {
mapscript_throw_exception("Point '%d' does not exist in this object." TSRMLS_CC, index);
@@ -314,14 +314,14 @@ PHP_METHOD(lineObj, set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_line = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zobj);
if ( (index < 0) || (index >= php_line->line->numpoints)) {
mapscript_throw_exception("Point '%d' does not exist in this object." TSRMLS_CC, index);
return;
}
- php_point = (php_point_object *) zend_object_store_get_object(zobj_point TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj_point);
php_line->line->point[index].x = php_point->point->x;
php_line->line->point[index].y = php_point->point->y;
@@ -350,16 +350,86 @@ void mapscript_create_line(lineObj *line, parent_object parent, zval *return_val
{
php_line_object * php_line;
object_init_ex(return_value, mapscript_ce_line);
- php_line = (php_line_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, return_value);
php_line->line = line;
- if (parent.val)
+ if (ZVAL_NOT_UNDEF(parent.val))
php_line->is_ref = 1;
php_line->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_line_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_line_object *php_line;
+
+ php_line = ecalloc(1, sizeof(*php_line) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_line->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_line->zobj, ce);
+
+ php_line->zobj.handlers = &mapscript_line_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_line->parent);
+ php_line->is_ref = 0;
+
+ return &php_line->zobj;
+}
+
+static void mapscript_line_free_object(zend_object *object)
+{
+ php_line_object *php_line;
+
+ php_line = (php_line_object *)((char *)object - XtOffsetOf(php_line_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_line->parent);
+
+ if (php_line->line && !php_line->is_ref) {
+ lineObj_destroy(php_line->line);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_line_clone_object(zval *zobj)
+{
+ php_line_object *php_line_old, *php_line_new;
+ zend_object* zobj_new;
+
+ php_line_old = MAPSCRIPT_OBJ_P(php_line_object, zobj);
+
+ zobj_new = mapscript_line_create_object(mapscript_ce_line);
+ php_line_new = (php_line_object *)((char *)zobj_new - XtOffsetOf(php_line_object, zobj));
+
+ zend_objects_clone_members(&php_line_new->zobj, &php_line_old->zobj);
+
+ php_line_new->line = lineObj_clone(php_line_old->line);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(line)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "lineObj", line_functions);
+ mapscript_ce_line = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_line->create_object = mapscript_line_create_object;
+ mapscript_ce_line->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_line_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_line_object_handlers));
+ mapscript_line_object_handlers.free_obj = mapscript_line_free_object;
+ mapscript_line_object_handlers.clone_obj = mapscript_line_clone_object;
+ mapscript_line_object_handlers.offset = XtOffsetOf(php_line_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_line_object_destroy(void *object TSRMLS_DC)
{
php_line_object *php_line = (php_line_object *)object;
@@ -405,7 +475,7 @@ static zend_object_value mapscript_line_object_clone(zval *zobj TSRMLS_DC)
php_line_object *php_line_old, *php_line_new;
zend_object_value new_ov;
- php_line_old = (php_line_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_line_old = MAPSCRIPT_OBJ_P(php_line_object, zobj);
new_ov = mapscript_line_object_new_ex(mapscript_ce_line, &php_line_new TSRMLS_CC);
zend_objects_clone_members(&php_line_new->std, new_ov, &php_line_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -432,3 +502,4 @@ PHP_MINIT_FUNCTION(line)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/map.c b/mapscript/php/map.c
index aa477375a..b8fcfda86 100644
--- a/mapscript/php/map.c
+++ b/mapscript/php/map.c
@@ -312,9 +312,11 @@ ZEND_BEGIN_ARG_INFO_EX(map_removeLayer_args, 0, 0, 1)
ZEND_ARG_INFO(0, index)
ZEND_END_ARG_INFO()
+#ifdef disabled
ZEND_BEGIN_ARG_INFO_EX(map_getLabel_args, 0, 0, 1)
ZEND_ARG_INFO(0, index)
ZEND_END_ARG_INFO()
+#endif
/* {{{ proto void __construct(string mapFileName, newMapPath)
Create a new mapObj instance. */
@@ -337,7 +339,7 @@ PHP_METHOD(mapObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *)zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
map = mapObj_new(filename, path);
@@ -365,7 +367,7 @@ PHP_METHOD(mapObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
IF_GET_LONG("numlayers", php_map->map->numlayers)
else IF_GET_STRING("name", php_map->map->name)
@@ -424,7 +426,7 @@ PHP_METHOD(mapObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
IF_SET_STRING("name", php_map->map->name, value)
else IF_SET_LONG("status", php_map->map->status, value)
@@ -487,7 +489,7 @@ PHP_METHOD(mapObj, getSymbolByName)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
symbolId = mapObj_getSymbolByName(php_map->map, symbolName);
@@ -514,7 +516,7 @@ PHP_METHOD(mapObj, getSymbolObjectById)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if ( symbolId < 0 || symbolId >= php_map->map->symbolset.numsymbols) {
mapscript_throw_exception("Invalid symbol index." TSRMLS_CC);
@@ -543,7 +545,7 @@ PHP_METHOD(mapObj, prepareQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
mapObj_prepareQuery(php_map->map);
}
@@ -564,7 +566,7 @@ PHP_METHOD(mapObj, prepareImage)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_prepareImage(php_map->map);
if (image == NULL) {
@@ -593,7 +595,7 @@ PHP_METHOD(mapObj, draw)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_draw(php_map->map);
if (image == NULL) {
@@ -620,7 +622,7 @@ PHP_METHOD(mapObj, drawQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_drawQuery(php_map->map);
if (image == NULL) {
@@ -647,7 +649,7 @@ PHP_METHOD(mapObj, drawLegend)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_drawLegend(php_map->map);
if (image == NULL) {
@@ -675,7 +677,7 @@ PHP_METHOD(mapObj, drawReferenceMap)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_drawReferenceMap(php_map->map);
if (image == NULL) {
@@ -703,7 +705,7 @@ PHP_METHOD(mapObj, drawScaleBar)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
image = mapObj_drawScalebar(php_map->map);
if (image == NULL) {
@@ -734,8 +736,8 @@ PHP_METHOD(mapObj, embedLegend)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
retval = mapObj_embedLegend(php_map->map, php_image->image);
if ( (retval == MS_FAILURE) || (retval == -1) ) {
@@ -766,8 +768,8 @@ PHP_METHOD(mapObj, embedScaleBar)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
retval = mapObj_embedScalebar(php_map->map, php_image->image);
if ( (retval == MS_FAILURE) || (retval == -1) ) {
@@ -798,8 +800,8 @@ PHP_METHOD(mapObj, drawLabelCache)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
retval = mapObj_drawLabelCache(php_map->map, php_image->image);
if ( (retval == MS_FAILURE) || (retval == -1) ) {
@@ -830,7 +832,7 @@ PHP_METHOD(mapObj, getLayer)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
layer = mapObj_getLayer(php_map->map, index);
if (layer == NULL) {
@@ -864,7 +866,7 @@ PHP_METHOD(mapObj, getLayerByName)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
layer = mapObj_getLayerByName(php_map->map, layerName);
if (layer == NULL) {
@@ -898,7 +900,7 @@ PHP_METHOD(mapObj, getColorByIndex)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
palette = php_map->map->palette;
@@ -934,7 +936,7 @@ PHP_METHOD(mapObj, setExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = msMapSetExtent( php_map->map,
minx, miny,
@@ -967,8 +969,8 @@ PHP_METHOD(mapObj, setCenter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
status = mapObj_setCenter(php_map->map, php_point->point);
if (status != MS_SUCCESS) {
@@ -996,7 +998,7 @@ PHP_METHOD(mapObj, offsetExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_offsetExtent(php_map->map, x, y);
if (status != MS_SUCCESS) {
@@ -1025,7 +1027,7 @@ PHP_METHOD(mapObj, scaleExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_scaleExtent(php_map->map, zoomFactor, minScaleDenom, maxScaleDenom);
if (status != MS_SUCCESS) {
@@ -1056,7 +1058,7 @@ PHP_METHOD(mapObj, setRotation)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_setRotation(php_map->map, angle);
if (status != MS_SUCCESS) {
@@ -1086,7 +1088,7 @@ PHP_METHOD(mapObj, setSize)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = msMapSetSize(php_map->map, width, height);
if (status != MS_SUCCESS) {
@@ -1126,11 +1128,11 @@ PHP_METHOD(mapObj, zoomPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_pixelPosition = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
- php_geoRefExtent = (php_rect_object *) zend_object_store_get_object(zgeoRefExtent TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_pixelPosition = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
+ php_geoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zgeoRefExtent);
if (zmaxGeoRefExtent)
- php_maxGeoRefExtent = (php_rect_object *) zend_object_store_get_object(zmaxGeoRefExtent TSRMLS_CC);
+ php_maxGeoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zmaxGeoRefExtent);
/* -------------------------------------------------------------------- */
/* check the validity of the parameters. */
@@ -1345,11 +1347,11 @@ PHP_METHOD(mapObj, zoomRectangle)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_pixelExtent = (php_rect_object *) zend_object_store_get_object(zpixelExtent TSRMLS_CC);
- php_geoRefExtent = (php_rect_object *) zend_object_store_get_object(zgeoRefExtent TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_pixelExtent = MAPSCRIPT_OBJ_P(php_rect_object, zpixelExtent);
+ php_geoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zgeoRefExtent);
if (zmaxGeoRefExtent)
- php_maxGeoRefExtent = (php_rect_object *) zend_object_store_get_object(zmaxGeoRefExtent TSRMLS_CC);
+ php_maxGeoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zmaxGeoRefExtent);
/* -------------------------------------------------------------------- */
@@ -1540,11 +1542,11 @@ PHP_METHOD(mapObj, zoomScale)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_pixelPosition = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
- php_geoRefExtent = (php_rect_object *) zend_object_store_get_object(zgeoRefExtent TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_pixelPosition = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
+ php_geoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zgeoRefExtent);
if (zmaxGeoRefExtent)
- php_maxGeoRefExtent = (php_rect_object *) zend_object_store_get_object(zmaxGeoRefExtent TSRMLS_CC);
+ php_maxGeoRefExtent = MAPSCRIPT_OBJ_P(php_rect_object, zmaxGeoRefExtent);
/* -------------------------------------------------------------------- */
/* check the validity of the parameters. */
@@ -1771,8 +1773,8 @@ PHP_METHOD(mapObj, queryByPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
status = mapObj_queryByPoint(php_map->map, php_point->point, mode, buffer);
if (status != MS_SUCCESS) {
@@ -1800,8 +1802,8 @@ PHP_METHOD(mapObj, queryByRect)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_rect = (php_rect_object *) zend_object_store_get_object(zrect TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zrect);
status = mapObj_queryByRect(php_map->map, *(php_rect->rect));
if (status != MS_SUCCESS) {
@@ -1836,8 +1838,8 @@ PHP_METHOD(mapObj, queryByShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
status = mapObj_queryByShape(php_map->map, php_shape->shape);
if (status != MS_SUCCESS) {
@@ -1864,7 +1866,7 @@ PHP_METHOD(mapObj, queryByFeatures)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_queryByFeatures(php_map->map, slayer);
if (status != MS_SUCCESS) {
@@ -1902,7 +1904,7 @@ PHP_METHOD(mapObj, queryByIndex)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_queryByIndex(php_map->map, layerIndex,
tileIndex,
@@ -1933,7 +1935,7 @@ PHP_METHOD(mapObj, queryByFilter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_queryByFilter(php_map->map, string);
if (status != MS_SUCCESS) {
@@ -1963,7 +1965,7 @@ PHP_METHOD(mapObj, saveQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_saveQuery(php_map->map, filename, results);
@@ -1991,7 +1993,7 @@ PHP_METHOD(mapObj, saveQueryAsGML)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = msGMLWriteQuery(php_map->map, filename, namespace);
@@ -2017,7 +2019,7 @@ PHP_METHOD(mapObj, loadQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_loadQuery(php_map->map, filename);
@@ -2042,7 +2044,7 @@ PHP_METHOD(mapObj, freeQuery)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
mapObj_freeQuery(php_map->map, qlayer);
@@ -2068,7 +2070,7 @@ PHP_METHOD(mapObj, save)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_save(php_map->map, filename);
if (status != MS_SUCCESS) {
@@ -2100,7 +2102,7 @@ PHP_METHOD(mapObj, setProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapscript_map_setProjection(MS_FALSE, php_map,
projection, setUnitsAndExtents TSRMLS_CC);
@@ -2123,14 +2125,14 @@ PHP_METHOD(mapObj, getProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
projection = mapObj_getProjection(php_map->map);
if (projection == NULL) {
RETURN_NULL();
}
- RETVAL_STRING(projection, 1);
+ MAPSCRIPT_RETVAL_STRING(projection, 1);
free(projection);
}
/* }}} */
@@ -2154,7 +2156,7 @@ PHP_METHOD(mapObj, setWKTProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapscript_map_setProjection(MS_TRUE, php_map,
projection, setUnitsAndExtents TSRMLS_CC);
@@ -2169,7 +2171,7 @@ PHP_METHOD(mapObj, getMetaData)
zval *zname;
zval *zobj = getThis();
php_map_object *php_map;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -2179,12 +2181,16 @@ PHP_METHOD(mapObj, getMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_map->metadata, &php_map->map->web.metadata);
MAPSCRIPT_CALL_METHOD_1(php_map->metadata, "get", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_STRING(Z_STRVAL_P(retval),1);
+#else
+ RETURN_STRING(Z_STRVAL(retval));
+#endif
}
/* }}} */
@@ -2195,7 +2201,7 @@ PHP_METHOD(mapObj, setMetaData)
zval *zname, *zvalue;
zval *zobj = getThis();
php_map_object *php_map;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz",
@@ -2205,12 +2211,16 @@ PHP_METHOD(mapObj, setMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_map->metadata, &php_map->map->web.metadata);
MAPSCRIPT_CALL_METHOD_2(php_map->metadata, "set", retval, zname, zvalue);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -2221,7 +2231,7 @@ PHP_METHOD(mapObj, removeMetaData)
zval *zname;
zval *zobj = getThis();
php_map_object *php_map;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z",
@@ -2231,12 +2241,16 @@ PHP_METHOD(mapObj, removeMetaData)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
CHECK_OBJECT(mapscript_ce_hashtable, php_map->metadata, &php_map->map->web.metadata);
MAPSCRIPT_CALL_METHOD_1(php_map->metadata, "remove", retval, zname);
+#if PHP_VERSION_ID < 70000
RETURN_LONG(Z_LVAL_P(retval));
+#else
+ RETURN_LONG(Z_LVAL(retval));
+#endif
}
/* }}} */
@@ -2260,7 +2274,7 @@ PHP_METHOD(mapObj, getLayersIndexByGroup)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
array_init(return_value);
indexes = mapObj_getLayersIndexByGroup(php_map->map, groupName, &count);
@@ -2290,7 +2304,7 @@ PHP_METHOD(mapObj, getAllGroupNames)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
array_init(return_value);
if (php_map->map->numlayers > 0) {
@@ -2298,7 +2312,11 @@ PHP_METHOD(mapObj, getAllGroupNames)
for (i=0; i<numTok; i++) {
/* add a copy of the group name to the PHP array */
+#if PHP_VERSION_ID < 70000
add_next_index_string(return_value, groups[i], 1);
+#else
+ add_next_index_string(return_value, groups[i]);
+#endif
free(groups[i]);
}
free(groups);
@@ -2322,12 +2340,16 @@ PHP_METHOD(mapObj, getAllLayerNames)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
array_init(return_value);
count = php_map->map->numlayers;
for (i=0; i<count; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(return_value, php_map->map->layers[i]->name, 1);
+#else
+ add_next_index_string(return_value, php_map->map->layers[i]->name);
+#endif
}
}
/* }}} */
@@ -2349,7 +2371,7 @@ PHP_METHOD(mapObj, moveLayerUp)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_moveLayerup(php_map->map, index);
@@ -2374,7 +2396,7 @@ PHP_METHOD(mapObj, moveLayerDown)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_moveLayerdown(php_map->map, index);
@@ -2400,7 +2422,7 @@ PHP_METHOD(mapObj, getLayersDrawingOrder)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
array_init(return_value);
@@ -2436,7 +2458,8 @@ PHP_METHOD(mapObj, getLayersDrawingOrder)
PHP_METHOD(mapObj, setLayersDrawingOrder)
{
zval *zobj = getThis();
- zval *zindexes, **ppzval;
+ zval *zindexes;
+ MAPSCRIPT_ZVAL_P ppzval;
HashTable *indexes_hash = NULL;
int *indexes = NULL;
int numElements = 0;
@@ -2451,7 +2474,7 @@ PHP_METHOD(mapObj, setLayersDrawingOrder)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
indexes_hash = Z_ARRVAL_P(zindexes);
numElements = zend_hash_num_elements(indexes_hash);
@@ -2468,7 +2491,11 @@ PHP_METHOD(mapObj, setLayersDrawingOrder)
for(zend_hash_internal_pointer_reset(indexes_hash);
zend_hash_has_more_elements(indexes_hash) == SUCCESS;
zend_hash_move_forward(indexes_hash), ++i) {
+#if PHP_VERSION_ID < 70000
zend_hash_get_current_data(indexes_hash, (void **)&ppzval);
+#else
+ ppzval = zend_hash_get_current_data(indexes_hash);
+#endif
indexes[i] = Z_LVAL_PP(ppzval);
}
@@ -2506,7 +2533,7 @@ PHP_METHOD(mapObj, processTemplate)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
indexes_hash = Z_ARRVAL_P(zindexes);
/**
@@ -2534,7 +2561,7 @@ PHP_METHOD(mapObj, processTemplate)
} else {
// Failed for some reason
mapscript_report_php_error(E_WARNING, "processTemplate: failed reading array" TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
efree(papszNameValue);
@@ -2545,11 +2572,11 @@ PHP_METHOD(mapObj, processTemplate)
msFree(papszValue);
if (buffer) {
- RETVAL_STRING(buffer, 1);
+ MAPSCRIPT_RETVAL_STRING(buffer, 1);
free(buffer);
} else {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
}
/* }}} */
@@ -2578,7 +2605,7 @@ PHP_METHOD(mapObj, processQueryTemplate)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
indexes_hash = Z_ARRVAL_P(zindexes);
/**
@@ -2607,7 +2634,7 @@ PHP_METHOD(mapObj, processQueryTemplate)
} else {
// Failed for some reason
mapscript_report_php_error(E_WARNING, "processQueryTemplate: failed reading array" TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
efree(papszNameValue);
@@ -2619,11 +2646,11 @@ PHP_METHOD(mapObj, processQueryTemplate)
msFree(papszValue);
if (buffer) {
- RETVAL_STRING(buffer, 1);
+ MAPSCRIPT_RETVAL_STRING(buffer, 1);
free(buffer);
} else {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
}
/* }}} */
@@ -2651,7 +2678,7 @@ PHP_METHOD(mapObj, processLegendTemplate)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
indexes_hash = Z_ARRVAL_P(zindexes);
/**
@@ -2680,7 +2707,7 @@ PHP_METHOD(mapObj, processLegendTemplate)
} else {
// Failed for some reason
mapscript_report_php_error(E_WARNING, "processLegendTemplate: failed reading array" TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
efree(papszNameValue);
@@ -2692,11 +2719,11 @@ PHP_METHOD(mapObj, processLegendTemplate)
msFree(papszValue);
if (buffer) {
- RETVAL_STRING(buffer, 1);
+ MAPSCRIPT_RETVAL_STRING(buffer, 1);
free(buffer);
} else {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
}
/* }}} */
@@ -2718,7 +2745,7 @@ PHP_METHOD(mapObj, setSymbolSet)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if(filename_len > 0) {
if ((status = mapObj_setSymbolSet(php_map->map,
@@ -2748,7 +2775,7 @@ PHP_METHOD(mapObj, getNumSymbols)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
RETURN_LONG(php_map->map->symbolset.numsymbols);
}
@@ -2771,7 +2798,7 @@ PHP_METHOD(mapObj, setFontSet)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if(filename_len > 0) {
if ((status = mapObj_setFontSet(php_map->map,
@@ -2805,9 +2832,9 @@ PHP_METHOD(mapObj, selectOutputFormat)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- if (php_map->outputformat)
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(php_map->outputformat TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ if (ZVAL_NOT_UNDEF(php_map->outputformat))
+ php_outputformat = MAPSCRIPT_OBJ(php_outputformat_object, php_map->outputformat);
if ((status = mapObj_selectOutputFormat(php_map->map,
type)) != MS_SUCCESS)
@@ -2815,7 +2842,7 @@ PHP_METHOD(mapObj, selectOutputFormat)
{
mapscript_report_php_error(E_WARNING, "Unable to set output format to '%s'" TSRMLS_CC,
type);
- } else if (php_map->outputformat) {
+ } else if (ZVAL_NOT_UNDEF(php_map->outputformat)) {
php_outputformat->outputformat = php_map->map->outputformat;
}
@@ -2841,8 +2868,8 @@ PHP_METHOD(mapObj, appendOutputFormat)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zoutputformat TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zoutputformat);
retval = msAppendOutputFormat(php_map->map, php_outputformat->outputformat);
@@ -2868,7 +2895,7 @@ PHP_METHOD(mapObj, removeOutputFormat)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if ((status = msRemoveOutputFormat(php_map->map, name)) != MS_SUCCESS)
@@ -2898,7 +2925,7 @@ PHP_METHOD(mapObj, getOutputFormat)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if (index < 0 || index >= php_map->map->numoutputformats) {
mapscript_throw_mapserver_exception("Invalid outputformat index." TSRMLS_CC);
@@ -2928,7 +2955,7 @@ PHP_METHOD(mapObj, saveMapContext)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if(filename_len > 0) {
if ((status = mapObj_saveMapContext(php_map->map, filename)) != MS_SUCCESS) {
@@ -2961,7 +2988,7 @@ PHP_METHOD(mapObj, loadMapContext)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if(filename_len > 0) {
if ((status = mapObj_loadMapContext(php_map->map, filename, unique)) != MS_SUCCESS) {
@@ -2994,7 +3021,7 @@ PHP_METHOD(mapObj, applySLD)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_applySLD(php_map->map, sldxml);
@@ -3021,7 +3048,7 @@ PHP_METHOD(mapObj, applySLDURL)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
status = mapObj_applySLDURL(php_map->map, sldurl);
@@ -3044,16 +3071,16 @@ PHP_METHOD(mapObj, generateSLD)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
buffer = mapObj_generateSLD(php_map->map);
if (buffer) {
- RETVAL_STRING(buffer, 1);
+ MAPSCRIPT_RETVAL_STRING(buffer, 1);
free(buffer);
} else {
mapscript_report_mapserver_error(E_WARNING TSRMLS_CC);
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
}
/* }}} */
@@ -3078,12 +3105,12 @@ PHP_METHOD(mapObj, getConfigOption)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if ((value = (char *)msGetConfigOption(php_map->map, key)) == NULL) {
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
} else {
- RETURN_STRING(value, 1);
+ MAPSCRIPT_RETURN_STRING(value, 1);
}
}
/* }}} */
@@ -3107,7 +3134,7 @@ PHP_METHOD(mapObj, setConfigOption)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
msSetConfigOption(php_map->map, key,value);
@@ -3129,7 +3156,7 @@ PHP_METHOD(mapObj, applyConfigOptions)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
msApplyMapConfigOptions(php_map->map);
RETURN_LONG(MS_SUCCESS);
@@ -3158,8 +3185,8 @@ PHP_METHOD(mapObj, loadOwsParameters)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_request = (php_owsrequest_object *) zend_object_store_get_object(zrequest TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_request = MAPSCRIPT_OBJ_P(php_owsrequest_object, zrequest);
if (!version) {
version = strdup("1.1.1");
@@ -3193,8 +3220,8 @@ PHP_METHOD(mapObj, owsDispatch)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_request = (php_owsrequest_object *) zend_object_store_get_object(zrequest TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_request = MAPSCRIPT_OBJ_P(php_owsrequest_object, zrequest);
status = mapObj_OWSDispatch(php_map->map, php_request->cgirequest);
@@ -3221,8 +3248,8 @@ PHP_METHOD(mapObj, insertLayer)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if ((retval = mapObj_insertLayer(php_map->map, php_layer->layer, index)) < 0) {
@@ -3254,7 +3281,7 @@ PHP_METHOD(mapObj, removeLayer)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
if ((layer = mapObj_removeLayer(php_map->map, index)) == NULL) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -3287,7 +3314,7 @@ PHP_METHOD(mapObj, getLabel)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
labelCacheMember=mapObj_getLabel(php_map->map, index);
@@ -3316,14 +3343,14 @@ PHP_METHOD(mapObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
value = mapObj_convertToString(php_map->map);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -3352,7 +3379,7 @@ PHP_METHOD(mapObj, getLatLongExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
geoRefExt.minx = php_map->map->extent.minx;
geoRefExt.miny = php_map->map->extent.miny;
@@ -3389,7 +3416,7 @@ PHP_METHOD(mapObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zobj);
MAPSCRIPT_DELREF(php_map->outputformat);
MAPSCRIPT_DELREF(php_map->extent);
@@ -3505,10 +3532,10 @@ static int mapscript_map_setProjection(int isWKTProj, php_map_object *php_map,
php_projection_object *php_projection = NULL;
php_rect_object *php_extent = NULL;
- if (php_map->projection)
- php_projection = (php_projection_object *) zend_object_store_get_object(php_map->projection TSRMLS_CC);
- if (php_map->extent)
- php_extent = (php_rect_object *) zend_object_store_get_object(php_map->extent TSRMLS_CC);
+ if (ZVAL_NOT_UNDEF(php_map->projection))
+ php_projection = MAPSCRIPT_OBJ(php_projection_object, php_map->projection);
+ if (ZVAL_NOT_UNDEF(php_map->extent))
+ php_extent = MAPSCRIPT_OBJ(php_rect_object, php_map->extent);
in = php_map->map->projection;
msInitProjection(&out);
@@ -3535,7 +3562,7 @@ static int mapscript_map_setProjection(int isWKTProj, php_map_object *php_map,
if (status == -1) {
mapscript_report_php_error(E_WARNING, "setProjection failed" TSRMLS_CC);
return MS_FAILURE;
- } else if (php_map->projection) {
+ } else if (ZVAL_NOT_UNDEF(php_map->projection)) {
php_projection->projection = &(php_map->map->projection);
}
@@ -3554,7 +3581,7 @@ static int mapscript_map_setProjection(int isWKTProj, php_map_object *php_map,
msCalculateScale(php_map->map->extent, php_map->map->units, php_map->map->width, php_map->map->height,
php_map->map->resolution, &(php_map->map->scaledenom));
- if (php_map->extent)
+ if (ZVAL_NOT_UNDEF(php_map->extent))
php_extent->rect = &(php_map->map->extent);
}
}
@@ -3570,10 +3597,103 @@ void mapscript_create_map(mapObj *map, zval *return_value TSRMLS_DC)
{
php_map_object * php_map;
object_init_ex(return_value, mapscript_ce_map);
- php_map = (php_map_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, return_value);
php_map->map = map;
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_map_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_map_object *php_map;
+
+ php_map = ecalloc(1, sizeof(*php_map) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_map->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_map->zobj, ce);
+
+ php_map->zobj.handlers = &mapscript_map_object_handlers;
+
+ ZVAL_UNDEF(&php_map->outputformat);
+ ZVAL_UNDEF(&php_map->extent);
+ ZVAL_UNDEF(&php_map->web);
+ ZVAL_UNDEF(&php_map->reference);
+ ZVAL_UNDEF(&php_map->imagecolor);
+ ZVAL_UNDEF(&php_map->scalebar);
+ ZVAL_UNDEF(&php_map->legend);
+ ZVAL_UNDEF(&php_map->querymap);
+#ifdef disabled
+ ZVAL_UNDEF(&php_map->labelcache);
+#endif
+ ZVAL_UNDEF(&php_map->projection);
+ ZVAL_UNDEF(&php_map->metadata);
+ ZVAL_UNDEF(&php_map->configoptions);
+
+ return &php_map->zobj;
+}
+
+static void mapscript_map_free_object(zend_object *object)
+{
+ php_map_object *php_map;
+
+ php_map = (php_map_object *)((char *)object - XtOffsetOf(php_map_object, zobj));
+
+ MAPSCRIPT_DELREF(php_map->outputformat);
+ MAPSCRIPT_DELREF(php_map->extent);
+ MAPSCRIPT_DELREF(php_map->web);
+ MAPSCRIPT_DELREF(php_map->reference);
+ MAPSCRIPT_DELREF(php_map->imagecolor);
+ MAPSCRIPT_DELREF(php_map->scalebar);
+ MAPSCRIPT_DELREF(php_map->legend);
+ MAPSCRIPT_DELREF(php_map->querymap);
+#ifdef disabled
+ MAPSCRIPT_DELREF(php_map->labelcache);
+#endif
+ MAPSCRIPT_DELREF(php_map->projection);
+ MAPSCRIPT_DELREF(php_map->metadata);
+ MAPSCRIPT_DELREF(php_map->configoptions);
+
+ mapObj_destroy(php_map->map);
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_map_clone_object(zval *zobj)
+{
+ php_map_object *php_map_old, *php_map_new;
+ zend_object* zobj_new;
+
+ php_map_old = MAPSCRIPT_OBJ_P(php_map_object, zobj);
+
+ zobj_new = mapscript_map_create_object(mapscript_ce_map);
+ php_map_new = (php_map_object *)((char *)zobj_new - XtOffsetOf(php_map_object, zobj));
+
+ zend_objects_clone_members(&php_map_new->zobj, &php_map_old->zobj);
+
+ php_map_new->map = mapObj_clone(php_map_old->map);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(map)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "mapObj", map_functions);
+ mapscript_ce_map = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_map->create_object = mapscript_map_create_object;
+ mapscript_ce_map->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_map_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_map_object_handlers));
+ mapscript_map_object_handlers.free_obj = mapscript_map_free_object;
+ mapscript_map_object_handlers.clone_obj = mapscript_map_clone_object;
+ mapscript_map_object_handlers.offset = XtOffsetOf(php_map_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_map_object_destroy(void *object TSRMLS_DC)
{
php_map_object *php_map = (php_map_object *)object;
@@ -3641,7 +3761,7 @@ static zend_object_value mapscript_map_object_clone(zval *zobj TSRMLS_DC)
php_map_object *php_map_old, *php_map_new;
zend_object_value new_ov;
- php_map_old = (php_map_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_map_old = MAPSCRIPT_OBJ_P(php_map_object, zobj);
new_ov = mapscript_map_object_new_ex(mapscript_ce_map, &php_map_new TSRMLS_CC);
zend_objects_clone_members(&php_map_new->std, new_ov, &php_map_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -3667,4 +3787,4 @@ PHP_MINIT_FUNCTION(map)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/mapscript_error.c b/mapscript/php/mapscript_error.c
index e2bef8ae5..dccf066d6 100644
--- a/mapscript/php/mapscript_error.c
+++ b/mapscript/php/mapscript_error.c
@@ -39,7 +39,11 @@
zend_class_entry *mapscript_ce_mapscriptexception;
+#if PHP_VERSION_ID >= 70000
+zend_object* mapscript_throw_exception(char *format TSRMLS_DC, ...)
+#else
zval* mapscript_throw_exception(char *format TSRMLS_DC, ...)
+#endif
{
va_list args;
char message[MAX_EXCEPTION_MSG];
@@ -53,7 +57,11 @@ zval* mapscript_throw_exception(char *format TSRMLS_DC, ...)
return zend_throw_exception(mapscript_ce_mapscriptexception, message, 0 TSRMLS_CC);
}
+#if PHP_VERSION_ID >= 70000
+zend_object* mapscript_throw_mapserver_exception(char *format TSRMLS_DC, ...)
+#else
zval* mapscript_throw_mapserver_exception(char *format TSRMLS_DC, ...)
+#endif
{
va_list args;
char message[MAX_EXCEPTION_MSG];
@@ -111,7 +119,12 @@ PHP_MINIT_FUNCTION(mapscript_error)
zend_class_entry ce;
INIT_CLASS_ENTRY(ce, "MapScriptException", NULL);
+
+#if PHP_VERSION_ID >= 70000
+ mapscript_ce_mapscriptexception = zend_register_internal_class_ex(&ce, zend_exception_get_default(TSRMLS_C));
+#else
mapscript_ce_mapscriptexception = zend_register_internal_class_ex(&ce, zend_exception_get_default(TSRMLS_C), "Exception" TSRMLS_CC);
+#endif
return SUCCESS;
}
diff --git a/mapscript/php/outputformat.c b/mapscript/php/outputformat.c
index a6dca9435..887a2de07 100644
--- a/mapscript/php/outputformat.c
+++ b/mapscript/php/outputformat.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_outputformat;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_outputformat_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(outputformat___construct_args, 0, 0, 1)
ZEND_ARG_INFO(0, driver)
@@ -79,7 +82,7 @@ PHP_METHOD(outputFormatObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *)zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
if ((php_outputformat->outputformat = outputFormatObj_new(driver, name)) == NULL) {
mapscript_throw_exception("Unable to construct outputFormatObj." TSRMLS_CC);
@@ -103,7 +106,7 @@ PHP_METHOD(outputFormatObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
IF_GET_STRING("name", php_outputformat->outputformat->name)
@@ -136,7 +139,7 @@ PHP_METHOD(outputFormatObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
IF_SET_STRING("name", php_outputformat->outputformat->name, value)
else IF_SET_STRING("mimetype", php_outputformat->outputformat->mimetype, value)
@@ -174,7 +177,7 @@ PHP_METHOD(outputFormatObj, setOption)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
msSetOutputFormatOption(php_outputformat->outputformat, property, value);
@@ -201,11 +204,11 @@ PHP_METHOD(outputFormatObj, getOption)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
value = msGetOutputFormatOption(php_outputformat->outputformat, property, "");
- RETURN_STRING((char*)value,1);
+ MAPSCRIPT_RETURN_STRING((char*)value,1);
}
/* }}} */
@@ -226,7 +229,7 @@ PHP_METHOD(outputFormatObj, validate)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
status = msOutputFormatValidate(php_outputformat->outputformat, MS_TRUE);
if (status != MS_TRUE) {
@@ -253,19 +256,19 @@ PHP_METHOD(outputFormatObj, getOptionByIndex)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_outputformat = (php_outputformat_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zobj);
if (index < 0 || index >= php_outputformat->outputformat->numformatoptions) {
mapscript_throw_mapserver_exception("Invalid format option index." TSRMLS_CC);
return;
}
- RETURN_STRING(php_outputformat->outputformat->formatoptions[index],1);
+ MAPSCRIPT_RETURN_STRING(php_outputformat->outputformat->formatoptions[index],1);
}
/* }}} */
zend_function_entry outputformat_functions[] = {
- PHP_ME(outputFormatObj, __construct, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
+ PHP_ME(outputFormatObj, __construct, outputformat___construct_args, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
PHP_ME(outputFormatObj, __get, outputformat___get_args, ZEND_ACC_PUBLIC)
PHP_ME(outputFormatObj, __set, outputformat___set_args, ZEND_ACC_PUBLIC)
PHP_MALIAS(outputFormatObj, set, __set, NULL, ZEND_ACC_PUBLIC)
@@ -281,16 +284,69 @@ void mapscript_create_outputformat(outputFormatObj *outputformat, parent_object
{
php_outputformat_object * php_outputformat;
object_init_ex(return_value, mapscript_ce_outputformat);
- php_outputformat = (php_outputformat_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, return_value);
php_outputformat->outputformat = outputformat;
- if (parent.val)
+ if(ZVAL_NOT_UNDEF(parent.val))
php_outputformat->is_ref = 1;
php_outputformat->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_outputformat_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_outputformat_object *php_outputformat;
+
+ php_outputformat = ecalloc(1, sizeof(*php_outputformat) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_outputformat->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_outputformat->zobj, ce);
+
+ php_outputformat->zobj.handlers = &mapscript_outputformat_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_outputformat->parent);
+ php_outputformat->is_ref = 0;
+
+ return &php_outputformat->zobj;
+}
+
+static void mapscript_outputformat_free_object(zend_object *object)
+{
+ php_outputformat_object *php_outputformat;
+
+ php_outputformat = (php_outputformat_object *)((char *)object - XtOffsetOf(php_outputformat_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_outputformat->parent);
+
+ if (php_outputformat->outputformat && !php_outputformat->is_ref) {
+ outputFormatObj_destroy(php_outputformat->outputformat);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(outputformat)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "outputFormatObj", outputformat_functions);
+ mapscript_ce_outputformat = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_outputformat->create_object = mapscript_outputformat_create_object;
+ mapscript_ce_outputformat->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_outputformat_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_outputformat_object_handlers));
+ mapscript_outputformat_object_handlers.free_obj = mapscript_outputformat_free_object;
+ mapscript_outputformat_object_handlers.offset = XtOffsetOf(php_outputformat_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
+
static void mapscript_outputformat_object_destroy(void *object TSRMLS_DC)
{
php_outputformat_object *php_outputformat = (php_outputformat_object *)object;
@@ -335,3 +391,4 @@ PHP_MINIT_FUNCTION(outputformat)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/owsrequest.c b/mapscript/php/owsrequest.c
index 11d999609..ce4a05362 100644
--- a/mapscript/php/owsrequest.c
+++ b/mapscript/php/owsrequest.c
@@ -39,6 +39,9 @@
char *owsrequest_getenv(const char *name, void *thread_context);
zend_class_entry *mapscript_ce_owsrequest;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_owsrequest_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(owsrequest___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -86,7 +89,7 @@ PHP_METHOD(OWSRequestObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
if ((request = cgirequestObj_new()) == NULL) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -112,7 +115,7 @@ PHP_METHOD(OWSRequestObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
IF_GET_LONG("numparams", php_owsrequest->cgirequest->NumParams)
@@ -157,24 +160,24 @@ PHP_METHOD(OWSRequestObj, __set)
PHP_METHOD(OWSRequestObj, loadParams)
{
zval *zobj = getThis();
- zval **val;
+ MAPSCRIPT_ZVAL_P val;
php_owsrequest_object *php_owsrequest;
void *thread_context;
+ PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
+ if (zend_parse_parameters_none() == FAILURE) {
+ PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
+ return;
+ }
+ PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
+
#ifdef ZTS
thread_context = (void*)TSRMLS_C;
#else
thread_context = NULL;
#endif
- //PHP_MAPSCRIPT_ERROR_HANDLING(TRUE);
- if (zend_parse_parameters_none() == FAILURE) {
- //PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- return;
- }
- //PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
-
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
if ( (STRING_EQUAL(sapi_module.name,"cli")) ||
(STRING_EQUAL(sapi_module.name,"cgi")) ||
@@ -184,6 +187,15 @@ PHP_METHOD(OWSRequestObj, loadParams)
// check if we have input data for GET method
if (SG(request_info).request_method &&
STRING_EQUAL(SG(request_info).request_method, "GET")) {
+#if PHP_VERSION_ID >= 70000
+ zend_is_auto_global_str("_SERVER", sizeof("_SERVER")-1 TSRMLS_CC);
+ if ( !Z_ISUNDEF(PG(http_globals)[TRACK_VARS_SERVER]) &&
+ ((val = zend_hash_str_find(Z_ARRVAL(PG(http_globals)[TRACK_VARS_SERVER]), "QUERY_STRING", sizeof("QUERY_STRING")-1)) != NULL) &&
+ (Z_TYPE_P(val) == IS_STRING) &&
+ (Z_STRLEN_P(val) > 0) ) {
+ cgirequestObj_loadParams(php_owsrequest->cgirequest, owsrequest_getenv, NULL, 0, thread_context);
+ }
+#else
zend_is_auto_global("_SERVER", sizeof("_SERVER")-1 TSRMLS_CC);
if ( PG(http_globals)[TRACK_VARS_SERVER] &&
(zend_hash_find(PG(http_globals)[TRACK_VARS_SERVER]->value.ht, "QUERY_STRING", sizeof("QUERY_STRING"), (void **) &val) == SUCCESS) &&
@@ -191,24 +203,40 @@ PHP_METHOD(OWSRequestObj, loadParams)
(Z_STRLEN_PP(val) > 0) ) {
cgirequestObj_loadParams(php_owsrequest->cgirequest, owsrequest_getenv, NULL, 0, thread_context);
}
+#endif
} else {
#if PHP_VERSION_ID >= 50600
php_stream *s = php_stream_temp_new();
php_stream *input = php_stream_open_wrapper("php://input", "r", 0, NULL);
+#if PHP_VERSION_ID >= 70000
+ zend_string *raw_post_data = NULL;
+#else
char *raw_post_data = NULL;
long raw_post_data_length = 0;
+#endif
/* php://input does not support stat */
php_stream_copy_to_stream_ex(input, s, -1, NULL);
php_stream_close(input);
php_stream_rewind(s);
+
- raw_post_data_length = php_stream_copy_to_mem(s, raw_post_data, -1, 0);
+#if PHP_VERSION_ID >= 70000
+ raw_post_data = php_stream_copy_to_mem(s, -1, 0);
+
+ cgirequestObj_loadParams(php_owsrequest->cgirequest, owsrequest_getenv,
+ ZSTR_VAL(raw_post_data),
+ ZSTR_LEN(raw_post_data), thread_context);
+
+ if(raw_post_data) zend_string_free(raw_post_data);
+#else
+ raw_post_data_length = php_stream_copy_to_mem(s, raw_post_data, -1, 0);
cgirequestObj_loadParams(php_owsrequest->cgirequest, owsrequest_getenv,
raw_post_data,
raw_post_data_length, thread_context);
+#endif
#else
cgirequestObj_loadParams(php_owsrequest->cgirequest, owsrequest_getenv,
SG(request_info).raw_post_data,
@@ -240,7 +268,7 @@ PHP_METHOD(OWSRequestObj, setParameter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
cgirequestObj_setParameter(php_owsrequest->cgirequest, name, value);
@@ -267,7 +295,7 @@ PHP_METHOD(OWSRequestObj, addParameter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
cgirequestObj_addParameter(php_owsrequest->cgirequest, name, value);
@@ -276,7 +304,7 @@ PHP_METHOD(OWSRequestObj, addParameter)
/* }}} */
/* {{{ proto string owsrequest.getName(int index)
- Return the name of the parameter at index in the requests array of parameter names. */
+ Return the name of the parameter at index in the request's array of parameter names. */
PHP_METHOD(OWSRequestObj, getName)
{
long index;
@@ -292,13 +320,13 @@ PHP_METHOD(OWSRequestObj, getName)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
value = cgirequestObj_getName(php_owsrequest->cgirequest, index);
if (!value)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETURN_STRING(value,1);
+ MAPSCRIPT_RETURN_STRING(value,1);
}
/* }}} */
@@ -319,13 +347,13 @@ PHP_METHOD(OWSRequestObj, getValue)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
value = cgirequestObj_getValue(php_owsrequest->cgirequest, index);
if (!value)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETURN_STRING(value,1);
+ MAPSCRIPT_RETURN_STRING(value,1);
}
/* }}} */
@@ -347,13 +375,13 @@ PHP_METHOD(OWSRequestObj, getValueByName)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_owsrequest = (php_owsrequest_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, zobj);
value = cgirequestObj_getValueByName(php_owsrequest->cgirequest, name);
if (!value)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETURN_STRING(value,1);
+ MAPSCRIPT_RETURN_STRING(value,1);
}
/* }}} */
@@ -371,6 +399,7 @@ zend_function_entry owsrequest_functions[] = {
}
};
+#if PHP_VERSION_ID < 70000
char *owsrequest_getenv(const char *name, void *thread_context)
{
zval **val, **ppzval;
@@ -410,15 +439,108 @@ char *owsrequest_getenv(const char *name, void *thread_context)
return NULL;
}
+#else
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+char *owsrequest_getenv(const char *name, void *thread_context)
+{
+ zval *val, *ppzval;
+ zval cookie_result;
+ HashTable *cookies;
+ zend_string *string_key;
+ zend_string *result = NULL;
+ zend_ulong num_key;
+ size_t len, sum = 0;
+ int i = 0;
+ TSRMLS_FETCH_FROM_CTX(thread_context);
+
+ if (STRING_EQUAL(name, "HTTP_COOKIE")) {
+ cookies = Z_ARRVAL(PG(http_globals)[TRACK_VARS_COOKIE]);
+ for(zend_hash_internal_pointer_reset(cookies);
+ zend_hash_has_more_elements(cookies) == SUCCESS;
+ zend_hash_move_forward(cookies), ++i) {
+ ppzval = zend_hash_get_current_data(cookies);
+ zend_hash_get_current_key(cookies, &string_key, &num_key);
+ len = (ZSTR_LEN(string_key)+Z_STRLEN_P(ppzval)+2) * sizeof(char);
+ if(!result)
+ result = zend_string_alloc(len, 1);
+ else
+ result = zend_string_extend(result, sum + len, 1);
+ sprintf(&result->val[sum], "%s=%s;",ZSTR_VAL(string_key),Z_STRVAL_P(ppzval));
+ sum += len;
+ }
+ if (result){
+ ZVAL_STRINGL(&cookie_result, ZSTR_VAL(result), ZSTR_LEN(result));
+ zend_string_free(result);
+ return Z_STRVAL(cookie_result); /* this string will stay in memory until php-script exit */
+ }
+ else
+ return "";
+ } else {
+ zend_is_auto_global_str("_SERVER", sizeof("_SERVER")-1 TSRMLS_CC);
+ if ( (!Z_ISUNDEF(PG(http_globals)[TRACK_VARS_SERVER])) &&
+ ((val = zend_hash_str_find(Z_ARRVAL(PG(http_globals)[TRACK_VARS_SERVER]), name, strlen(name))) != NULL) &&
+ (Z_TYPE_P(val) == IS_STRING)) {
+ return Z_STRVAL_P(val);
+ }
+ }
+
+ return NULL;
+}
+#endif
void mapscript_create_owsrequest(cgiRequestObj *cgirequest, zval *return_value TSRMLS_DC)
{
php_owsrequest_object * php_owsrequest;
object_init_ex(return_value, mapscript_ce_owsrequest);
- php_owsrequest = (php_owsrequest_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_owsrequest = MAPSCRIPT_OBJ_P(php_owsrequest_object, return_value);
php_owsrequest->cgirequest = cgirequest;
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_owsrequest_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_owsrequest_object *php_owsrequest;
+
+ php_owsrequest = ecalloc(1, sizeof(*php_owsrequest) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_owsrequest->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_owsrequest->zobj, ce);
+
+ php_owsrequest->zobj.handlers = &mapscript_owsrequest_object_handlers;
+
+ return &php_owsrequest->zobj;
+}
+
+static void mapscript_owsrequest_free_object(zend_object *object)
+{
+ php_owsrequest_object *php_owsrequest;
+
+ php_owsrequest = (php_owsrequest_object *)((char *)object - XtOffsetOf(php_owsrequest_object, zobj));
+
+ cgirequestObj_destroy(php_owsrequest->cgirequest);
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(owsrequest)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "OWSRequestObj", owsrequest_functions);
+ mapscript_ce_owsrequest = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_owsrequest->create_object = mapscript_owsrequest_create_object;
+ mapscript_ce_owsrequest->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_owsrequest_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_owsrequest_object_handlers));
+ mapscript_owsrequest_object_handlers.free_obj = mapscript_owsrequest_free_object;
+ mapscript_owsrequest_object_handlers.offset = XtOffsetOf(php_owsrequest_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_owsrequest_object_destroy(void *object TSRMLS_DC)
{
php_owsrequest_object *php_owsrequest = (php_owsrequest_object *)object;
@@ -455,4 +577,4 @@ PHP_MINIT_FUNCTION(owsrequest)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/php_mapscript.c b/mapscript/php/php_mapscript.c
index 5ef38461f..37aa1ddea 100644
--- a/mapscript/php/php_mapscript.c
+++ b/mapscript/php/php_mapscript.c
@@ -197,9 +197,9 @@ PHP_FUNCTION(ms_newLayerObj)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *)zend_object_store_get_object(zmap TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
if (zlayer)
- php_layer = (php_layer_object *)zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if ((layer = layerObj_new(php_map->map)) == NULL) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -260,7 +260,7 @@ PHP_FUNCTION(ms_newRectObj)
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
object_init_ex(return_value, mapscript_ce_rect);
- php_rect = (php_rect_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, return_value);
if ((php_rect->rect = rectObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct rectObj." TSRMLS_CC);
@@ -314,7 +314,7 @@ PHP_FUNCTION(ms_newLineObj)
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
object_init_ex(return_value, mapscript_ce_line);
- php_line = (php_line_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, return_value);
if ((php_line->line = lineObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct lineObj." TSRMLS_CC);
@@ -342,9 +342,9 @@ PHP_FUNCTION(ms_newStyleObj)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_class = (php_class_object *)zend_object_store_get_object(zclass TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zclass);
if (zstyle)
- php_style = (php_style_object *)zend_object_store_get_object(zstyle TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zstyle);
if ((style = styleObj_new(php_class->class, (zstyle ? php_style->style : NULL))) == NULL) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -375,9 +375,9 @@ PHP_FUNCTION(ms_newClassObj)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if (zclass)
- php_class = (php_class_object *) zend_object_store_get_object(zclass TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zclass);
if ((class = classObj_new(php_layer->layer, (zclass ? php_class->class:NULL))) == NULL) {
@@ -409,7 +409,7 @@ PHP_FUNCTION(ms_newSymbolObj)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_map = (php_map_object *)zend_object_store_get_object(zmap TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
retval = msAddNewSymbol(php_map->map, symbolName);
@@ -433,7 +433,7 @@ PHP_FUNCTION(ms_newShapeObj)
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
object_init_ex(return_value, mapscript_ce_shape);
- php_shape = (php_shape_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, return_value);
if ((php_shape->shape = shapeObj_new(type)) == NULL) {
mapscript_throw_exception("Unable to construct shapeObj." TSRMLS_CC);
@@ -441,7 +441,7 @@ PHP_FUNCTION(ms_newShapeObj)
}
MAKE_STD_ZVAL(php_shape->values);
- array_init(php_shape->values);
+ mapscript_array_init(php_shape->values);
}
/* }}} */
@@ -462,7 +462,7 @@ PHP_FUNCTION(ms_shapeObjFromWkt)
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
object_init_ex(return_value, mapscript_ce_shape);
- php_shape = (php_shape_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, return_value);
if ((php_shape->shape = msShapeFromWKT(wkt)) == NULL) {
mapscript_throw_exception("Unable to construct shapeObj." TSRMLS_CC);
@@ -470,7 +470,7 @@ PHP_FUNCTION(ms_shapeObjFromWkt)
}
MAKE_STD_ZVAL(php_shape->values);
- array_init(php_shape->values);
+ mapscript_array_init(php_shape->values);
}
/* }}} */
@@ -538,7 +538,7 @@ PHP_FUNCTION(ms_newGridObj)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
php_layer->layer->connectiontype = MS_GRATICULE;
@@ -550,19 +550,29 @@ PHP_FUNCTION(ms_newGridObj)
php_layer->layer->grid = (graticuleObj *)malloc( sizeof( graticuleObj ) );
initGrid(php_layer->layer->grid);
- if (php_layer->grid && (Z_TYPE_P(php_layer->grid) == IS_OBJECT)) {
- php_grid = (php_grid_object *) zend_object_store_get_object(php_layer->grid TSRMLS_CC);
+ if (ZVAL_NOT_UNDEF(php_layer->grid) && (MAPSCRIPT_TYPE(php_layer->grid) == IS_OBJECT)) {
+ php_grid = MAPSCRIPT_OBJ(php_grid_object, php_layer->grid);
php_grid->parent.child_ptr = NULL;
+#if PHP_VERSION_ID < 70000
zend_objects_store_del_ref(php_layer->grid TSRMLS_CC);
+#else
+ MAPSCRIPT_DELREF(php_layer->grid);
+#endif
}
MAKE_STD_ZVAL(php_layer->grid);
MAPSCRIPT_MAKE_PARENT(zlayer, &php_layer->grid);
+#if PHP_VERSION_ID < 70000
mapscript_create_grid((graticuleObj *)(php_layer->layer->grid), parent, php_layer->grid TSRMLS_CC);
zend_objects_store_add_ref(php_layer->grid TSRMLS_CC);
*return_value = *(php_layer->grid);
+#else
+ mapscript_create_grid((graticuleObj *)(php_layer->layer->grid), parent, &php_layer->grid TSRMLS_CC);
+
+ ZVAL_COPY_VALUE(return_value, &php_layer->grid);
+#endif
}
/* }}} */
@@ -616,7 +626,7 @@ PHP_FUNCTION(ms_GetVersion)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- RETURN_STRING(msGetVersion(), 1);
+ MAPSCRIPT_RETURN_STRING(msGetVersion(), 1);
}
/************************************************************************/
@@ -685,7 +695,7 @@ PHP_FUNCTION(ms_ioGetStdoutBufferString)
buffer = (char *) (buf->data);
- RETURN_STRINGL(buffer, buf->data_offset, 1);
+ MAPSCRIPT_RETURN_STRINGL(buffer, buf->data_offset, 1);
}
@@ -732,12 +742,35 @@ PHP_FUNCTION(ms_ioStripStdoutBufferContentType)
buf = msIO_stripStdoutBufferContentType();
if (buf) {
- RETURN_STRING((char *)buf, 1);
+ MAPSCRIPT_RETURN_STRING((char *)buf, 1);
} else {
RETURN_FALSE;
}
}
+PHP_FUNCTION(ms_ioGetAndStripStdoutBufferMimeHeaders)
+{
+ hashTableObj *hashtable;
+ char *value, *key = NULL;
+
+ if((hashtable = msIO_getAndStripStdoutBufferMimeHeaders())) {
+
+ array_init(return_value);
+
+ while((key = hashTableObj_nextKey(hashtable, key))) {
+ value = (char *) hashTableObj_get(hashtable, key);
+#if PHP_VERSION_ID < 70000
+ add_assoc_string(return_value, key, value, 1);
+#else
+ add_assoc_string(return_value, key, value);
+#endif
+ }
+ free(hashtable);
+ }
+ else
+ RETURN_FALSE;
+}
+
PHP_FUNCTION(ms_ioStripStdoutBufferContentHeaders)
{
msIO_stripStdoutBufferContentHeaders();
@@ -783,7 +816,7 @@ PHP_FUNCTION(ms_getCwd)
RETURN_FALSE;
}
- RETURN_STRING(buffer, 1);
+ MAPSCRIPT_RETURN_STRING(buffer, 1);
}
PHP_FUNCTION(ms_getPid)
@@ -824,7 +857,7 @@ PHP_FUNCTION(ms_getScale)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_geoRefExt = (php_rect_object *)zend_object_store_get_object(zgeoRefExt TSRMLS_CC);
+ php_geoRefExt = MAPSCRIPT_OBJ_P(php_rect_object, zgeoRefExt);
if (msCalculateScale(*(php_geoRefExt->rect), unit, width, height, resolution, &dfScale) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -870,7 +903,11 @@ PHP_FUNCTION(ms_tokenizeMap)
}
for (i=0; i<numtokens; i++) {
+#if PHP_VERSION_ID < 70000
add_next_index_string(return_value, tokens[i], 1);
+#else
+ add_next_index_string(return_value, tokens[i]);
+#endif
}
msFreeCharArray(tokens, numtokens);
@@ -909,6 +946,7 @@ zend_function_entry mapscript_functions[] = {
PHP_FE(ms_ioResetHandlers, NULL)
PHP_FE(ms_ioStripStdoutBufferContentType, NULL)
PHP_FE(ms_ioStripStdoutBufferContentHeaders, NULL)
+ PHP_FE(ms_ioGetAndStripStdoutBufferMimeHeaders, NULL)
PHP_FE(ms_ioGetStdoutBufferBytes, NULL) {
NULL, NULL, NULL
}
diff --git a/mapscript/php/php_mapscript.h b/mapscript/php/php_mapscript.h
index d961fb930..740aa4899 100644
--- a/mapscript/php/php_mapscript.h
+++ b/mapscript/php/php_mapscript.h
@@ -61,6 +61,71 @@
#define MAPSCRIPT_VERSION "($Revision$ $Date$)"
+#define MAPSCRIPT_VERSION "($Revision$ $Date$)"
+
+#if PHP_VERSION_ID >= 70000
+#define MAPSCRIPT_ZVAL zval
+#define MAPSCRIPT_ZVAL_P zval*
+
+#define Z_DVAL_PP(zv) Z_DVAL_P(zv)
+#define Z_LVAL_PP(zv) Z_LVAL_P(zv)
+#define Z_STRVAL_PP(zv) Z_STRVAL_P(zv)
+
+#define MAPSCRIPT_OBJ_P(t, o) (t *)((char *)(Z_OBJ_P(o)) - XtOffsetOf(t, zobj))
+#define MAPSCRIPT_OBJ(t, o) (t *)((char *)(Z_OBJ(o)) - XtOffsetOf(t, zobj))
+#define MAPSCRIPT_RETURN_STRINGL(a, b, c) RETURN_STRINGL(a, b)
+#define MAPSCRIPT_RETURN_STRING(a, b) RETURN_STRING(a)
+#define MAPSCRIPT_RETVAL_STRING(a, b) RETVAL_STRING(a)
+#define MAPSCRIPT_RETURN_STRINGL(a, b, c) RETURN_STRINGL(a, b)
+#define MAPSCRIPT_ZVAL_STRING(a, b, c) ZVAL_STRING(a, b)
+
+#define mapscript_is_auto_global(s, l) zend_is_auto_global_str(s, l)
+#define mapscript_array_init(zv) array_init(&zv)
+#define mapscript_add_next_index_string(a, b, c) add_next_index_string(a, b)
+#define mapscript_add_assoc_string(zv, b, c, d) add_assoc_string(&zv, b, c)
+#define mapscript_hash_get_current_key(a, b, c, d) zend_hash_get_current_key(a, b, c)
+#define mapscript_hash_update(ht, keyname, data) \
+ zend_hash_str_update(ht, keyname, strlen(keyname)+1, &data);
+
+#define MAPSCRIPT_TYPE(zv) Z_TYPE(zv)
+#define MAPSCRIPT_OBJCE(zv) Z_OBJCE(zv)
+#define MAKE_STD_ZVAL(zv) ZVAL_UNDEF(&zv)
+#define ZVAL_NOT_UNDEF(zv) !(Z_ISUNDEF(zv))
+#define ZVAL_IS_UNDEF(zv) (Z_ISUNDEF(zv))
+#define ZVAL_SET_UNDEF(zv) ZVAL_UNDEF(&zv)
+#define INIT_ZVAL(zv)
+#define INIT_PZVAL(a)
+
+#else
+
+#define MAPSCRIPT_ZVAL zval*
+#define MAPSCRIPT_ZVAL_P zval**
+
+#define MAPSCRIPT_OBJ_P(t, o) (t *) zend_object_store_get_object(o TSRMLS_CC)
+#define MAPSCRIPT_OBJ(t, o) (t *) zend_object_store_get_object(o TSRMLS_CC)
+#define MAPSCRIPT_RETURN_STRINGL(a, b, c) RETURN_STRINGL(a, b, c)
+#define MAPSCRIPT_RETURN_STRING(a, b) RETURN_STRING(a, b)
+#define MAPSCRIPT_RETVAL_STRING(a, b) RETVAL_STRING(a, b)
+#define MAPSCRIPT_RETVAL_STRINGL(a, b, c) RETURN_STRINGL(a, b, c)
+#define MAPSCRIPT_ZVAL_STRING(a, b, c) ZVAL_STRING(a, b, c)
+
+#define mapscript_is_auto_global(s, l) zend_is_auto_global(s, l)
+#define mapscript_array_init(zv) array_init(zv)
+#define mapscript_add_next_index_string(a, b, c) add_next_index_string(a, b, c)
+#define mapscript_add_assoc_string(a, b, c, d) add_assoc_string(a, b, c, d)
+#define mapscript_hash_get_current_key(a, b, c, d) zend_hash_get_current_key(a, b, c, d)
+#define mapscript_hash_update(ht, key, data) \
+ zend_hash_update(Z_ARRVAL_P(return_value), key, strlen(key)+1, &data, sizeof(data), NULL)
+
+#define MAPSCRIPT_TYPE(zv) Z_TYPE_P(zv)
+#define MAPSCRIPT_OBJCE(zv) Z_OBJCE_P(zv)
+#define ZVAL_NOT_UNDEF(zv) (zv != NULL)
+#define ZVAL_IS_UNDEF(zv) (zv == NULL)
+#define ZVAL_SET_UNDEF(zv) zv = NULL
+
+#endif
+
+
extern zend_module_entry mapscript_module_entry;
#define phpext_mapscript_ptr &mapscript_module_entry
@@ -104,6 +169,252 @@ extern zend_module_entry mapscript_module_entry;
#endif
/* MapScript objects */
+#if PHP_VERSION_ID >= 70000
+typedef struct _parent_object {
+ zval val; // the zval of the parent
+ zval *child_ptr; // a ptr to a parent property, which is the zval of the child object.
+ // should be set to NULL when the child is destroyed
+} parent_object;
+
+typedef struct _php_color_object {
+ parent_object parent;
+ colorObj *color;
+ zend_object zobj;
+} php_color_object;
+
+typedef struct _php_rect_object {
+ parent_object parent;
+ int is_ref;
+ rectObj *rect;
+ zend_object zobj;
+} php_rect_object;
+
+typedef struct _php_hashtable_object {
+ parent_object parent;
+ hashTableObj *hashtable;
+ zend_object zobj;
+} php_hashtable_object;
+
+typedef struct _php_symbol_object {
+ parent_object parent;
+ symbolObj *symbol;
+ zend_object zobj;
+} php_symbol_object;
+
+typedef struct _php_class_object {
+ parent_object parent; //old layer
+ zval metadata;
+ zval leader;
+ classObj *class;
+ zend_object zobj;
+} php_class_object;
+
+typedef struct _php_image_object {
+ imageObj *image;
+ zend_object zobj;
+} php_image_object;
+
+typedef struct _php_web_object {
+ parent_object parent;
+ zval extent;
+ zval metadata;
+ zval validation;
+ webObj *web;
+ zend_object zobj;
+} php_web_object;
+
+typedef struct _php_legend_object {
+ parent_object parent;
+ zval outlinecolor;
+ zval label;
+ zval imagecolor;
+ legendObj *legend;
+ zend_object zobj;
+} php_legend_object;
+
+typedef struct _php_outputformat_object {
+ parent_object parent;
+ int is_ref;
+ outputFormatObj *outputformat;
+ zend_object zobj;
+} php_outputformat_object;
+
+typedef struct _php_querymap_object {
+ parent_object parent;
+ zval color;
+ queryMapObj *querymap;
+ zend_object zobj;
+} php_querymap_object;
+
+typedef struct _php_grid_object {
+ parent_object parent;
+ graticuleObj *grid;
+ zend_object zobj;
+} php_grid_object;
+
+typedef struct _php_error_object {
+ errorObj *error;
+ zend_object zobj;
+} php_error_object;
+
+typedef struct _php_referencemap_object {
+ parent_object parent;
+ zval extent;
+ zval color;
+ zval outlinecolor;
+ referenceMapObj *referencemap;
+ zend_object zobj;
+} php_referencemap_object;
+
+typedef struct _php_label_object {
+ parent_object parent;
+ int is_ref;
+ zval color;
+ zval outlinecolor;
+ zval shadowcolor;
+ zval backgroundcolor;
+ zval backgroundshadowcolor;
+ zval leader;
+ labelObj *label;
+ zend_object zobj;
+} php_label_object;
+
+typedef struct _php_style_object {
+ parent_object parent;
+ zval color;
+ zval outlinecolor;
+ zval backgroundcolor;
+ zval mincolor;
+ zval maxcolor;
+ styleObj *style;
+ zend_object zobj;
+} php_style_object;
+
+typedef struct _php_projection_object {
+ parent_object parent;
+ int is_ref;
+ projectionObj *projection;
+ zend_object zobj;
+} php_projection_object;
+
+typedef struct _php_point_object {
+ parent_object parent;
+ int is_ref;
+ pointObj *point;
+ zend_object zobj;
+} php_point_object;
+
+typedef struct _php_line_object {
+ parent_object parent;
+ int is_ref;
+ lineObj *line;
+ zend_object zobj;
+} php_line_object;
+
+typedef struct _php_shape_object {
+ parent_object parent;
+ zval bounds;
+ zval values;
+ int is_ref;
+ shapeObj *shape;
+ zend_object zobj;
+} php_shape_object;
+
+typedef struct _php_shapefile_object {
+ zval bounds;
+ shapefileObj *shapefile;
+ zend_object zobj;
+} php_shapefile_object;
+
+#ifdef disabled
+typedef struct _php_labelcache_object {
+ parent_object parent;
+ labelCacheObj *labelcache;
+ zend_object zobj;
+} php_labelcache_object;
+#endif
+
+typedef struct _php_labelleader_object {
+ parent_object parent;
+ labelLeaderObj *labelleader;
+ zend_object zobj;
+} php_labelleader_object;
+
+#ifdef disabled
+typedef struct _php_labelcachemember_object {
+ parent_object parent;
+ zval labels; /* should be immutable */
+ zval point; /* should be immutable */
+ zval styles; /* should be immutable */
+ zval poly; /* should be immutable */
+ labelCacheMemberObj *labelcachemember;
+ zend_object zobj;
+} php_labelcachemember_object;
+#endif
+
+typedef struct _php_result_object {
+ parent_object parent;
+ resultObj *result;
+ zend_object zobj;
+} php_result_object;
+
+typedef struct _php_scalebar_object {
+ parent_object parent;
+ zval color;
+ zval backgroundcolor;
+ zval outlinecolor;
+ zval label;
+ zval imagecolor;
+ scalebarObj *scalebar;
+ zend_object zobj;
+} php_scalebar_object;
+
+typedef struct _php_owsrequest_object {
+ cgiRequestObj *cgirequest;
+ zend_object zobj;
+} php_owsrequest_object;
+
+typedef struct _php_layer_object {
+ parent_object parent; //old map
+ zval offsite;
+ zval grid;
+ zval metadata;
+ zval bindvals;
+ zval projection;
+ zval cluster;
+ zval extent;
+ int is_ref;
+ layerObj *layer;
+ zend_object zobj;
+} php_layer_object;
+
+typedef struct _php_map_object {
+ zval outputformat;
+ zval extent;
+ zval web;
+ zval reference;
+ zval imagecolor;
+ zval scalebar;
+ zval legend;
+ zval querymap;
+#ifdef disabled
+ zval labelcache;
+#endif
+ zval projection;
+ zval metadata;
+ zval configoptions;
+ mapObj *map;
+ zend_object zobj;
+} php_map_object;
+
+typedef struct _php_cluster_object {
+ parent_object parent;
+ int is_ref;
+ clusterObj *cluster;
+ zend_object zobj;
+} php_cluster_object;
+#else
+/* PHP5 object structs */
typedef struct _parent_object {
zval *val; // the zval of the parent
zval **child_ptr; // a ptr to a parent property, which point to the child object.
@@ -347,6 +658,7 @@ typedef struct _php_cluster_object {
int is_ref;
clusterObj *cluster;
} php_cluster_object;
+#endif
/* Lifecyle functions*/
PHP_MINIT_FUNCTION(mapscript);
@@ -403,6 +715,7 @@ PHP_FUNCTION(ms_ioGetStdoutBufferString);
PHP_FUNCTION(ms_ioResetHandlers);
PHP_FUNCTION(ms_ioStripStdoutBufferContentType);
PHP_FUNCTION(ms_ioStripStdoutBufferContentHeaders);
+PHP_FUNCTION(ms_ioGetAndStripStdoutBufferMimeHeaders);
PHP_FUNCTION(ms_ioGetStdoutBufferBytes);
/* object constructors */
@@ -457,14 +770,17 @@ extern zend_class_entry *mapscript_ce_layer;
extern zend_class_entry *mapscript_ce_map;
extern zend_class_entry *mapscript_ce_cluster;
+#if PHP_VERSION_ID < 70000
/* PHP Object constructors */
extern zend_object_value mapscript_object_new(zend_object *zobj, zend_class_entry *ce,
void (*zend_objects_free_object) TSRMLS_DC);
extern zend_object_value mapscript_object_new_ex(zend_object *zobj, zend_class_entry *ce,
void (*zend_objects_free_object),
zend_object_handlers *object_handlers TSRMLS_DC);
+#endif /* PHP_VERSION_ID < 70000 */
+
extern void mapscript_fetch_object(zend_class_entry *ce, zval* zval_parent, php_layer_object* layer,
- void *internal_object, zval **php_object_storage TSRMLS_DC);
+ void *internal_object, MAPSCRIPT_ZVAL_P php_object_storage TSRMLS_DC);
extern void mapscript_create_color(colorObj *color, parent_object parent, zval *return_value TSRMLS_DC);
extern void mapscript_create_rect(rectObj *rect, parent_object php_parent, zval *return_value TSRMLS_DC);
extern void mapscript_create_hashtable(hashTableObj *hashtable, parent_object parent, zval *return_value TSRMLS_DC);
@@ -504,9 +820,17 @@ extern void mapscript_create_cluster(clusterObj *cluster, parent_object php_pare
/* Exported functions for PHP Mapscript API */
/* throw a MapScriptException */
+#if PHP_VERSION_ID >= 70000
+extern zend_object * mapscript_throw_exception(char *format TSRMLS_DC, ...);
+#else
extern zval * mapscript_throw_exception(char *format TSRMLS_DC, ...);
+#endif
/* print all MapServer errors (as Warning) and throw a MapScriptException */
+#if PHP_VERSION_ID >= 70000
+extern zend_object* mapscript_throw_mapserver_exception(char *format TSRMLS_DC, ...);
+#else
extern zval* mapscript_throw_mapserver_exception(char *format TSRMLS_DC, ...);
+#endif
extern void mapscript_report_mapserver_error(int error_type TSRMLS_DC);
extern void mapscript_report_php_error(int error_type, char *format TSRMLS_DC, ...);
diff --git a/mapscript/php/php_mapscript_util.c b/mapscript/php/php_mapscript_util.c
index fc681bd7e..eaa83b21a 100644
--- a/mapscript/php/php_mapscript_util.c
+++ b/mapscript/php/php_mapscript_util.c
@@ -31,7 +31,7 @@
#include "php_mapscript_util.h"
#include "../../maperror.h"
-
+#if PHP_VERSION_ID < 70000
zend_object_value mapscript_object_new(zend_object *zobj,
zend_class_entry *ce,
void (*zend_objects_free_object) TSRMLS_DC)
@@ -78,22 +78,37 @@ zend_object_value mapscript_object_new_ex(zend_object *zobj,
retval.handlers = object_handlers;
return retval;
}
+#endif /* PHP_VERSION_ID < 70000 */
int mapscript_extract_associative_array(HashTable *php, char **array)
{
- zval **value;
+ MAPSCRIPT_ZVAL_P value;
+#if PHP_VERSION_ID < 70000
char *string_key = NULL;
ulong num_key;
+#else
+ zend_string *string_key = NULL;
+ zend_ulong num_key;
+#endif
+
int i = 0;
for(zend_hash_internal_pointer_reset(php);
zend_hash_has_more_elements(php) == SUCCESS;
zend_hash_move_forward(php)) {
+#if PHP_VERSION_ID < 70000
zend_hash_get_current_data(php, (void **)&value);
+#else
+ value = zend_hash_get_current_data(php);
+#endif
- switch (zend_hash_get_current_key(php, &string_key, &num_key, 1)) {
+ switch (mapscript_hash_get_current_key(php, &string_key, &num_key, 1)) {
case HASH_KEY_IS_STRING:
+#if PHP_VERSION_ID < 70000
array[i++] = string_key;
+#else
+ array[i++] = ZSTR_VAL(string_key);
+#endif
array[i++] = Z_STRVAL_PP(value);
break;
}
@@ -107,64 +122,70 @@ int mapscript_extract_associative_array(HashTable *php, char **array)
otherwise it creates it */
void mapscript_fetch_object(zend_class_entry *ce, zval* zval_parent, php_layer_object* layer,
void *internal_object,
- zval **php_object_storage TSRMLS_DC)
+ MAPSCRIPT_ZVAL_P php_object_storage TSRMLS_DC)
{
parent_object p;
// create the parent struct
+#if PHP_VERSION_ID < 70000
p.val = zval_parent;
+ #define mapscript_fetch_object_return_value *php_object_storage
+#else
+ p.val = *zval_parent;
+ #define mapscript_fetch_object_return_value php_object_storage
+#endif
p.child_ptr = &*php_object_storage;
MAKE_STD_ZVAL(*php_object_storage);
if (ce == mapscript_ce_outputformat)
- mapscript_create_outputformat((outputFormatObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_outputformat((outputFormatObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_color)
- mapscript_create_color((colorObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_color((colorObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_rect)
- mapscript_create_rect((rectObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_rect((rectObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_class)
- mapscript_create_class((classObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_class((classObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_hashtable)
- mapscript_create_hashtable((hashTableObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_hashtable((hashTableObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_label)
- mapscript_create_label((labelObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_label((labelObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_style)
- mapscript_create_style((styleObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_style((styleObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_symbol)
- mapscript_create_symbol((symbolObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_symbol((symbolObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
#ifdef disabled
else if (ce == mapscript_ce_labelcachemember)
- mapscript_create_labelcachemember((labelCacheMemberObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_labelcachemember((labelCacheMemberObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_labelcache)
- mapscript_create_labelcache((labelCacheObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_labelcache((labelCacheObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
#endif
else if (ce == mapscript_ce_result)
- mapscript_create_result((resultObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_result((resultObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_scalebar)
- mapscript_create_scalebar((scalebarObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_scalebar((scalebarObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_web)
- mapscript_create_web((webObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_web((webObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_legend)
- mapscript_create_legend((legendObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_legend((legendObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_querymap)
- mapscript_create_querymap((queryMapObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_querymap((queryMapObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_grid)
- mapscript_create_grid((graticuleObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_grid((graticuleObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_referencemap)
- mapscript_create_referencemap((referenceMapObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_referencemap((referenceMapObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_point)
- mapscript_create_point((pointObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_point((pointObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_projection)
- mapscript_create_projection((projectionObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_projection((projectionObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_line)
- mapscript_create_line((lineObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_line((lineObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_shape)
- mapscript_create_shape((shapeObj*)internal_object, p, layer, *php_object_storage TSRMLS_CC);
+ mapscript_create_shape((shapeObj*)internal_object, p, layer, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_layer)
- mapscript_create_layer((layerObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_layer((layerObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_cluster)
- mapscript_create_cluster((clusterObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_cluster((clusterObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
else if (ce == mapscript_ce_labelleader)
- mapscript_create_labelleader((labelLeaderObj*)internal_object, p, *php_object_storage TSRMLS_CC);
+ mapscript_create_labelleader((labelLeaderObj*)internal_object, p, mapscript_fetch_object_return_value TSRMLS_CC);
}
diff --git a/mapscript/php/php_mapscript_util.h b/mapscript/php/php_mapscript_util.h
index 73ae02df6..bccfd169b 100644
--- a/mapscript/php/php_mapscript_util.h
+++ b/mapscript/php/php_mapscript_util.h
@@ -36,6 +36,8 @@
#include "php_globals.h"
#include "php_mapscript.h"
+#if PHP_VERSION_ID < 70000
+
#if ZEND_MODULE_API_NO < 20010901
#define TSRMLS_D void
#define TSRMLS_DC
@@ -141,9 +143,30 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
#define MAPSCRIPT_FREE_OBJECT(zobj) \
zend_hash_destroy(zobj->std.properties); \
FREE_HASHTABLE(zobj->std.properties);
+#endif /* PHP_VERSION_ID < 70000 */
+#if PHP_VERSION_ID >= 70000
+#define MAPSCRIPT_ADDREF(zv) if(!(Z_ISUNDEF(zv))) GC_REFCOUNT(Z_COUNTED(zv))++;
+#define MAPSCRIPT_ADDREF_P(zv) if(!(Z_ISUNDEF(*zv))) GC_REFCOUNT(Z_COUNTED_P(zv))++;
+#else
#define MAPSCRIPT_ADDREF(zobj) if (zobj) Z_ADDREF_P(zobj)
+#define MAPSCRIPT_ADDREF_P(zv) MAPSCRIPT_ADDREF(zv)
+#endif
+#if PHP_VERSION_ID >= 70000
+#ifndef _zval_dtor_func_for_ptr
+//use _zval_dtor_func in PHP7.1 instead
+#define _zval_dtor_func_for_ptr _zval_dtor_func
+#endif
+#define MAPSCRIPT_DELREF(zv) \
+ if (!(Z_ISUNDEF(zv))) \
+ { \
+ zend_refcounted *_gc = Z_COUNTED_P(&zv); \
+ if(--GC_REFCOUNT(_gc) == 0) \
+ _zval_dtor_func_for_ptr(_gc); \
+ ZVAL_UNDEF(&zv); \
+ }
+#else
#define MAPSCRIPT_DELREF(zobj) \
if (zobj) \
{ \
@@ -155,11 +178,25 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
} \
zobj = NULL; \
}
+#endif
+
+#if PHP_VERSION_ID >= 70000
+#define MAPSCRIPT_FREE_PARENT(parent) \
+ if (parent.child_ptr) \
+ ZVAL_UNDEF(parent.child_ptr); \
+ MAPSCRIPT_DELREF(parent.val);
+#define MAPSCRIPT_MAKE_PARENT(zobj, ptr) \
+ if(zobj == NULL) \
+ ZVAL_UNDEF(&parent.val); \
+ else \
+ ZVAL_COPY_VALUE(&parent.val, zobj); \
+ parent.child_ptr = ptr;
#define MAPSCRIPT_INIT_PARENT(parent) \
- parent.val = NULL; \
+ ZVAL_UNDEF(&parent.val); \
parent.child_ptr = NULL;
+#else
#define MAPSCRIPT_FREE_PARENT(parent) \
if (parent.child_ptr) \
@@ -170,12 +207,35 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
parent.val = zobj; \
parent.child_ptr = ptr;
+#define MAPSCRIPT_INIT_PARENT(parent) \
+ parent.val = NULL; \
+ parent.child_ptr = NULL;
+#endif
+
+#if PHP_VERSION_ID >= 70000
+
+#define MAPSCRIPT_CALL_METHOD_1(zobj, function_name, retval, arg1) \
+ zend_call_method_with_1_params(&zobj, Z_OBJCE(zobj), NULL, function_name, &retval, arg1);
+
+#define MAPSCRIPT_CALL_METHOD_2(zobj, function_name, retval, arg1, arg2) \
+ zend_call_method_with_2_params(&zobj, Z_OBJCE(zobj), NULL, function_name, &retval, arg1, arg2);
+
+#define MAPSCRIPT_CALL_METHOD_2_P(zobj, function_name, retval, arg1, arg2) \
+ zend_call_method_with_2_params(zobj, Z_OBJCE_P(zobj), NULL, function_name, &retval, arg1, arg2);
+
+#else
+
#define MAPSCRIPT_CALL_METHOD_1(zobj, function_name, retval, arg1) \
zend_call_method_with_1_params(&zobj, Z_OBJCE_P(zobj), NULL, function_name, &retval, arg1);
#define MAPSCRIPT_CALL_METHOD_2(zobj, function_name, retval, arg1, arg2) \
zend_call_method_with_2_params(&zobj, Z_OBJCE_P(zobj), NULL, function_name, &retval, arg1, arg2);
+#define MAPSCRIPT_CALL_METHOD_2_P(zobj, function_name, retval, arg1, arg2) \
+ MAPSCRIPT_CALL_METHOD_2(zobj, function_name, retval, arg1, arg2)
+
+#endif /* PHP_VERSION_ID */
+
#define STRING_EQUAL(string1, string2) \
strcmp(string1, string2) == 0
@@ -183,7 +243,7 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
#define IF_GET_STRING(property_name, value) \
if (strcmp(property, property_name)==0) \
{ \
- RETVAL_STRING( (value ? value:"") , 1); \
+ MAPSCRIPT_RETVAL_STRING( (value ? value:"") , 1); \
} \
#define IF_GET_LONG(property_name, value) \
@@ -198,6 +258,17 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
RETVAL_DOUBLE(value); \
} \
+#if PHP_VERSION_ID >= 70000
+#define IF_GET_OBJECT(property_name, mapscript_ce, php_object_storage, internal_object) \
+ if (strcmp(property, property_name)==0) \
+ { \
+ if (Z_ISUNDEF(php_object_storage)) { \
+ mapscript_fetch_object(mapscript_ce, zobj, NULL, (void*)internal_object, \
+ &php_object_storage TSRMLS_CC); \
+ } \
+ RETURN_ZVAL(&php_object_storage, 1, 0); \
+ }
+#else
#define IF_GET_OBJECT(property_name, mapscript_ce, php_object_storage, internal_object) \
if (strcmp(property, property_name)==0) \
{ \
@@ -207,12 +278,21 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
} \
RETURN_ZVAL(php_object_storage, 1, 0); \
}
+#endif
+#if PHP_VERSION_ID >= 70000
#define CHECK_OBJECT(mapscript_ce, php_object_storage, internal_object) \
- if (!php_object_storage) { \
+ if (Z_ISUNDEF(php_object_storage)) { \
mapscript_fetch_object(mapscript_ce, zobj, NULL, (void*)internal_object, \
&php_object_storage TSRMLS_CC); \
}
+#else
+#define CHECK_OBJECT(mapscript_ce, php_object_storage, internal_object) \
+ if (!php_object_storage) { \
+ mapscript_fetch_object(mapscript_ce, zobj, NULL, (void*)internal_object, \
+ &php_object_storage TSRMLS_CC); \
+ }
+#endif
/* helpers for setters */
#define IF_SET_STRING(property_name, internal, value) \
@@ -257,10 +337,11 @@ static zend_always_inline zend_bool zval_set_isref_to_p(zval* pz, zend_bool isre
internal = Z_LVAL_P(value); \
}
-
+#if PHP_VERSION_ID < 70000
zend_object_value mapscript_object_new(zend_object *zobj,
zend_class_entry *ce,
void (*zend_objects_free_object) TSRMLS_DC);
+#endif /* PHP_VERSION_ID < 70000 */
int mapscript_extract_associative_array(HashTable *php, char **array);
diff --git a/mapscript/php/point.c b/mapscript/php/point.c
index 5e6299fa8..719ffd7ae 100644
--- a/mapscript/php/point.c
+++ b/mapscript/php/point.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_point;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_point_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(point___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -94,7 +97,7 @@ PHP_METHOD(pointObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, getThis());
if ((php_point->point = pointObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct pointObj." TSRMLS_CC);
@@ -125,7 +128,7 @@ PHP_METHOD(pointObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
IF_GET_DOUBLE("x", php_point->point->x)
else IF_GET_DOUBLE("y", php_point->point->y)
@@ -154,7 +157,7 @@ PHP_METHOD(pointObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
IF_SET_DOUBLE("x", php_point->point->x, value)
else IF_SET_DOUBLE("y", php_point->point->y, value)
@@ -184,7 +187,7 @@ PHP_METHOD(pointObj, setXY)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
php_point->point->x = x;
php_point->point->y = y;
@@ -216,7 +219,7 @@ PHP_METHOD(pointObj, setXYZ)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
php_point->point->x = x;
php_point->point->y = y;
@@ -253,9 +256,9 @@ PHP_METHOD(pointObj, project)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_proj_in = (php_projection_object *) zend_object_store_get_object(zobj_proj_in TSRMLS_CC);
- php_proj_out = (php_projection_object *) zend_object_store_get_object(zobj_proj_out TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+ php_proj_in = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_in);
+ php_proj_out = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_out);
status = pointObj_project(php_point->point, php_proj_in->projection, php_proj_out->projection);
if (status != MS_SUCCESS) {
@@ -283,8 +286,8 @@ PHP_METHOD(pointObj, distanceToPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point2 = (php_point_object *) zend_object_store_get_object(zobj_point2 TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+ php_point2 = MAPSCRIPT_OBJ_P(php_point_object, zobj_point2);
distance = pointObj_distanceToPoint(php_point->point, php_point2->point);
@@ -311,9 +314,9 @@ PHP_METHOD(pointObj, distanceToLine)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_line_point = (php_point_object *) zend_object_store_get_object(zobj_line_point TSRMLS_CC);
- php_line_point2 = (php_point_object *) zend_object_store_get_object(zobj_line_point2 TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+ php_line_point = MAPSCRIPT_OBJ_P(php_point_object, zobj_line_point);
+ php_line_point2 = MAPSCRIPT_OBJ_P(php_point_object, zobj_line_point2);
distance = pointObj_distanceToLine(php_point->point, php_line_point->point, php_line_point2->point);
@@ -339,8 +342,8 @@ PHP_METHOD(pointObj, distanceToShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
distance = pointObj_distanceToShape(php_point->point, php_shape->shape);
@@ -374,10 +377,10 @@ PHP_METHOD(pointObj, draw)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_point = (php_point_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_map = (php_map_object *) zend_object_store_get_object(zmap TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
if ((status = pointObj_draw(php_point->point, php_map->map, php_layer->layer, php_image->image,
classIndex, text)) != MS_SUCCESS) {
@@ -410,16 +413,91 @@ void mapscript_create_point(pointObj *point, parent_object parent, zval *return_
{
php_point_object * php_point;
object_init_ex(return_value, mapscript_ce_point);
- php_point = (php_point_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, return_value);
php_point->point = point;
- if (parent.val)
+ if (ZVAL_NOT_UNDEF(parent.val))
php_point->is_ref = 1;
php_point->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_point_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_point_object *php_point;
+
+ php_point = ecalloc(1, sizeof(*php_point) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_point->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_point->zobj, ce);
+
+ php_point->zobj.handlers = &mapscript_point_object_handlers;
+
+ php_point->is_ref = 0;
+ MAPSCRIPT_INIT_PARENT(php_point->parent);
+
+ return &php_point->zobj;
+}
+
+static void mapscript_point_free_object(zend_object *object)
+{
+ php_point_object *php_point;
+
+ php_point = (php_point_object *)((char *)object - XtOffsetOf(php_point_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_point->parent);
+
+ if (php_point->point && !php_point->is_ref) {
+ pointObj_destroy(php_point->point);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_point_clone_object(zval *zobj)
+{
+ php_point_object *php_point_old, *php_point_new;
+ zend_object* zobj_new;
+
+ php_point_old = MAPSCRIPT_OBJ_P(php_point_object, zobj);
+
+ zobj_new = mapscript_point_create_object(mapscript_ce_point);
+ php_point_new = (php_point_object *)((char *)zobj_new - XtOffsetOf(php_point_object, zobj));
+
+ zend_objects_clone_members(&php_point_new->zobj, &php_point_old->zobj);
+
+ if ((php_point_new->point = pointObj_new()) == NULL) {
+ mapscript_throw_exception("Unable to construct pointObj." TSRMLS_CC);
+ return NULL;
+ }
+ memcpy(php_point_new->point, php_point_old->point, sizeof(pointObj));
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(point)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "pointObj", point_functions);
+ mapscript_ce_point = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_point->create_object = mapscript_point_create_object;
+ mapscript_ce_point->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_point_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_point_object_handlers));
+ mapscript_point_object_handlers.free_obj = mapscript_point_free_object;
+ mapscript_point_object_handlers.clone_obj = mapscript_point_clone_object;
+ mapscript_point_object_handlers.offset = XtOffsetOf(php_point_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
+
static void mapscript_point_object_destroy(void *object TSRMLS_DC)
{
php_point_object *php_point = (php_point_object *)object;
@@ -464,3 +542,4 @@ PHP_MINIT_FUNCTION(point)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/projection.c b/mapscript/php/projection.c
index 46b74c165..d7e9c1633 100644
--- a/mapscript/php/projection.c
+++ b/mapscript/php/projection.c
@@ -57,7 +57,7 @@ PHP_METHOD(projectionObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_projection = (php_projection_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_projection = MAPSCRIPT_OBJ_P(php_projection_object, getThis());
if ((php_projection->projection = projectionObj_new(projString)) == NULL) {
mapscript_throw_mapserver_exception("Unable to construct projectionObj." TSRMLS_CC);
@@ -82,7 +82,7 @@ PHP_METHOD(projectionObj, setWKTProjection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_projection = (php_projection_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_projection = MAPSCRIPT_OBJ_P(php_projection_object, getThis());
RETURN_LONG(msOGCWKT2ProjectionObj(wkt, php_projection->projection, MS_FALSE));
}
@@ -101,7 +101,7 @@ PHP_METHOD(projectionObj, getUnits)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_projection = (php_projection_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_projection = MAPSCRIPT_OBJ_P(php_projection_object, getThis());
RETURN_LONG(projectionObj_getUnits(php_projection->projection));
}
@@ -120,16 +120,86 @@ void mapscript_create_projection(projectionObj *projection, parent_object parent
{
php_projection_object * php_projection;
object_init_ex(return_value, mapscript_ce_projection);
- php_projection = (php_projection_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_projection = MAPSCRIPT_OBJ_P(php_projection_object, return_value);
php_projection->projection = projection;
- if (parent.val)
+ if (ZVAL_NOT_UNDEF(parent.val))
php_projection->is_ref = 1;
php_projection->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_projection_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_projection_object *php_projection;
+
+ php_projection = ecalloc(1, sizeof(*php_projection) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_projection->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_projection->zobj, ce);
+
+ php_projection->zobj.handlers = &mapscript_projection_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_projection->parent);
+ php_projection->is_ref = 0;
+
+ return &php_projection->zobj;
+}
+
+static void mapscript_projection_free_object(zend_object *object)
+{
+ php_projection_object *php_projection;
+
+ php_projection = (php_projection_object *)((char *)object - XtOffsetOf(php_projection_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_projection->parent);
+
+ if (php_projection->projection && !php_projection->is_ref) {
+ projectionObj_destroy(php_projection->projection);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_projection_clone_object(zval *zobj)
+{
+ php_projection_object *php_projection_old, *php_projection_new;
+ zend_object* zobj_new;
+
+ php_projection_old = MAPSCRIPT_OBJ_P(php_projection_object, zobj);
+
+ zobj_new = mapscript_projection_create_object(mapscript_ce_projection);
+ php_projection_new = (php_projection_object *)((char *)zobj_new - XtOffsetOf(php_projection_object, zobj));
+
+ zend_objects_clone_members(&php_projection_new->zobj, &php_projection_old->zobj);
+
+ php_projection_new->projection = projectionObj_clone(php_projection_old->projection);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(projection)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "projectionObj", projection_functions);
+ mapscript_ce_projection = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_projection->create_object = mapscript_projection_create_object;
+ mapscript_ce_projection->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_projection_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_projection_object_handlers));
+ mapscript_projection_object_handlers.free_obj = mapscript_projection_free_object;
+ mapscript_projection_object_handlers.clone_obj = mapscript_projection_clone_object;
+ mapscript_projection_object_handlers.offset = XtOffsetOf(php_projection_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_projection_object_destroy(void *object TSRMLS_DC)
{
php_projection_object *php_projection = (php_projection_object *)object;
@@ -175,7 +245,7 @@ static zend_object_value mapscript_projection_object_clone(zval *zobj TSRMLS_DC)
php_projection_object *php_projection_old, *php_projection_new;
zend_object_value new_ov;
- php_projection_old = (php_projection_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_projection_old = MAPSCRIPT_OBJ_P(php_projection_object, zobj);
new_ov = mapscript_projection_object_new_ex(mapscript_ce_projection, &php_projection_new TSRMLS_CC);
zend_objects_clone_members(&php_projection_new->std, new_ov, &php_projection_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -201,3 +271,4 @@ PHP_MINIT_FUNCTION(projection)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/querymap.c b/mapscript/php/querymap.c
index a76962b98..bd29d2a8c 100644
--- a/mapscript/php/querymap.c
+++ b/mapscript/php/querymap.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_querymap;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_querymap_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(querymap___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -69,7 +72,7 @@ PHP_METHOD(queryMapObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_querymap = (php_querymap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, zobj);
IF_GET_LONG("width", php_querymap->querymap->width)
else IF_GET_LONG("height", php_querymap->querymap->height)
@@ -97,7 +100,7 @@ PHP_METHOD(queryMapObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_querymap = (php_querymap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, zobj);
IF_SET_LONG("width", php_querymap->querymap->width, value)
else IF_SET_LONG("height", php_querymap->querymap->height, value)
@@ -128,7 +131,7 @@ PHP_METHOD(queryMapObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_querymap = (php_querymap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, zobj);
status = queryMapObj_updateFromString(php_querymap->querymap, snippet);
@@ -156,14 +159,14 @@ PHP_METHOD(queryMapObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_querymap = (php_querymap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, zobj);
value = queryMapObj_convertToString(php_querymap->querymap);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -182,7 +185,7 @@ PHP_METHOD(queryMapObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_querymap = (php_querymap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, zobj);
MAPSCRIPT_DELREF(php_querymap->color);
}
@@ -204,7 +207,7 @@ void mapscript_create_querymap(queryMapObj *querymap, parent_object parent, zval
{
php_querymap_object * php_querymap;
object_init_ex(return_value, mapscript_ce_querymap);
- php_querymap = (php_querymap_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_querymap = MAPSCRIPT_OBJ_P(php_querymap_object, return_value);
php_querymap->querymap = querymap;
php_querymap->parent = parent;
@@ -212,6 +215,59 @@ void mapscript_create_querymap(queryMapObj *querymap, parent_object parent, zval
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_querymap_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_querymap_object *php_querymap;
+
+ php_querymap = ecalloc(1, sizeof(*php_querymap) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_querymap->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_querymap->zobj, ce);
+
+ php_querymap->zobj.handlers = &mapscript_querymap_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_querymap->parent);
+ ZVAL_UNDEF(&php_querymap->color);
+
+ return &php_querymap->zobj;
+}
+
+static void mapscript_querymap_free_object(zend_object *object)
+{
+ php_querymap_object *php_querymap;
+
+ php_querymap = (php_querymap_object *)((char *)object - XtOffsetOf(php_querymap_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_querymap->parent);
+
+ MAPSCRIPT_FREE_PARENT(php_querymap->parent);
+ MAPSCRIPT_DELREF(php_querymap->color);
+
+ /* We don't need to free the queryMapObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(querymap)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "queryMapObj", querymap_functions);
+ mapscript_ce_querymap = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_querymap->create_object = mapscript_querymap_create_object;
+ mapscript_ce_querymap->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_querymap_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_querymap_object_handlers));
+ mapscript_querymap_object_handlers.free_obj = mapscript_querymap_free_object;
+ mapscript_querymap_object_handlers.offset = XtOffsetOf(php_querymap_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_querymap_object_destroy(void *object TSRMLS_DC)
{
php_querymap_object *php_querymap = (php_querymap_object *)object;
@@ -255,3 +311,4 @@ PHP_MINIT_FUNCTION(querymap)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/rect.c b/mapscript/php/rect.c
index abf44dcfc..e72a86a89 100644
--- a/mapscript/php/rect.c
+++ b/mapscript/php/rect.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_rect;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_rect_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(rect___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -80,7 +83,7 @@ PHP_METHOD(rectObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, getThis());
if ((php_rect->rect = rectObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct rectObj." TSRMLS_CC);
@@ -104,7 +107,7 @@ PHP_METHOD(rectObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
IF_GET_DOUBLE("minx", php_rect->rect->minx)
else IF_GET_DOUBLE("miny", php_rect->rect->miny)
@@ -141,10 +144,10 @@ PHP_METHOD(rectObj, draw)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_map = (php_map_object *) zend_object_store_get_object(zmap TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
if ((status = rectObj_draw(php_rect->rect, php_map->map, php_layer->layer, php_image->image,
classIndex, text)) != MS_SUCCESS) {
@@ -172,7 +175,7 @@ PHP_METHOD(rectObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
IF_SET_DOUBLE("minx", php_rect->rect->minx, value)
else IF_SET_DOUBLE("miny", php_rect->rect->miny, value)
@@ -202,9 +205,9 @@ PHP_METHOD(rectObj, project)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_proj_in = (php_projection_object *) zend_object_store_get_object(zobj_proj_in TSRMLS_CC);
- php_proj_out = (php_projection_object *) zend_object_store_get_object(zobj_proj_out TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
+ php_proj_in = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_in);
+ php_proj_out = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_out);
status = rectObj_project(php_rect->rect, php_proj_in->projection, php_proj_out->projection);
if (status != MS_SUCCESS) {
@@ -231,7 +234,7 @@ PHP_METHOD(rectObj, setExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
php_rect->rect->minx = minx;
php_rect->rect->miny = miny;
@@ -259,7 +262,7 @@ PHP_METHOD(rectObj, fit)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
retval = rectObj_fit(php_rect->rect, width, height);
@@ -282,7 +285,7 @@ PHP_METHOD(rectObj, getCenter)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_rect = (php_rect_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, getThis());
center = (pointObj *)calloc(1, sizeof(pointObj));
if (!center) {
@@ -318,16 +321,90 @@ void mapscript_create_rect(rectObj *rect, parent_object parent, zval *return_val
{
php_rect_object * php_rect;
object_init_ex(return_value, mapscript_ce_rect);
- php_rect = (php_rect_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_rect = MAPSCRIPT_OBJ_P(php_rect_object, return_value);
php_rect->rect = rect;
- if (parent.val)
+ if(ZVAL_NOT_UNDEF(parent.val))
php_rect->is_ref = 1;
php_rect->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_rect_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_rect_object *php_rect;
+
+ php_rect = ecalloc(1, sizeof(*php_rect) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_rect->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_rect->zobj, ce);
+
+ php_rect->zobj.handlers = &mapscript_rect_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_rect->parent);
+ php_rect->is_ref = 0;
+
+ return &php_rect->zobj;
+}
+
+static void mapscript_rect_free_object(zend_object *object)
+{
+ php_rect_object *php_rect;
+
+ php_rect = (php_rect_object *)((char *)object - XtOffsetOf(php_rect_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_rect->parent);
+
+ if (php_rect->rect && !php_rect->is_ref) {
+ rectObj_destroy(php_rect->rect);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_rect_clone_object(zval *zobj)
+{
+ php_rect_object *php_rect_old, *php_rect_new;
+ zend_object* zobj_new;
+
+ php_rect_old = MAPSCRIPT_OBJ_P(php_rect_object, zobj);
+
+ zobj_new = mapscript_rect_create_object(mapscript_ce_rect);
+ php_rect_new = (php_rect_object *)((char *)zobj_new - XtOffsetOf(php_rect_object, zobj));
+
+ zend_objects_clone_members(&php_rect_new->zobj, &php_rect_old->zobj);
+
+ if ((php_rect_new->rect = rectObj_new()) == NULL) {
+ mapscript_throw_exception("Unable to construct rectObj." TSRMLS_CC);
+ return NULL;
+ }
+ memcpy(php_rect_new->rect, php_rect_old->rect, sizeof(rectObj));
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(rect)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "rectObj", rect_functions);
+ mapscript_ce_rect = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_rect->create_object = mapscript_rect_create_object;
+ mapscript_ce_rect->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_rect_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_rect_object_handlers));
+ mapscript_rect_object_handlers.free_obj = mapscript_rect_free_object;
+ mapscript_rect_object_handlers.clone_obj = mapscript_rect_clone_object;
+ mapscript_rect_object_handlers.offset = XtOffsetOf(php_rect_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_rect_object_destroy(void *object TSRMLS_DC)
{
php_rect_object *php_rect = (php_rect_object *)object;
@@ -372,3 +449,4 @@ PHP_MINIT_FUNCTION(rect)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/referencemap.c b/mapscript/php/referencemap.c
index bb0b7074b..86d0afebe 100644
--- a/mapscript/php/referencemap.c
+++ b/mapscript/php/referencemap.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_referencemap;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_referencemap_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(referenceMap___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -69,7 +72,7 @@ PHP_METHOD(referenceMapObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_referencemap = (php_referencemap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, zobj);
IF_GET_STRING("image", php_referencemap->referencemap->image)
else IF_GET_LONG("width", php_referencemap->referencemap->width)
@@ -104,7 +107,7 @@ PHP_METHOD(referenceMapObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_referencemap = (php_referencemap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, zobj);
IF_SET_STRING("image", php_referencemap->referencemap->image, value)
else IF_SET_LONG("width", php_referencemap->referencemap->width, value)
@@ -142,7 +145,7 @@ PHP_METHOD(referenceMapObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_referencemap = (php_referencemap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, zobj);
status = referenceMapObj_updateFromString(php_referencemap->referencemap, snippet);
@@ -170,14 +173,14 @@ PHP_METHOD(referenceMapObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_referencemap = (php_referencemap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, zobj);
value = referenceMapObj_convertToString(php_referencemap->referencemap);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -196,7 +199,7 @@ PHP_METHOD(referenceMapObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_referencemap = (php_referencemap_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, zobj);
MAPSCRIPT_DELREF(php_referencemap->extent);
MAPSCRIPT_DELREF(php_referencemap->color);
@@ -220,13 +223,68 @@ void mapscript_create_referencemap(referenceMapObj *referencemap, parent_object
{
php_referencemap_object * php_referencemap;
object_init_ex(return_value, mapscript_ce_referencemap);
- php_referencemap = (php_referencemap_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_referencemap = MAPSCRIPT_OBJ_P(php_referencemap_object, return_value);
php_referencemap->referencemap = referencemap;
php_referencemap->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_referencemap_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_referencemap_object *php_referencemap;
+
+ php_referencemap = ecalloc(1, sizeof(*php_referencemap) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_referencemap->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_referencemap->zobj, ce);
+
+ php_referencemap->zobj.handlers = &mapscript_referencemap_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_referencemap->parent);
+ ZVAL_UNDEF(&php_referencemap->extent);
+ ZVAL_UNDEF(&php_referencemap->color);
+ ZVAL_UNDEF(&php_referencemap->outlinecolor);
+
+ return &php_referencemap->zobj;
+}
+
+static void mapscript_referencemap_free_object(zend_object *object)
+{
+ php_referencemap_object *php_referencemap;
+
+ php_referencemap = (php_referencemap_object *)((char *)object - XtOffsetOf(php_referencemap_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_referencemap->parent);
+ MAPSCRIPT_DELREF(php_referencemap->extent);
+ MAPSCRIPT_DELREF(php_referencemap->color);
+ MAPSCRIPT_DELREF(php_referencemap->outlinecolor);
+
+ /* We don't need to free the referenceMapObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(referencemap)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "referenceMapObj", referencemap_functions);
+ mapscript_ce_referencemap = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_referencemap->create_object = mapscript_referencemap_create_object;
+ mapscript_ce_referencemap->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_referencemap_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_referencemap_object_handlers));
+ mapscript_referencemap_object_handlers.free_obj = mapscript_referencemap_free_object;
+ mapscript_referencemap_object_handlers.offset = XtOffsetOf(php_referencemap_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_referencemap_object_destroy(void *object TSRMLS_DC)
{
php_referencemap_object *php_referencemap = (php_referencemap_object *)object;
@@ -274,3 +332,4 @@ PHP_MINIT_FUNCTION(referencemap)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/result.c b/mapscript/php/result.c
index 994b0596d..a0748b786 100644
--- a/mapscript/php/result.c
+++ b/mapscript/php/result.c
@@ -30,6 +30,9 @@
**********************************************************************/
#include "php_mapscript.h"
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_result_object_handlers;
+#endif
zend_class_entry *mapscript_ce_result;
@@ -62,7 +65,7 @@ PHP_METHOD(resultObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_result = (php_result_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
+ php_result = MAPSCRIPT_OBJ_P(php_result_object, getThis());
if ((php_result->result = resultObj_new()) == NULL) {
mapscript_throw_exception("Unable to construct resultObj." TSRMLS_CC);
@@ -88,7 +91,7 @@ PHP_METHOD(resultObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_result = (php_result_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_result = MAPSCRIPT_OBJ_P(php_result_object, zobj);
IF_GET_LONG("shapeindex", php_result->result->shapeindex)
else IF_GET_LONG("tileindex", php_result->result->tileindex)
@@ -136,13 +139,62 @@ void mapscript_create_result(resultObj *result, parent_object parent,
{
php_result_object * php_result;
object_init_ex(return_value, mapscript_ce_result);
- php_result = (php_result_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_result = MAPSCRIPT_OBJ_P(php_result_object, return_value);
php_result->result = result;
php_result->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_result_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_result_object *php_result;
+
+ php_result = ecalloc(1, sizeof(*php_result) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_result->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_result->zobj, ce);
+
+ php_result->zobj.handlers = &mapscript_result_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_result->parent);
+
+ return &php_result->zobj;
+}
+
+static void mapscript_result_free_object(zend_object *object)
+{
+ php_result_object *php_result;
+
+ php_result = (php_result_object *)((char *)object - XtOffsetOf(php_result_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_result->parent);
+
+ /* We don't need to free the resultObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(result)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "resultObj", result_functions);
+ mapscript_ce_result = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_result->create_object = mapscript_result_create_object;
+ mapscript_ce_result->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_result_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_result_object_handlers));
+ mapscript_result_object_handlers.free_obj = mapscript_result_free_object;
+ mapscript_result_object_handlers.offset = XtOffsetOf(php_result_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_result_object_destroy(void *object TSRMLS_DC)
{
php_result_object *php_result = (php_result_object *)object;
@@ -184,3 +236,4 @@ PHP_MINIT_FUNCTION(result)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/scalebar.c b/mapscript/php/scalebar.c
index 21b04664d..cb879266d 100644
--- a/mapscript/php/scalebar.c
+++ b/mapscript/php/scalebar.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_scalebar;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_scalebar_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(scalebar___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -75,7 +78,7 @@ PHP_METHOD(scalebarObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
IF_GET_LONG("height", php_scalebar->scalebar->height)
else IF_GET_LONG("width", php_scalebar->scalebar->width)
@@ -112,7 +115,7 @@ PHP_METHOD(scalebarObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
IF_SET_LONG("height", php_scalebar->scalebar->height, value)
else IF_SET_LONG("width", php_scalebar->scalebar->width, value)
@@ -152,7 +155,7 @@ PHP_METHOD(scalebarObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
status = scalebarObj_updateFromString(php_scalebar->scalebar, snippet);
@@ -180,14 +183,14 @@ PHP_METHOD(scalebarObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
value = scalebarObj_convertToString(php_scalebar->scalebar);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -208,7 +211,7 @@ PHP_METHOD(scalebarObj, setImageColor)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
if (red < 0 || red > 255 || green < 0 || green > 255 || blue < 0 || blue > 255)
RETURN_LONG(MS_FAILURE);
@@ -235,7 +238,7 @@ PHP_METHOD(scalebarObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_scalebar = (php_scalebar_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, zobj);
MAPSCRIPT_DELREF(php_scalebar->color);
MAPSCRIPT_DELREF(php_scalebar->backgroundcolor);
@@ -262,13 +265,72 @@ void mapscript_create_scalebar(scalebarObj *scalebar, parent_object parent, zval
{
php_scalebar_object * php_scalebar;
object_init_ex(return_value, mapscript_ce_scalebar);
- php_scalebar = (php_scalebar_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_scalebar = MAPSCRIPT_OBJ_P(php_scalebar_object, return_value);
php_scalebar->scalebar = scalebar;
php_scalebar->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_scalebar_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_scalebar_object *php_scalebar;
+
+ php_scalebar = ecalloc(1, sizeof(*php_scalebar) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_scalebar->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_scalebar->zobj, ce);
+
+ php_scalebar->zobj.handlers = &mapscript_scalebar_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_scalebar->parent);
+ ZVAL_UNDEF(&php_scalebar->color);
+ ZVAL_UNDEF(&php_scalebar->backgroundcolor);
+ ZVAL_UNDEF(&php_scalebar->outlinecolor);
+ ZVAL_UNDEF(&php_scalebar->imagecolor);
+ ZVAL_UNDEF(&php_scalebar->label);
+
+ return &php_scalebar->zobj;
+}
+
+static void mapscript_scalebar_free_object(zend_object *object)
+{
+ php_scalebar_object *php_scalebar;
+
+ php_scalebar = (php_scalebar_object *)((char *)object - XtOffsetOf(php_scalebar_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_scalebar->parent);
+ MAPSCRIPT_DELREF(php_scalebar->color);
+ MAPSCRIPT_DELREF(php_scalebar->backgroundcolor);
+ MAPSCRIPT_DELREF(php_scalebar->outlinecolor);
+ MAPSCRIPT_DELREF(php_scalebar->imagecolor);
+ MAPSCRIPT_DELREF(php_scalebar->label);
+
+ /* We don't need to free the scalebarObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(scalebar)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "scalebarObj", scalebar_functions);
+ mapscript_ce_scalebar = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_scalebar->create_object = mapscript_scalebar_create_object;
+ mapscript_ce_scalebar->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_scalebar_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_scalebar_object_handlers));
+ mapscript_scalebar_object_handlers.free_obj = mapscript_scalebar_free_object;
+ mapscript_scalebar_object_handlers.offset = XtOffsetOf(php_scalebar_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_scalebar_object_destroy(void *object TSRMLS_DC)
{
php_scalebar_object *php_scalebar = (php_scalebar_object *)object;
@@ -320,3 +382,4 @@ PHP_MINIT_FUNCTION(scalebar)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/shape.c b/mapscript/php/shape.c
index 7bf474bad..a2be5f94e 100644
--- a/mapscript/php/shape.c
+++ b/mapscript/php/shape.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_shape;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_shape_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(shape___construct_args, 0, 0, 1)
ZEND_ARG_INFO(0, type)
@@ -166,7 +169,7 @@ PHP_METHOD(shapeObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *)zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
if ((php_shape->shape = shapeObj_new(type)) == NULL) {
mapscript_throw_exception("Unable to construct shapeObj." TSRMLS_CC);
@@ -174,7 +177,7 @@ PHP_METHOD(shapeObj, __construct)
}
MAKE_STD_ZVAL(php_shape->values);
- array_init(php_shape->values);
+ mapscript_array_init(php_shape->values);
}
/* }}} */
@@ -193,7 +196,7 @@ PHP_METHOD(shapeObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
IF_GET_STRING("text", php_shape->shape->text)
else IF_GET_LONG("classindex", php_shape->shape->classindex)
@@ -226,7 +229,7 @@ PHP_METHOD(shapeObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
IF_SET_STRING("text", php_shape->shape->text, value)
else IF_SET_LONG("classindex", php_shape->shape->classindex, value)
@@ -262,8 +265,8 @@ PHP_METHOD(shapeObj, add)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_line = (php_line_object *) zend_object_store_get_object(zline TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_line = MAPSCRIPT_OBJ_P(php_line_object, zline);
retval = shapeObj_add(php_shape->shape, php_line->line);
@@ -288,7 +291,7 @@ PHP_METHOD(shapeObj, line)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
if (index < 0 || index >= php_shape->shape->numlines) {
@@ -318,8 +321,8 @@ PHP_METHOD(shapeObj, contains)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
if (!shapeObj_contains(php_shape->shape, php_point->point))
RETURN_FALSE;
@@ -344,8 +347,8 @@ PHP_METHOD(shapeObj, intersects)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (!shapeObj_intersects(php_shape->shape, php_shape2->shape))
RETURN_FALSE;
@@ -373,9 +376,9 @@ PHP_METHOD(shapeObj, project)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_proj_in = (php_projection_object *) zend_object_store_get_object(zobj_proj_in TSRMLS_CC);
- php_proj_out = (php_projection_object *) zend_object_store_get_object(zobj_proj_out TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_proj_in = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_in);
+ php_proj_out = MAPSCRIPT_OBJ_P(php_projection_object, zobj_proj_out);
status = shapeObj_project(php_shape->shape, php_proj_in->projection, php_proj_out->projection);
if (status != MS_SUCCESS) {
@@ -405,7 +408,7 @@ PHP_METHOD(shapeObj, getPointUsingMeasure)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
point = shapeObj_getpointusingmeasure(php_shape->shape, measure);
if (point == NULL)
@@ -437,8 +440,8 @@ PHP_METHOD(shapeObj, getMeasureUsingPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
intersection = shapeObj_getmeasureusingpoint(php_shape->shape, php_point->point);
if (intersection == NULL)
@@ -470,15 +473,15 @@ PHP_METHOD(shapeObj, getValue)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
if (php_shape->shape->numvalues != php_layer->layer->numitems)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
for(i=0; i<php_layer->layer->numitems; i++) {
if (strcasecmp(php_layer->layer->items[i], fieldName)==0) {
- RETURN_STRING(php_shape->shape->values[i], 1);
+ MAPSCRIPT_RETURN_STRING(php_shape->shape->values[i], 1);
}
}
}
@@ -503,7 +506,7 @@ PHP_METHOD(shapeObj, buffer)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shape = shapeObj_buffer(php_shape->shape, width);
if (shape == NULL)
@@ -531,7 +534,7 @@ PHP_METHOD(shapeObj, convexhull)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shape = shapeObj_convexHull(php_shape->shape);
if (shape == NULL)
@@ -559,7 +562,7 @@ PHP_METHOD(shapeObj, boundary)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shape = shapeObj_boundary(php_shape->shape);
if (shape == NULL)
@@ -587,8 +590,8 @@ PHP_METHOD(shapeObj, containsShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_contains_geos(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -617,8 +620,8 @@ PHP_METHOD(shapeObj, union)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
shape = shapeObj_Union(php_shape->shape, php_shape2->shape);
@@ -649,8 +652,8 @@ PHP_METHOD(shapeObj, intersection)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
shape = shapeObj_intersection(php_shape->shape, php_shape2->shape);
@@ -681,8 +684,8 @@ PHP_METHOD(shapeObj, difference)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
shape = shapeObj_difference(php_shape->shape, php_shape2->shape);
@@ -713,8 +716,8 @@ PHP_METHOD(shapeObj, symdifference)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
shape = shapeObj_symdifference(php_shape->shape, php_shape2->shape);
@@ -743,8 +746,8 @@ PHP_METHOD(shapeObj, overlaps)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_overlaps(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -770,8 +773,8 @@ PHP_METHOD(shapeObj, within)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_within(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -798,8 +801,8 @@ PHP_METHOD(shapeObj, crosses)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_crosses(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -825,8 +828,8 @@ PHP_METHOD(shapeObj, touches)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_touches(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -852,8 +855,8 @@ PHP_METHOD(shapeObj, equals)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_equals(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -879,8 +882,8 @@ PHP_METHOD(shapeObj, disjoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
if (shapeObj_disjoint(php_shape->shape, php_shape2->shape)) {
RETURN_TRUE;
@@ -905,7 +908,7 @@ PHP_METHOD(shapeObj, getCentroid)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
point = shapeObj_getcentroid(php_shape->shape);
@@ -932,7 +935,7 @@ PHP_METHOD(shapeObj, getArea)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
area = shapeObj_getarea(php_shape->shape);
@@ -955,7 +958,7 @@ PHP_METHOD(shapeObj, getLength)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
length = shapeObj_getlength(php_shape->shape);
@@ -979,7 +982,7 @@ PHP_METHOD(shapeObj, getLabelPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
point = shapeObj_getLabelPoint(php_shape->shape);
@@ -1006,16 +1009,16 @@ PHP_METHOD(shapeObj, toWkt)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
wkt = msShapeToWKT(php_shape->shape);
if (wkt) {
- RETVAL_STRING(wkt, 1);
+ MAPSCRIPT_RETVAL_STRING(wkt, 1);
msFree(wkt);
return;
}
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
}
/* }}} */
@@ -1035,7 +1038,7 @@ PHP_METHOD(shapeObj, setBounds)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shapeObj_setBounds(php_shape->shape);
@@ -1062,7 +1065,7 @@ PHP_METHOD(shapeObj, simplify)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shape = shapeObj_simplify(php_shape->shape, tolerance);
if (shape == NULL)
@@ -1092,7 +1095,7 @@ PHP_METHOD(shapeObj, topologyPreservingSimplify)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
shape = shapeObj_topologypreservingsimplify(php_shape->shape, tolerance);
if (shape == NULL)
@@ -1125,10 +1128,10 @@ PHP_METHOD(shapeObj, draw)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_map = (php_map_object *) zend_object_store_get_object(zmap TSRMLS_CC);
- php_layer = (php_layer_object *) zend_object_store_get_object(zlayer TSRMLS_CC);
- php_image = (php_image_object *) zend_object_store_get_object(zimage TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
+ php_layer = MAPSCRIPT_OBJ_P(php_layer_object, zlayer);
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
if ((status = shapeObj_draw(php_shape->shape, php_map->map, php_layer->layer,
php_image->image)) != MS_SUCCESS) {
@@ -1154,7 +1157,7 @@ PHP_METHOD(shapeObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
MAPSCRIPT_DELREF(php_shape->bounds);
}
@@ -1177,8 +1180,8 @@ PHP_METHOD(shapeObj, distanceToPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
RETURN_DOUBLE(msDistancePointToShape(php_point->point, php_shape->shape));
}
@@ -1201,8 +1204,8 @@ PHP_METHOD(shapeObj, distanceToShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shape = (php_shape_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape2 = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zobj);
+ php_shape2 = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
RETURN_DOUBLE(msGEOSDistance(php_shape->shape, php_shape2->shape));
}
@@ -1259,17 +1262,17 @@ void mapscript_create_shape(shapeObj *shape, parent_object parent, php_layer_obj
int i;
object_init_ex(return_value, mapscript_ce_shape);
- php_shape = (php_shape_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, return_value);
php_shape->shape = shape;
MAKE_STD_ZVAL(php_shape->values);
- array_init(php_shape->values);
+ mapscript_array_init(php_shape->values);
if (php_layer) {
if ((php_shape->shape->numvalues == php_layer->layer->numitems) ||
(php_shape->shape->numvalues == 0 && php_layer->layer->numitems == -1)) {
for(i=0; i<php_shape->shape->numvalues; i++) {
- add_assoc_string(php_shape->values, php_layer->layer->items[i], php_shape->shape->values[i], 1);
+ mapscript_add_assoc_string(php_shape->values, php_layer->layer->items[i], php_shape->shape->values[i], 1);
}
} else {
mapscript_throw_exception("Assertion failed, Could not set shape values: %d, %d" TSRMLS_CC,
@@ -1278,13 +1281,70 @@ void mapscript_create_shape(shapeObj *shape, parent_object parent, php_layer_obj
}
}
- if (parent.val)
+ if (ZVAL_NOT_UNDEF(parent.val))
php_shape->is_ref = 1;
php_shape->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_shape_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_shape_object *php_shape;
+
+ php_shape = ecalloc(1, sizeof(*php_shape) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_shape->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_shape->zobj, ce);
+
+ php_shape->zobj.handlers = &mapscript_shape_object_handlers;
+
+ php_shape->is_ref = 0;
+ MAPSCRIPT_INIT_PARENT(php_shape->parent);
+ ZVAL_UNDEF(&php_shape->bounds);
+ ZVAL_UNDEF(&php_shape->values);
+
+
+ return &php_shape->zobj;
+}
+
+static void mapscript_shape_free_object(zend_object *object)
+{
+ php_shape_object *php_shape;
+
+ php_shape = (php_shape_object *)((char *)object - XtOffsetOf(php_shape_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_shape->parent);
+ MAPSCRIPT_DELREF(php_shape->bounds);
+ MAPSCRIPT_DELREF(php_shape->values);
+
+ if (php_shape->shape && !php_shape->is_ref) {
+ shapeObj_destroy(php_shape->shape);
+ }
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(shape)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "shapeObj", shape_functions);
+ mapscript_ce_shape = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_shape->create_object = mapscript_shape_create_object;
+ mapscript_ce_shape->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_shape_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_shape_object_handlers));
+ mapscript_shape_object_handlers.free_obj = mapscript_shape_free_object;
+ mapscript_shape_object_handlers.offset = XtOffsetOf(php_shape_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_shape_object_destroy(void *object TSRMLS_DC)
{
php_shape_object *php_shape = (php_shape_object *)object;
@@ -1333,3 +1393,4 @@ PHP_MINIT_FUNCTION(shape)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/shapefile.c b/mapscript/php/shapefile.c
index 89aceff2a..233809840 100644
--- a/mapscript/php/shapefile.c
+++ b/mapscript/php/shapefile.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_shapefile;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_shapefile_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(shapefile___construct_args, 0, 0, 2)
ZEND_ARG_INFO(0, filename)
@@ -90,7 +93,7 @@ PHP_METHOD(shapeFileObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *)zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
php_shapefile->shapefile = shapefileObj_new(filename, type);
@@ -116,7 +119,7 @@ PHP_METHOD(shapeFileObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
IF_GET_LONG("numshapes", php_shapefile->shapefile->numshapes)
else IF_GET_LONG("type", php_shapefile->shapefile->type)
@@ -173,7 +176,7 @@ PHP_METHOD(shapeFileObj, getShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
/* Create a new shapeObj to hold the result
* Note that the type used to create the shape (MS_NULL) does not matter
@@ -213,7 +216,7 @@ PHP_METHOD(shapeFileObj, getPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
/* Create a new shapeObj to hold the result
* Note that the type used to create the shape (MS_NULL) does not matter
@@ -256,7 +259,7 @@ PHP_METHOD(shapeFileObj, getExtent)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
/* Create a new rectObj to hold the result */
if ((rect = rectObj_new()) == NULL) {
@@ -293,8 +296,8 @@ PHP_METHOD(shapeFileObj, addShape)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_shape = (php_shape_object *) zend_object_store_get_object(zshape TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
+ php_shape = MAPSCRIPT_OBJ_P(php_shape_object, zshape);
retval = shapefileObj_add(php_shapefile->shapefile, php_shape->shape);
@@ -320,8 +323,8 @@ PHP_METHOD(shapeFileObj, addPoint)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_point = (php_point_object *) zend_object_store_get_object(zpoint TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
+ php_point = MAPSCRIPT_OBJ_P(php_point_object, zpoint);
retval = shapefileObj_addPoint(php_shapefile->shapefile, php_point->point);
@@ -349,8 +352,8 @@ PHP_METHOD(shapeFileObj, getTransformed)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
- php_map = (php_map_object *) zend_object_store_get_object(zmap TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
/* Create a new shapeObj to hold the result
* Note that the type used to create the shape (MS_NULL) does not matter
@@ -389,7 +392,7 @@ PHP_METHOD(shapeFileObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_shapefile = (php_shapefile_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, zobj);
MAPSCRIPT_DELREF(php_shapefile->bounds);
}
@@ -416,10 +419,59 @@ void mapscript_create_shapefile(shapefileObj *shapefile, zval *return_value TSRM
php_shapefile_object * php_shapefile;
object_init_ex(return_value, mapscript_ce_shapefile);
- php_shapefile = (php_shapefile_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_shapefile = MAPSCRIPT_OBJ_P(php_shapefile_object, return_value);
php_shapefile->shapefile = shapefile;
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_shapefile_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_shapefile_object *php_shapefile;
+
+ php_shapefile = ecalloc(1, sizeof(*php_shapefile) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_shapefile->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_shapefile->zobj, ce);
+
+ php_shapefile->zobj.handlers = &mapscript_shapefile_object_handlers;
+
+ ZVAL_UNDEF(&php_shapefile->bounds);
+
+ return &php_shapefile->zobj;
+}
+
+static void mapscript_shapefile_free_object(zend_object *object)
+{
+ php_shapefile_object *php_shapefile;
+
+ php_shapefile = (php_shapefile_object *)((char *)object - XtOffsetOf(php_shapefile_object, zobj));
+
+ MAPSCRIPT_DELREF(php_shapefile->bounds);
+
+ shapefileObj_destroy(php_shapefile->shapefile);
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(shapefile)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "shapefileObj", shapefile_functions);
+ mapscript_ce_shapefile = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_shapefile->create_object = mapscript_shapefile_create_object;
+ mapscript_ce_shapefile->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_shapefile_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_shapefile_object_handlers));
+ mapscript_shapefile_object_handlers.free_obj = mapscript_shapefile_free_object;
+ mapscript_shapefile_object_handlers.offset = XtOffsetOf(php_shapefile_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_shapefile_object_destroy(void *object TSRMLS_DC)
{
php_shapefile_object *php_shapefile = (php_shapefile_object *)object;
@@ -461,3 +513,4 @@ PHP_MINIT_FUNCTION(shapefile)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/style.c b/mapscript/php/style.c
index b5a53f179..963718b9e 100644
--- a/mapscript/php/style.c
+++ b/mapscript/php/style.c
@@ -94,19 +94,19 @@ PHP_METHOD(styleObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *)zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if (Z_TYPE_P(zparent) == IS_OBJECT && Z_OBJCE_P(zparent) == mapscript_ce_class)
- php_class = (php_class_object *)zend_object_store_get_object(zparent TSRMLS_CC);
+ php_class = MAPSCRIPT_OBJ_P(php_class_object, zparent);
else if (Z_TYPE_P(zparent) == IS_OBJECT && Z_OBJCE_P(zparent) == mapscript_ce_label)
- php_label = (php_label_object *)zend_object_store_get_object(zparent TSRMLS_CC);
+ php_label = MAPSCRIPT_OBJ_P(php_label_object, zparent);
else {
mapscript_throw_mapserver_exception("Invalid argument 1: should be a classObj or labelObj" TSRMLS_CC);
return;
}
if (zstyle)
- php_style2 = (php_style_object *)zend_object_store_get_object(zstyle TSRMLS_CC);
+ php_style2 = MAPSCRIPT_OBJ_P(php_style_object, zstyle);
if (php_class) {
if ((style = styleObj_new(php_class->class, (zstyle ? php_style2->style : NULL))) == NULL) {
@@ -124,7 +124,7 @@ PHP_METHOD(styleObj, __construct)
MAPSCRIPT_MAKE_PARENT(zparent, NULL);
php_style->parent = parent;
- MAPSCRIPT_ADDREF(zparent);
+ MAPSCRIPT_ADDREF_P(zparent);
}
/* }}} */
@@ -143,7 +143,7 @@ PHP_METHOD(styleObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
IF_GET_LONG("symbol", php_style->style->symbol)
else IF_GET_STRING("symbolname", php_style->style->symbolname)
@@ -207,7 +207,7 @@ PHP_METHOD(styleObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
IF_SET_LONG("symbol", php_style->style->symbol, value)
else IF_SET_DOUBLE("size", php_style->style->size, value)
@@ -259,24 +259,24 @@ PHP_METHOD(styleObj, __set)
php_style->style->symbolname = strdup(Z_STRVAL_P(value));
/* The parent can be a classObj or a labelCacheMemberObj */
- if (Z_OBJCE_P(php_style->parent.val) == mapscript_ce_class) {
- php_class = (php_class_object *) zend_object_store_get_object(php_style->parent.val TSRMLS_CC);
+ if (MAPSCRIPT_OBJCE(php_style->parent.val) == mapscript_ce_class) {
+ php_class = MAPSCRIPT_OBJ(php_class_object, php_style->parent.val);
/* Can a class have no layer object ? */
- php_layer = (php_layer_object *) zend_object_store_get_object(php_class->parent.val TSRMLS_CC);
- if (!php_layer->parent.val) {
+ php_layer = MAPSCRIPT_OBJ(php_layer_object, php_class->parent.val);
+ if (ZVAL_IS_UNDEF(php_layer->parent.val)) {
mapscript_throw_exception("No map object associated with this style object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_layer->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_layer->parent.val);
#ifdef disabled
- } else if (Z_OBJCE_P(php_style->parent.val) == mapscript_ce_labelcachemember) {
+ } else if (MAPSCRIPT_OBJCE(php_style->parent.val) == mapscript_ce_labelcachemember) {
/* The parent is always a map */
- php_labelcachemember = (php_labelcachemember_object *) zend_object_store_get_object(php_style->parent.val TSRMLS_CC);
- if (!php_labelcachemember->parent.val) {
+ php_labelcachemember = MAPSCRIPT_OBJ(php_labelcachemember_object, php_style->parent.val);
+ if (ZVAL_NOT_UNDEF(php_labelcachemember->parent.val)) {
mapscript_throw_exception("No map object associated with this style object." TSRMLS_CC);
return;
}
- php_map = (php_map_object *) zend_object_store_get_object(php_labelcachemember->parent.val TSRMLS_CC);
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_labelcachemember->parent.val);
#endif
}
@@ -308,7 +308,7 @@ PHP_METHOD(styleObj, updateFromString)
char *snippet;
long snippet_len = 0;
int status = MS_FAILURE;
- zval *retval;
+ MAPSCRIPT_ZVAL retval;
zval property_name, value;
php_style_object *php_style;
@@ -320,7 +320,7 @@ PHP_METHOD(styleObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if ((status = styleObj_updateFromString(php_style->style, snippet)) != MS_SUCCESS) {
mapscript_throw_mapserver_exception("" TSRMLS_CC);
@@ -331,9 +331,9 @@ PHP_METHOD(styleObj, updateFromString)
if (php_style->style->symbolname) {
INIT_ZVAL(property_name);
INIT_ZVAL(value);
- ZVAL_STRING(&property_name, "symbolname", 1);
- ZVAL_STRING(&value, php_style->style->symbolname, 1);
- MAPSCRIPT_CALL_METHOD_2(zobj, "__set", retval, &property_name, &value);
+ MAPSCRIPT_ZVAL_STRING(&property_name, "symbolname", 1);
+ MAPSCRIPT_ZVAL_STRING(&value, php_style->style->symbolname, 1);
+ MAPSCRIPT_CALL_METHOD_2_P(zobj, "__set", retval, &property_name, &value);
}
RETURN_LONG(status);
@@ -355,14 +355,14 @@ PHP_METHOD(styleObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
value = styleObj_convertToString(php_style->style);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -385,7 +385,7 @@ PHP_METHOD(styleObj, setBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if (bindingId < 0 || bindingId > MS_STYLE_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -428,7 +428,7 @@ PHP_METHOD(styleObj, getBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if (bindingId < 0 || bindingId > MS_STYLE_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -436,7 +436,7 @@ PHP_METHOD(styleObj, getBinding)
}
if( (value = php_style->style->bindings[bindingId].item) != NULL) {
- RETURN_STRING(value, 1);
+ MAPSCRIPT_RETURN_STRING(value, 1);
}
RETURN_NULL();
@@ -460,7 +460,7 @@ PHP_METHOD(styleObj, removeBinding)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if (bindingId < 0 || bindingId > MS_STYLE_BINDING_LENGTH) {
mapscript_throw_exception("Invalid binding id." TSRMLS_CC);
@@ -494,7 +494,7 @@ PHP_METHOD(styleObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
MAPSCRIPT_DELREF(php_style->color);
MAPSCRIPT_DELREF(php_style->outlinecolor);
@@ -516,13 +516,13 @@ PHP_METHOD(styleObj, getGeomTransform)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
if (php_style->style->_geomtransform.type == MS_GEOMTRANSFORM_NONE ||
!php_style->style->_geomtransform.string)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETURN_STRING(php_style->style->_geomtransform.string, 1);
+ MAPSCRIPT_RETURN_STRING(php_style->style->_geomtransform.string, 1);
}
/* }}} */
@@ -543,7 +543,7 @@ PHP_METHOD(styleObj, setGeomTransform)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
styleObj_setGeomTransform(php_style->style, transform);
}
@@ -553,7 +553,8 @@ PHP_METHOD(styleObj, setGeomTransform)
Set the pattern of the style ) */
PHP_METHOD(styleObj, setPattern)
{
- zval *zpattern, **ppzval;
+ zval *zpattern;
+ MAPSCRIPT_ZVAL_P ppzval;
HashTable *pattern_hash = NULL;
zval *zobj = getThis();
int index = 0, numelements = 0;
@@ -567,7 +568,7 @@ PHP_METHOD(styleObj, setPattern)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
pattern_hash = Z_ARRVAL_P(zpattern);
numelements = zend_hash_num_elements(pattern_hash);
@@ -581,9 +582,15 @@ PHP_METHOD(styleObj, setPattern)
zend_hash_has_more_elements(pattern_hash) == SUCCESS;
zend_hash_move_forward(pattern_hash)) {
+#if PHP_VERSION_ID < 70000
zend_hash_get_current_data(pattern_hash, (void **)&ppzval);
if (Z_TYPE_PP(ppzval) != IS_LONG)
convert_to_long(*ppzval);
+#else
+ ppzval = zend_hash_get_current_data(pattern_hash);
+ if (Z_TYPE_P(ppzval) != IS_DOUBLE)
+ convert_to_double(ppzval);
+#endif
php_style->style->pattern[index] = Z_LVAL_PP(ppzval);
index++;
@@ -610,7 +617,7 @@ PHP_METHOD(styleObj, getPatternArray)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_style = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, zobj);
array_init(return_value);
@@ -646,7 +653,7 @@ void mapscript_create_style(styleObj *style, parent_object parent, zval *return_
{
php_style_object * php_style;
object_init_ex(return_value, mapscript_ce_style);
- php_style = (php_style_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_style = MAPSCRIPT_OBJ_P(php_style_object, return_value);
php_style->style = style;
php_style->parent = parent;
@@ -654,6 +661,79 @@ void mapscript_create_style(styleObj *style, parent_object parent, zval *return_
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_style_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_style_object *php_style;
+
+ php_style = ecalloc(1, sizeof(*php_style) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_style->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_style->zobj, ce);
+
+ php_style->zobj.handlers = &mapscript_style_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_style->parent);
+ ZVAL_UNDEF(&php_style->color);
+ ZVAL_UNDEF(&php_style->outlinecolor);
+ ZVAL_UNDEF(&php_style->backgroundcolor);
+
+ return &php_style->zobj;
+}
+
+static void mapscript_style_free_object(zend_object *object)
+{
+ php_style_object *php_style;
+
+ php_style = (php_style_object *)((char *)object - XtOffsetOf(php_style_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_style->parent);
+ MAPSCRIPT_DELREF(php_style->color);
+ MAPSCRIPT_DELREF(php_style->outlinecolor);
+ MAPSCRIPT_DELREF(php_style->backgroundcolor);
+
+ /* We don't need to free the styleObj, the mapObj will do it */
+
+ zend_object_std_dtor(object);
+}
+
+static zend_object* mapscript_style_clone_object(zval *zobj)
+{
+ php_style_object *php_style_old, *php_style_new;
+ zend_object* zobj_new;
+
+ php_style_old = MAPSCRIPT_OBJ_P(php_style_object, zobj);
+
+ zobj_new = mapscript_style_create_object(mapscript_ce_style);
+ php_style_new = (php_style_object *)((char *)zobj_new - XtOffsetOf(php_style_object, zobj));
+
+ zend_objects_clone_members(&php_style_new->zobj, &php_style_old->zobj);
+
+ php_style_new->style = styleObj_clone(php_style_old->style);
+
+ return zobj_new;
+}
+
+PHP_MINIT_FUNCTION(style)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "styleObj", style_functions);
+ mapscript_ce_style = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_style->create_object = mapscript_style_create_object;
+ mapscript_ce_style->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_style_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_style_object_handlers));
+ mapscript_style_object_handlers.free_obj = mapscript_style_free_object;
+ mapscript_style_object_handlers.clone_obj = mapscript_style_clone_object;
+ mapscript_style_object_handlers.offset = XtOffsetOf(php_style_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_style_object_destroy(void *object TSRMLS_DC)
{
php_style_object *php_style = (php_style_object *)object;
@@ -701,7 +781,7 @@ static zend_object_value mapscript_style_object_clone(zval *zobj TSRMLS_DC)
php_style_object *php_style_old, *php_style_new;
zend_object_value new_ov;
- php_style_old = (php_style_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_style_old = MAPSCRIPT_OBJ_P(php_style_object, zobj);
new_ov = mapscript_style_object_new_ex(mapscript_ce_style, &php_style_new TSRMLS_CC);
zend_objects_clone_members(&php_style_new->std, new_ov, &php_style_old->std, Z_OBJ_HANDLE_P(zobj) TSRMLS_CC);
@@ -727,4 +807,4 @@ PHP_MINIT_FUNCTION(style)
return SUCCESS;
}
-
+#endif
diff --git a/mapscript/php/symbol.c b/mapscript/php/symbol.c
index 8b53ec9b5..6928e1168 100644
--- a/mapscript/php/symbol.c
+++ b/mapscript/php/symbol.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_symbol;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_symbol_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(symbol___construct_args, 0, 0, 2)
ZEND_ARG_OBJ_INFO(0, map, mapObj, 0)
@@ -84,8 +87,8 @@ PHP_METHOD(symbolObj, __construct)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
- php_map = (php_map_object *)zend_object_store_get_object(zmap TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, getThis());
+ php_map = MAPSCRIPT_OBJ_P(php_map_object, zmap);
symbolId = msAddNewSymbol(php_map->map, symbolName);
@@ -98,7 +101,7 @@ PHP_METHOD(symbolObj, __construct)
MAPSCRIPT_MAKE_PARENT(zmap, NULL);
php_symbol->parent = parent;
- MAPSCRIPT_ADDREF(zmap);
+ MAPSCRIPT_ADDREF_P(zmap);
}
/* }}} */
@@ -117,7 +120,7 @@ PHP_METHOD(symbolObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, zobj);
IF_GET_STRING("name", php_symbol->symbol->name)
else IF_GET_LONG("type", php_symbol->symbol->type)
@@ -158,7 +161,7 @@ PHP_METHOD(symbolObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, zobj);
IF_SET_STRING("name", php_symbol->symbol->name, value)
else IF_SET_LONG("type", php_symbol->symbol->type, value)
@@ -188,7 +191,8 @@ PHP_METHOD(symbolObj, __set)
Set the points of the symbol ) */
PHP_METHOD(symbolObj, setPoints)
{
- zval *zpoints, **ppzval;
+ zval *zpoints;
+ MAPSCRIPT_ZVAL_P ppzval;
HashTable *points_hash = NULL;
zval *zobj = getThis();
int index = 0, flag = 0, numelements = 0;
@@ -202,7 +206,7 @@ PHP_METHOD(symbolObj, setPoints)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, zobj);
points_hash = Z_ARRVAL_P(zpoints);
numelements = zend_hash_num_elements(points_hash);
@@ -217,9 +221,15 @@ PHP_METHOD(symbolObj, setPoints)
zend_hash_has_more_elements(points_hash) == SUCCESS;
zend_hash_move_forward(points_hash)) {
+#if PHP_VERSION_ID < 70000
zend_hash_get_current_data(points_hash, (void **)&ppzval);
if (Z_TYPE_PP(ppzval) != IS_DOUBLE)
convert_to_double(*ppzval);
+#else
+ ppzval = zend_hash_get_current_data(points_hash);
+ if (Z_TYPE_P(ppzval) != IS_DOUBLE)
+ convert_to_double(ppzval);
+#endif
if (!flag) {
php_symbol->symbol->points[index].x = Z_DVAL_PP(ppzval);
@@ -254,7 +264,7 @@ PHP_METHOD(symbolObj, getPointsArray)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, zobj);
array_init(return_value);
@@ -287,7 +297,7 @@ PHP_METHOD(symbolObj, setImagePath)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, zobj);
status = msLoadImageSymbol(php_symbol->symbol, filename);
@@ -316,8 +326,8 @@ PHP_METHOD(symbolObj, setImage)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
- php_image = (php_image_object *)zend_object_store_get_object(zimage TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, getThis());
+ php_image = MAPSCRIPT_OBJ_P(php_image_object, zimage);
RETURN_LONG(symbolObj_setImage(php_symbol->symbol, php_image->image));
}
@@ -341,9 +351,9 @@ PHP_METHOD(symbolObj, getImage)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_symbol = (php_symbol_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
- php_map = (php_map_object *) zend_object_store_get_object(php_symbol->parent.val TSRMLS_CC);
- php_outputformat = (php_outputformat_object *)zend_object_store_get_object(zoutputformat TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, getThis());
+ php_map = MAPSCRIPT_OBJ(php_map_object, php_symbol->parent.val);
+ php_outputformat = MAPSCRIPT_OBJ_P(php_outputformat_object, zoutputformat);
image = symbolObj_getImage(php_symbol->symbol, php_outputformat->outputformat);
if (image == NULL) {
@@ -360,7 +370,7 @@ PHP_METHOD(symbolObj, getImage)
} /* }}} */
zend_function_entry symbol_functions[] = {
- PHP_ME(symbolObj, __construct, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
+ PHP_ME(symbolObj, __construct, symbol___construct_args, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
PHP_ME(symbolObj, __get, symbol___get_args, ZEND_ACC_PUBLIC)
PHP_ME(symbolObj, __set, symbol___set_args, ZEND_ACC_PUBLIC)
PHP_MALIAS(symbolObj, set, __set, NULL, ZEND_ACC_PUBLIC)
@@ -377,7 +387,7 @@ void mapscript_create_symbol(symbolObj *symbol, parent_object parent, zval *retu
{
php_symbol_object * php_symbol;
object_init_ex(return_value, mapscript_ce_symbol);
- php_symbol = (php_symbol_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_symbol = MAPSCRIPT_OBJ_P(php_symbol_object, return_value);
php_symbol->symbol = symbol;
php_symbol->parent = parent;
@@ -385,6 +395,55 @@ void mapscript_create_symbol(symbolObj *symbol, parent_object parent, zval *retu
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_symbol_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_symbol_object *php_symbol;
+
+ php_symbol = ecalloc(1, sizeof(*php_symbol) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_symbol->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_symbol->zobj, ce);
+
+ php_symbol->zobj.handlers = &mapscript_symbol_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_symbol->parent);
+
+ return &php_symbol->zobj;
+}
+
+static void mapscript_symbol_free_object(zend_object *object)
+{
+ php_symbol_object *php_symbol;
+
+ php_symbol = (php_symbol_object *)((char *)object - XtOffsetOf(php_symbol_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_symbol->parent);
+
+ /* We don't need to free the symbolObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(symbol)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "symbolObj", symbol_functions);
+ mapscript_ce_symbol = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_symbol->create_object = mapscript_symbol_create_object;
+ mapscript_ce_symbol->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_symbol_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_symbol_object_handlers));
+ mapscript_symbol_object_handlers.free_obj = mapscript_symbol_free_object;
+ mapscript_symbol_object_handlers.offset = XtOffsetOf(php_symbol_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_symbol_object_destroy(void *object TSRMLS_DC)
{
php_symbol_object *php_symbol = (php_symbol_object *)object;
@@ -426,3 +485,4 @@ PHP_MINIT_FUNCTION(symbol)
return SUCCESS;
}
+#endif
diff --git a/mapscript/php/web.c b/mapscript/php/web.c
index 51ec72f36..41f7c7cff 100644
--- a/mapscript/php/web.c
+++ b/mapscript/php/web.c
@@ -32,6 +32,9 @@
#include "php_mapscript.h"
zend_class_entry *mapscript_ce_web;
+#if PHP_VERSION_ID >= 70000
+zend_object_handlers mapscript_web_object_handlers;
+#endif
ZEND_BEGIN_ARG_INFO_EX(web___get_args, 0, 0, 1)
ZEND_ARG_INFO(0, property)
@@ -69,7 +72,7 @@ PHP_METHOD(webObj, __get)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_web = (php_web_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, zobj);
IF_GET_STRING("log", php_web->web->log)
else IF_GET_STRING("imagepath", php_web->web->imagepath)
@@ -111,7 +114,7 @@ PHP_METHOD(webObj, __set)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_web = (php_web_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, zobj);
IF_SET_STRING("log", php_web->web->log, value)
else IF_SET_STRING("imagepath", php_web->web->imagepath, value)
@@ -157,7 +160,7 @@ PHP_METHOD(webObj, updateFromString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_web = (php_web_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, zobj);
status = webObj_updateFromString(php_web->web, snippet);
@@ -185,14 +188,14 @@ PHP_METHOD(webObj, convertToString)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_web = (php_web_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, zobj);
value = webObj_convertToString(php_web->web);
if (value == NULL)
- RETURN_STRING("", 1);
+ MAPSCRIPT_RETURN_STRING("", 1);
- RETVAL_STRING(value, 1);
+ MAPSCRIPT_RETVAL_STRING(value, 1);
free(value);
}
/* }}} */
@@ -211,7 +214,7 @@ PHP_METHOD(webObj, free)
}
PHP_MAPSCRIPT_RESTORE_ERRORS(TRUE);
- php_web = (php_web_object *) zend_object_store_get_object(zobj TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, zobj);
MAPSCRIPT_DELREF(php_web->extent);
MAPSCRIPT_DELREF(php_web->metadata);
@@ -235,13 +238,68 @@ void mapscript_create_web(webObj *web, parent_object parent, zval *return_value
{
php_web_object * php_web;
object_init_ex(return_value, mapscript_ce_web);
- php_web = (php_web_object *)zend_object_store_get_object(return_value TSRMLS_CC);
+ php_web = MAPSCRIPT_OBJ_P(php_web_object, return_value);
php_web->web = web;
php_web->parent = parent;
MAPSCRIPT_ADDREF(parent.val);
}
+#if PHP_VERSION_ID >= 70000
+/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
+static zend_object *mapscript_web_create_object(zend_class_entry *ce TSRMLS_DC)
+{
+ php_web_object *php_web;
+
+ php_web = ecalloc(1, sizeof(*php_web) + zend_object_properties_size(ce));
+
+ zend_object_std_init(&php_web->zobj, ce TSRMLS_CC);
+ object_properties_init(&php_web->zobj, ce);
+
+ php_web->zobj.handlers = &mapscript_web_object_handlers;
+
+ MAPSCRIPT_INIT_PARENT(php_web->parent);
+ ZVAL_UNDEF(&php_web->extent);
+ ZVAL_UNDEF(&php_web->metadata);
+ ZVAL_UNDEF(&php_web->validation);
+
+ return &php_web->zobj;
+}
+
+static void mapscript_web_free_object(zend_object *object)
+{
+ php_web_object *php_web;
+
+ php_web = (php_web_object *)((char *)object - XtOffsetOf(php_web_object, zobj));
+
+ MAPSCRIPT_FREE_PARENT(php_web->parent);
+ MAPSCRIPT_DELREF(php_web->extent);
+ MAPSCRIPT_DELREF(php_web->metadata);
+ MAPSCRIPT_DELREF(php_web->validation);
+
+ /* We don't need to free the webObj */
+
+ zend_object_std_dtor(object);
+}
+
+PHP_MINIT_FUNCTION(web)
+{
+ zend_class_entry ce;
+
+ INIT_CLASS_ENTRY(ce, "webObj", web_functions);
+ mapscript_ce_web = zend_register_internal_class(&ce TSRMLS_CC);
+
+ mapscript_ce_web->create_object = mapscript_web_create_object;
+ mapscript_ce_web->ce_flags |= ZEND_ACC_FINAL;
+
+ memcpy(&mapscript_web_object_handlers, &mapscript_std_object_handlers, sizeof(mapscript_web_object_handlers));
+ mapscript_web_object_handlers.free_obj = mapscript_web_free_object;
+ mapscript_web_object_handlers.offset = XtOffsetOf(php_web_object, zobj);
+
+ return SUCCESS;
+}
+#else
+/* PHP5 */
static void mapscript_web_object_destroy(void *object TSRMLS_DC)
{
php_web_object *php_web = (php_web_object *)object;
@@ -289,3 +347,4 @@ PHP_MINIT_FUNCTION(web)
return SUCCESS;
}
+#endif
From f54ce3a08f9a735b32b648b8be7dabd848965c88 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bj=C3=B6rn=20Boldt?= <mapscript@pixaweb.net>
Date: Fri, 10 Nov 2017 14:43:20 +0100
Subject: [PATCH 2/5] Fix bug in msQueryByFilter()
Mapserver crashes in msQueryByFilter() if an error occurs (e.g. filteritem name is not a column name of the shape). We have to restore lp->filteritem and lp->filter. Why was this commented out?
---
mapquery.c | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/mapquery.c b/mapquery.c
index a0766911d..3ff0ff6e1 100644
--- a/mapquery.c
+++ b/mapquery.c
@@ -864,10 +864,10 @@ int msQueryByFilter(mapObj *map)
query_error:
// msFree(lp->filteritem);
- // lp->filteritem = old_filteritem;
- // msCopyExpression(&lp->filter, &old_filter); /* restore old filter */
- // msFreeExpression(&old_filter);
- // msLayerClose(lp);
+ lp->filteritem = old_filteritem;
+ msCopyExpression(&lp->filter, &old_filter); /* restore old filter */
+ msFreeExpression(&old_filter);
+ msLayerClose(lp);
return MS_FAILURE;
}
From a5049b7ba8b2ab4c278cca1993566b3ef1b4cb9b Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bj=C3=B6rn=20Boldt?= <mapscript@pixaweb.net>
Date: Fri, 10 Nov 2017 15:16:14 +0100
Subject: [PATCH 3/5] Update mapquery.c
---
mapquery.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/mapquery.c b/mapquery.c
index 3ff0ff6e1..34b483221 100644
--- a/mapquery.c
+++ b/mapquery.c
@@ -736,7 +736,7 @@ int msQueryByFilter(mapObj *map)
paging = msLayerGetPaging(lp);
msLayerClose(lp); /* reset */
status = msLayerOpen(lp);
- if(status != MS_SUCCESS) goto query_error;
+ if(status != MS_SUCCESS) return MS_FAILURE;
msLayerEnablePaging(lp, paging);
/* disable driver paging */
From 54256aa1611a6c21e1a7e50ceaaaf9735bdbb7a3 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bj=C3=B6rn=20Boldt?= <mapscript@pixaweb.net>
Date: Tue, 27 Mar 2018 10:07:21 +0200
Subject: [PATCH 4/5] Moving function mapscript_create_legend
Fixing error "undefined symbol: mapscript_create_legend" in PHP7
---
mapscript/php/legend.c | 22 +++++++++++-----------
1 file changed, 11 insertions(+), 11 deletions(-)
diff --git a/mapscript/php/legend.c b/mapscript/php/legend.c
index 29e080df7..742cc0c00 100644
--- a/mapscript/php/legend.c
+++ b/mapscript/php/legend.c
@@ -220,6 +220,17 @@ zend_function_entry legend_functions[] = {
}
};
+void mapscript_create_legend(legendObj *legend, parent_object parent, zval *return_value TSRMLS_DC)
+{
+ php_legend_object * php_legend;
+ object_init_ex(return_value, mapscript_ce_legend);
+ php_legend = MAPSCRIPT_OBJ_P(php_legend_object, return_value);
+ php_legend->legend = legend;
+
+ php_legend->parent = parent;
+ MAPSCRIPT_ADDREF(parent.val);
+}
+
#if PHP_VERSION_ID >= 70000
/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
@@ -276,17 +287,6 @@ PHP_MINIT_FUNCTION(legend)
}
#else
/* PHP5 */
-void mapscript_create_legend(legendObj *legend, parent_object parent, zval *return_value TSRMLS_DC)
-{
- php_legend_object * php_legend;
- object_init_ex(return_value, mapscript_ce_legend);
- php_legend = MAPSCRIPT_OBJ_P(php_legend_object, return_value);
- php_legend->legend = legend;
-
- php_legend->parent = parent;
- MAPSCRIPT_ADDREF(parent.val);
-}
-
static void mapscript_legend_object_destroy(void *object TSRMLS_DC)
{
php_legend_object *php_legend = (php_legend_object *)object;
From fd3cbf6cb23c7a558893e7e11cde419049ea4fdf Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bj=C3=B6rn=20Boldt?= <mapscript@pixaweb.net>
Date: Tue, 27 Mar 2018 15:24:51 +0200
Subject: [PATCH 5/5] Moving function void mapscript_create_grid
---
mapscript/php/grid.c | 24 ++++++++++++------------
1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/mapscript/php/grid.c b/mapscript/php/grid.c
index c13f54bc3..f57e91fe5 100644
--- a/mapscript/php/grid.c
+++ b/mapscript/php/grid.c
@@ -176,6 +176,17 @@ zend_function_entry grid_functions[] = {
}
};
+void mapscript_create_grid(graticuleObj *grid, parent_object parent, zval *return_value TSRMLS_DC)
+{
+ php_grid_object * php_grid;
+ object_init_ex(return_value, mapscript_ce_grid);
+ php_grid = MAPSCRIPT_OBJ_P(php_grid_object, return_value);
+ php_grid->grid = grid;
+
+ php_grid->parent = parent;
+ MAPSCRIPT_ADDREF(parent.val);
+}
+
#if PHP_VERSION_ID >= 70000
/* PHP7 - Modification by Bjoern Boldt <mapscript@pixaweb.net> */
static zend_object *mapscript_grid_create_object(zend_class_entry *ce TSRMLS_DC)
@@ -225,17 +236,6 @@ PHP_MINIT_FUNCTION(grid)
}
#else
/* PHP5 */
-void mapscript_create_grid(graticuleObj *grid, parent_object parent, zval *return_value TSRMLS_DC)
-{
- php_grid_object * php_grid;
- object_init_ex(return_value, mapscript_ce_grid);
- php_grid = MAPSCRIPT_OBJ_P(php_grid_object, return_value);
- php_grid->grid = grid;
-
- php_grid->parent = parent;
- MAPSCRIPT_ADDREF(parent.val);
-}
-
static void mapscript_grid_object_destroy(void *object TSRMLS_DC)
{
php_grid_object *php_grid = (php_grid_object *)object;
@@ -277,4 +277,4 @@ PHP_MINIT_FUNCTION(grid)
return SUCCESS;
}
-#endif
\ No newline at end of file
+#endif