From 9dbfe1b23d9c9529c9c980bd3de79dbf2033f388 Mon Sep 17 00:00:00 2001 From: bjoernboldt 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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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; ilayer->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; ilayer->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; ilayer->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; inTop; 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; inTop; 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; inBottom; 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; inBottom; 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; inLeft; 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; inLeft; 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; inRight; 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; inRight; 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 */ +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 */ +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 */ +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; imap->numlayers; for (i=0; imap->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 */ +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 */ +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 request’s 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 */ +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 */ +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= 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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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 */ +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; ilayer->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; ishape->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 */ +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 */ +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 */ +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 */ +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 */ +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?= 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?= 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?= 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 */ @@ -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?= 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 */ 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