summaryrefslogtreecommitdiff
path: root/src/boolmember.h
diff options
context:
space:
mode:
authorEmiel Bruijntjes <emiel.bruijntjes@copernica.com>2014-02-28 15:17:53 +0100
committerEmiel Bruijntjes <emiel.bruijntjes@copernica.com>2014-02-28 15:17:53 +0100
commit7cf89f18d766368dd4a14d35e4e144107ad7be36 (patch)
tree0bd4e449cbfddc928c25aaa1abac8b44c028c8e2 /src/boolmember.h
parent6072701319a3bf085bbc354c3e3dae9b7d021be0 (diff)
implemented properties
Diffstat (limited to 'src/boolmember.h')
-rw-r--r--src/boolmember.h29
1 files changed, 13 insertions, 16 deletions
diff --git a/src/boolmember.h b/src/boolmember.h
index 981a711..3dd4466 100644
--- a/src/boolmember.h
+++ b/src/boolmember.h
@@ -15,7 +15,7 @@ namespace Php {
/**
* Class definition
*/
-class BoolMember : public MemberInfo
+class BoolMember : public Member
{
private:
/**
@@ -27,9 +27,11 @@ private:
public:
/**
* Constructor
+ * @param name
* @param value
+ * @param flags
*/
- BoolMember(bool value) : MemberInfo(), _value(value) {}
+ BoolMember(const char *name, bool value, int flags) : Member(name, flags), _value(value) {}
/**
* Destructor
@@ -37,27 +39,22 @@ public:
virtual ~BoolMember() {}
/**
- * Is this a property member
- * @return bool
+ * Virtual method to declare a class constant
+ * @param entry Class entry
*/
- virtual bool isProperty() { return true; }
+ virtual void constant(struct _zend_class_entry *entry) override
+ {
+ zend_declare_class_constant_bool(entry, _name.c_str(), _name.size(), _value);
+ }
/**
* Virtual method to declare the property
* @param entry Class entry
- * @param name Name of the member
- * @param size Size of the name
- * @param flags Additional flags
*/
- virtual void declare(struct _zend_class_entry *entry, const char *name, int size, MemberModifier flags) override
+ virtual void declare(struct _zend_class_entry *entry) override
{
-#if PHP_VERSION_ID >= 50400
- if (flags == constMember) zend_declare_class_constant_bool(entry, name, size, _value);
- else zend_declare_property_bool(entry, name, size, _value, flags);
-#else
- if (flags == constMember) zend_declare_class_constant_bool(entry, (char *) name, size, _value);
- else zend_declare_property_bool(entry, (char *) name, size, _value, flags);
-#endif
+ // char* cast is necessary for php 5.3
+ zend_declare_property_bool(entry, (char *)_name.c_str(), _name.size(), _value, _flags);
}
};