summaryrefslogtreecommitdiff
path: root/lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php
diff options
context:
space:
mode:
authorNathan Kinkade <kinkade@measurementlab.net>2019-08-27 13:05:48 -0600
committerNathan Kinkade <kinkade@measurementlab.net>2019-08-27 13:05:48 -0600
commita6c179d56973e382205c8583568d635c37f814c8 (patch)
treed144141439adac21f0c1bc2fc2caa85fd8135039 /lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php
parent34972193073432105b8659407af5a914b3686f81 (diff)
Updates smarty to v3.1.33.
Diffstat (limited to 'lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php')
-rw-r--r--lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php49
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php b/lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php
new file mode 100644
index 0000000..c959044
--- /dev/null
+++ b/lib/smarty-3.1.33/sysplugins/smarty_internal_method_appendbyref.php
@@ -0,0 +1,49 @@
+<?php
+
+/**
+ * Smarty Method AppendByRef
+ *
+ * Smarty::appendByRef() method
+ *
+ * @package Smarty
+ * @subpackage PluginsInternal
+ * @author Uwe Tews
+ */
+class Smarty_Internal_Method_AppendByRef
+{
+ /**
+ * appends values to template variables by reference
+ *
+ * @api Smarty::appendByRef()
+ * @link http://www.smarty.net/docs/en/api.append.by.ref.tpl
+ *
+ * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data
+ * @param string $tpl_var the template variable name
+ * @param mixed &$value the referenced value to append
+ * @param bool $merge flag if array elements shall be merged
+ *
+ * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty
+ */
+ public static function appendByRef(Smarty_Internal_Data $data, $tpl_var, &$value, $merge = false)
+ {
+ if ($tpl_var !== '' && isset($value)) {
+ if (!isset($data->tpl_vars[ $tpl_var ])) {
+ $data->tpl_vars[ $tpl_var ] = new Smarty_Variable();
+ }
+ if (!is_array($data->tpl_vars[ $tpl_var ]->value)) {
+ settype($data->tpl_vars[ $tpl_var ]->value, 'array');
+ }
+ if ($merge && is_array($value)) {
+ foreach ($value as $_key => $_val) {
+ $data->tpl_vars[ $tpl_var ]->value[ $_key ] = &$value[ $_key ];
+ }
+ } else {
+ $data->tpl_vars[ $tpl_var ]->value[] = &$value;
+ }
+ if ($data->_isTplObj() && $data->scope) {
+ $data->ext->_updateScope->_updateScope($data, $tpl_var);
+ }
+ }
+ return $data;
+ }
+}