mapserver/5461.patch

8837 lines
312 KiB
Diff
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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