From 56bbf0e2fdeee88edab3f2260ca2c5ed110fa938 Mon Sep 17 00:00:00 2001 From: Vladimir Kolesnikov Date: Wed, 9 Oct 2013 15:50:17 +0300 Subject: [PATCH 1/2] Fix #1349 --- ext/forms/form.c | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/ext/forms/form.c b/ext/forms/form.c index 9e296e7b76d..ad80a20c09d 100644 --- a/ext/forms/form.c +++ b/ext/forms/form.c @@ -550,8 +550,7 @@ PHP_METHOD(Phalcon_Forms_Form, isValid){ */ PHP_METHOD(Phalcon_Forms_Form, getMessages){ - zval *by_item_name = NULL, *messages, *element_messages = NULL; - zval *element = NULL; + zval *by_item_name = NULL, *messages; HashTable *ah0; HashPosition hp0; zval **hd; @@ -579,16 +578,13 @@ PHP_METHOD(Phalcon_Forms_Form, getMessages){ object_init_ex(return_value, phalcon_validation_message_group_ce); phalcon_call_method_noret(return_value, "__construct"); - phalcon_is_iterable(messages, &ah0, &hp0, 0, 0); - - while (zend_hash_get_current_data_ex(ah0, (void**) &hd, &hp0) == SUCCESS) { - - PHALCON_GET_HKEY(element, ah0, hp0); - PHALCON_GET_HVALUE(element_messages); - - phalcon_call_method_p1_noret(return_value, "appendmessages", element_messages); - - zend_hash_move_forward_ex(ah0, &hp0); + if (Z_TYPE_P(messages) == IS_ARRAY) { + phalcon_is_iterable(messages, &ah0, &hp0, 0, 0); + + while (zend_hash_get_current_data_ex(ah0, (void**) &hd, &hp0) == SUCCESS) { + phalcon_call_method_p1_noret(return_value, "appendmessages", *hd); + zend_hash_move_forward_ex(ah0, &hp0); + } } PHALCON_MM_RESTORE(); From 41889b202f34377873b55cde98656c7b7856c816 Mon Sep 17 00:00:00 2001 From: Vladimir Kolesnikov Date: Wed, 9 Oct 2013 15:50:32 +0300 Subject: [PATCH 2/2] Test for #1349 --- ext/tests/issue-1349.phpt | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 ext/tests/issue-1349.phpt diff --git a/ext/tests/issue-1349.phpt b/ext/tests/issue-1349.phpt new file mode 100644 index 00000000000..82d6a1f0e0e --- /dev/null +++ b/ext/tests/issue-1349.phpt @@ -0,0 +1,12 @@ +--TEST-- +Phalcon\Forms\Form::getMessages() produces PHP error if form is valid - https://github.com/phalcon/cphalcon/issues/1349 +--SKIPIF-- + +--FILE-- +add(new \Phalcon\Forms\Element\Text('name')); +$form->isValid(array('name' => 'John')); +assert(get_class($form->getMessages(false)) == 'Phalcon\Validation\Message\Group'); +?> +--EXPECT--