From c524645738e666bf4a298d15e6fd6f39d7c6992e Mon Sep 17 00:00:00 2001 From: Ber Clausen Date: Thu, 5 Sep 2013 10:38:29 -0300 Subject: [PATCH] Update Model/Behaviors callback signature to be PHP5.4+ compliant. --- lib/Cake/Model/Behavior/TranslateBehavior.php | 6 +++++- lib/Cake/Model/Behavior/TreeBehavior.php | 4 +++- lib/Cake/Model/Model.php | 3 ++- lib/Cake/Model/ModelBehavior.php | 8 ++++++-- .../Test/Case/Model/BehaviorCollectionTest.php | 18 +++++++++++------- lib/Cake/Test/Case/Model/models.php | 8 ++++++-- 6 files changed, 33 insertions(+), 14 deletions(-) diff --git a/lib/Cake/Model/Behavior/TranslateBehavior.php b/lib/Cake/Model/Behavior/TranslateBehavior.php index 3156d7f70..2550b72d2 100644 --- a/lib/Cake/Model/Behavior/TranslateBehavior.php +++ b/lib/Cake/Model/Behavior/TranslateBehavior.php @@ -320,9 +320,11 @@ class TranslateBehavior extends ModelBehavior { * beforeValidate Callback * * @param Model $Model Model invalidFields was called on. + * @param array $options Options passed from Model::save(). * @return boolean + * @see Model::save() */ - public function beforeValidate(Model $Model) { + public function beforeValidate(Model $Model, $options = array()) { unset($this->runtime[$Model->alias]['beforeSave']); $this->_setRuntimeData($Model); return true; @@ -335,7 +337,9 @@ class TranslateBehavior extends ModelBehavior { * disabled. Or the runtime data hasn't been set yet. * * @param Model $Model Model save was called on. + * @param array $options Options passed from Model::save(). * @return boolean true. + * @see Model::save() */ public function beforeSave(Model $Model, $options = array()) { if (isset($options['validate']) && !$options['validate']) { diff --git a/lib/Cake/Model/Behavior/TreeBehavior.php b/lib/Cake/Model/Behavior/TreeBehavior.php index dc5c22085..84af35833 100644 --- a/lib/Cake/Model/Behavior/TreeBehavior.php +++ b/lib/Cake/Model/Behavior/TreeBehavior.php @@ -175,9 +175,11 @@ class TreeBehavior extends ModelBehavior { * * @since 1.2 * @param Model $Model Model instance + * @param array $options Options passed from Model::save(). * @return boolean true to continue, false to abort the save + * @see Model::save() */ - public function beforeSave(Model $Model) { + public function beforeSave(Model $Model, $options = array()) { extract($this->settings[$Model->alias]); $this->_addToWhitelist($Model, array($left, $right)); diff --git a/lib/Cake/Model/Model.php b/lib/Cake/Model/Model.php index 0c1d51e02..449ca5c7a 100644 --- a/lib/Cake/Model/Model.php +++ b/lib/Cake/Model/Model.php @@ -3460,9 +3460,10 @@ class Model extends Object implements CakeEventListener { * Called during validation operations, before validation. Please note that custom * validation rules can be defined in $validate. * - * @param array $options Options passed from model::save(), see $options of model::save(). + * @param array $options Options passed from Model::save(). * @return boolean True if validate operation should continue, false to abort * @link http://book.cakephp.org/2.0/en/models/callback-methods.html#beforevalidate + * @see Model::save() */ public function beforeValidate($options = array()) { return true; diff --git a/lib/Cake/Model/ModelBehavior.php b/lib/Cake/Model/ModelBehavior.php index 11ca87184..4ccfbfd00 100644 --- a/lib/Cake/Model/ModelBehavior.php +++ b/lib/Cake/Model/ModelBehavior.php @@ -141,9 +141,11 @@ class ModelBehavior extends Object { * will allow you to make the validation fail. * * @param Model $model Model using this behavior + * @param array $options Options passed from Model::save(). * @return mixed False or null will abort the operation. Any other result will continue. + * @see Model::save() */ - public function beforeValidate(Model $model) { + public function beforeValidate(Model $model, $options = array()) { return true; } @@ -163,9 +165,11 @@ class ModelBehavior extends Object { * will abort the save operation. * * @param Model $model Model using this behavior + * @param array $options Options passed from Model::save(). * @return mixed False if the operation should abort. Any other result will continue. + * @see Model::save() */ - public function beforeSave(Model $model) { + public function beforeSave(Model $model, $options = array()) { return true; } diff --git a/lib/Cake/Test/Case/Model/BehaviorCollectionTest.php b/lib/Cake/Test/Case/Model/BehaviorCollectionTest.php index b84260dec..fd5f3088a 100644 --- a/lib/Cake/Test/Case/Model/BehaviorCollectionTest.php +++ b/lib/Cake/Test/Case/Model/BehaviorCollectionTest.php @@ -104,10 +104,12 @@ class TestBehavior extends ModelBehavior { /** * beforeSave method * - * @param Model $model - * @return void + * @param Model $model Model using this behavior + * @param array $options Options passed from Model::save(). + * @return mixed False if the operation should abort. Any other result will continue. + * @see Model::save() */ - public function beforeSave(Model $model) { + public function beforeSave(Model $model, $options = array()) { $settings = $this->settings[$model->alias]; if (!isset($settings['beforeSave']) || $settings['beforeSave'] === 'off') { return parent::beforeSave($model); @@ -155,12 +157,14 @@ class TestBehavior extends ModelBehavior { } /** - * beforeValidate method + * beforeValidate Callback * - * @param Model $model - * @return void + * @param Model $Model Model invalidFields was called on. + * @param array $options Options passed from Model::save(). + * @return boolean + * @see Model::save() */ - public function beforeValidate(Model $model) { + public function beforeValidate(Model $model, $options = array()) { $settings = $this->settings[$model->alias]; if (!isset($settings['validate']) || $settings['validate'] === 'off') { return parent::beforeValidate($model); diff --git a/lib/Cake/Test/Case/Model/models.php b/lib/Cake/Test/Case/Model/models.php index 5290e42ad..41c66eaac 100644 --- a/lib/Cake/Test/Case/Model/models.php +++ b/lib/Cake/Test/Case/Model/models.php @@ -2039,7 +2039,9 @@ class CallbackPostTestModel extends CakeTestModel { /** * beforeValidate callback * - * @return boolean + * @param array $options Options passed from Model::save(). + * @return boolean True if validate operation should continue, false to abort + * @see Model::save() */ public function beforeValidate($options = array()) { return $this->beforeValidateReturn; @@ -4980,7 +4982,9 @@ class CustomArticle extends AppModel { /** * Alters title data * - * @return void + * @param array $options Options passed from Model::save(). + * @return boolean True if validate operation should continue, false to abort + * @see Model::save() */ public function beforeValidate($options = array()) { $this->data[$this->alias]['title'] = 'foo';