From 35fd3ccbeb4def71b4d8a59dfbb5c31201b099b9 Mon Sep 17 00:00:00 2001 From: Emiel Bruijntjes Date: Sun, 6 Apr 2014 21:53:24 +0200 Subject: renamed src directory to zend directory, disabled TSRM debug code --- zend/numericmember.h | 67 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100644 zend/numericmember.h (limited to 'zend/numericmember.h') diff --git a/zend/numericmember.h b/zend/numericmember.h new file mode 100644 index 0000000..0a040d3 --- /dev/null +++ b/zend/numericmember.h @@ -0,0 +1,67 @@ +/** + * NumericMember.h + * + * Implementation for a property that is initially set to a numeric value + * + * @author Emiel Bruijntjes + * @copyright 2013, 2014 Copernica BV + */ + +/** + * Set up namespace + */ +namespace Php { + +/** + * Class definition + */ +class NumericMember : public Member +{ +private: + /** + * The value + * @var long + */ + long _value; + +public: + /** + * Constructor + * @param name + * @param value + * @param flags + */ + NumericMember(const char *name, long value, int flags) : Member(name, flags), _value(value) {} + + /** + * Destructor + */ + virtual ~NumericMember() {} + + /** + * Declare class constant + * @param entry Class entry + * @param tsrm_ls + */ + virtual void constant(struct _zend_class_entry *entry TSRMLS_DC) override + { + zend_declare_class_constant_long(entry, _name.c_str(), _name.size(), _value TSRMLS_CC); + } + + /** + * Virtual method to declare the property + * @param entry Class entry + * @param tsrm_ls + */ + virtual void declare(struct _zend_class_entry *entry TSRMLS_DC) override + { + // char* cast is necessary for php 5.3 + zend_declare_property_long(entry, (char *)_name.c_str(), _name.size(), _value, _flags TSRMLS_CC); + } +}; + +/** + * End of namespace + */ +} + -- cgit v1.2.3