Commit ba4d1a89 by Taylor Otwell

Removed add_ magic method from eloquent model as this will be a 3.2 feature.

parent a915e24b
......@@ -17,6 +17,8 @@ class Blade {
'structure_closings',
'else',
'includes',
'render_each',
'render',
'yields',
'yield_sections',
'section_start',
......@@ -266,6 +268,32 @@ class Blade {
}
/**
* Rewrites Blade @render statements into valid PHP.
*
* @param string $value
* @return string
*/
protected static function compile_render($value)
{
$pattern = static::matcher('render');
return preg_replace($pattern, '$1<?php echo render$2; ?>', $value);
}
/**
* Rewrites Blade @render_each statements into valid PHP.
*
* @param string $value
* @return string
*/
protected static function compile_render_each($value)
{
$pattern = static::matcher('render_each');
return preg_replace($pattern, '$1<?php echo render_each$2; ?>', $value);
}
/**
* Rewrites Blade @yield statements into Section statements.
*
* The Blade @yield statement is a shortcut to the Section::yield method.
......
......@@ -136,9 +136,9 @@ abstract class Model {
}
}
// If the original attribute values have not been set, we will set them to
// the values passed to this method allowing us to quickly check if the
// model has changed since hydration of the original instance.
// If the original attribute values have not been set, we will set
// them to the values passed to this method allowing us to easily
// check if the model has changed since hydration.
if (count($this->original) === 0)
{
$this->original = $this->attributes;
......@@ -309,6 +309,32 @@ abstract class Model {
}
/**
* Save the model and all of its relations to the database.
*
* @return bool
*/
public function push()
{
$this->save();
// To sync all of the relationships to the database, we will simply spin through
// the relationships, calling the "push" method on each of the models in that
// given relationship, this should ensure that each model is saved.
foreach ($this->relationships as $name => $models)
{
if ( ! is_array($models))
{
$models = array($models);
}
foreach ($models as $model)
{
$model->push();
}
}
}
/**
* Save the model instance to the database.
*
* @return bool
......@@ -612,14 +638,6 @@ abstract class Model {
$this->attributes[substr($method, 4)] = $parameters[0];
}
// If the method begins with "add_", we will assume that the developer is
// adding a related model instance to the model. This is useful for
// adding all of the related models and then saving at once.
elseif (starts_with($method, 'add_'))
{
$this->relationships[substr($method, 4)][] = $parameters[0];
}
// Finally we will assume that the method is actually the beginning of a
// query, such as "where", and will create a new query instance and
// call the method on the query instance, returning it after.
......
......@@ -96,7 +96,7 @@ abstract class Relationship extends Query {
*
* @return string
*/
protected function foreign_key()
public function foreign_key()
{
return static::foreign($this->base, $this->foreign);
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment