summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Zmievski <andrei@php.net>2003-04-02 20:27:44 +0000
committerAndrei Zmievski <andrei@php.net>2003-04-02 20:27:44 +0000
commit3d62a3491e8508e90bc109f3d3d984eae2f8c10a (patch)
tree8d9f94dd73a2979eeae2fdae3760998b53d7e7d4
parentbac12360efebe8a6d2ae2e50cd46b26f2b8f5021 (diff)
downloadphp-git-3d62a3491e8508e90bc109f3d3d984eae2f8c10a.tar.gz
- Add zend_register_internal_namespace() API function.
- Add zend_register_internal_class_in_ns() API function.
-rw-r--r--Zend/zend_API.c54
-rw-r--r--Zend/zend_API.h4
2 files changed, 57 insertions, 1 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c
index 1ab36bf29e..ce3e89a620 100644
--- a/Zend/zend_API.c
+++ b/Zend/zend_API.c
@@ -1165,7 +1165,11 @@ int zend_register_functions(zend_class_entry *scope, zend_function_entry *functi
internal_function->function_name = ptr->fname;
internal_function->scope = scope;
internal_function->fn_flags = ZEND_ACC_PUBLIC;
- internal_function->ns = EG(active_namespace);
+ if (!scope) {
+ internal_function->ns = EG(active_namespace);
+ } else {
+ internal_function->ns = NULL;
+ }
internal_function->prototype = NULL;
if (!internal_function->handler) {
zend_error(error_type, "Null function defined as active function");
@@ -1381,6 +1385,54 @@ ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *orig_c
return class_entry;
}
+ZEND_API zend_class_entry *zend_register_internal_class_in_ns(zend_class_entry *class_entry, zend_class_entry *parent_ce, zend_namespace *ns, char *ns_name TSRMLS_DC)
+{
+ zend_class_entry *register_class;
+ zend_namespace *orig_namespace = NULL;
+
+ if (!ns && ns_name) {
+ zend_namespace **pns;
+ size_t ns_name_length = strlen(ns_name);
+ char *lowercase_name = zend_strndup(ns_name, ns_name_length);
+ zend_str_tolower(lowercase_name, ns_name_length);
+ if (zend_hash_find(&CG(global_namespace).class_table, lowercase_name, ns_name_length+1, (void **)&pns) == FAILURE) {
+ free(lowercase_name);
+ return NULL;
+ } else {
+ ns = *pns;
+ }
+ free(lowercase_name);
+ }
+
+ if (EG(active_namespace) != ns) {
+ orig_namespace = EG(active_namespace);
+ EG(active_namespace) = ns;
+ CG(class_table) = &ns->class_table;
+ }
+ register_class = zend_register_internal_class_ex(class_entry, parent_ce, NULL TSRMLS_CC);
+ if (orig_namespace) {
+ EG(active_namespace) = orig_namespace;
+ CG(class_table) = &orig_namespace->class_table;
+ }
+
+ return register_class;
+}
+
+ZEND_API zend_namespace *zend_register_internal_namespace(zend_namespace *orig_ns TSRMLS_DC)
+{
+ zend_namespace *ns = malloc(sizeof(zend_namespace));
+ char *lowercase_name = zend_strndup(orig_ns->name, orig_ns->name_length);
+ *ns = *orig_ns;
+
+ ns->type = ZEND_INTERNAL_NAMESPACE;
+ zend_init_namespace(ns TSRMLS_CC);
+
+ zend_str_tolower(lowercase_name, ns->name_length);
+ zend_hash_update(&CG(global_namespace).class_table, lowercase_name, ns->name_length+1, &ns, sizeof(zend_namespace *), NULL);
+ free(lowercase_name);
+
+ return ns;
+}
ZEND_API int zend_set_hash_symbol(zval *symbol, char *name, int name_length,
zend_bool is_ref, int num_symbol_tables, ...)
diff --git a/Zend/zend_API.h b/Zend/zend_API.h
index 75007c3558..2181a483cf 100644
--- a/Zend/zend_API.h
+++ b/Zend/zend_API.h
@@ -101,6 +101,8 @@ BEGIN_EXTERN_C()
class_container.__set = handle_propset; \
}
+#define INIT_NAMESPACE(ns_container, ns_name) INIT_CLASS_ENTRY(ns_container, ns_name, NULL)
+
int zend_next_free_module(void);
@@ -134,6 +136,8 @@ ZEND_API int zend_register_module(zend_module_entry *module_entry);
ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *class_entry TSRMLS_DC);
ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *class_entry, zend_class_entry *parent_ce, char *parent_name TSRMLS_DC);
+ZEND_API zend_class_entry *zend_register_internal_class_in_ns(zend_class_entry *class_entry, zend_class_entry *parent_ce, zend_namespace *ns, char *ns_name TSRMLS_DC);
+ZEND_API zend_namespace *zend_register_internal_namespace(zend_namespace *ns TSRMLS_DC);
ZEND_API int zend_disable_function(char *function_name, uint function_name_length TSRMLS_DC);
ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_DC);