X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=php_psi.h;h=3dedff290a3830dbca22049141b3d05fcff1594e;hp=cce350390016fe3ad2b4150e4d7df63e6a6c570f;hb=3fa287dfd76814b2ec54991c0208a019845a3dc0;hpb=be3ceffdd27422aae6ba44d31d868fb12d08957a diff --git a/php_psi.h b/php_psi.h index cce3503..3dedff2 100644 --- a/php_psi.h +++ b/php_psi.h @@ -1,4 +1,3 @@ - #ifndef PHP_PSI_H #define PHP_PSI_H @@ -21,11 +20,34 @@ extern zend_module_entry psi_module_entry; #include "context.h" +static inline int psi_check_env(const char *var) { + char *set = getenv(var); + return (set && *set && '0' != *set); +} + +typedef struct psi_object { + void *data; + size_t size; + zend_object std; +} psi_object; + +static inline psi_object *PSI_OBJ(zval *zv, zend_object *zo) { + if (zv) { + zo = Z_OBJ_P(zv); + } + return (void *) (((char *) zo) - zo->handlers->offset); +} + +PHP_PSI_API zend_class_entry *psi_object_get_class_entry(); + ZEND_BEGIN_MODULE_GLOBALS(psi) + char *engine; char *directory; - PSI_Context context; + struct psi_context context; ZEND_END_MODULE_GLOBALS(psi); +ZEND_EXTERN_MODULE_GLOBALS(psi); + #define PSI_G(v) ZEND_MODULE_GLOBALS_ACCESSOR(psi, v) #if defined(ZTS) && defined(COMPILE_DL_PSI)