X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=include%2Fsieve%2Fclass_My_Tree.inc;h=ee1276a36ac3c1aba3c85281c0f2aa6b0bd2696b;hb=4ef5a0ec2c799536446dd29d5d828488cc14608f;hp=38d252302e4085fb0cf8824305a85bc4ecd56a09;hpb=fd4a7f5e409113c4d808d3cc8ba01a6822faa6e3;p=gosa.git
diff --git a/include/sieve/class_My_Tree.inc b/include/sieve/class_My_Tree.inc
index 38d252302..ee1276a36 100644
--- a/include/sieve/class_My_Tree.inc
+++ b/include/sieve/class_My_Tree.inc
@@ -17,11 +17,11 @@ class My_Tree extends Tree
var $pap = array();
var $parent = NULL;
- function My_Tree(&$root,$parent)
- {
+ function My_Tree(&$root,$parent)
+ {
$this->parent = $parent;
- $this->_construct($root);
- }
+ $this->_construct($root);
+ }
function execute()
{
@@ -56,18 +56,21 @@ class My_Tree extends Tree
$block_indent_start = $smarty->fetch(get_template_path("templates/block_indent_start.tpl",TRUE,dirname(__FILE__)));
$block_indent_stop = $smarty->fetch(get_template_path("templates/block_indent_stop.tpl",TRUE,dirname(__FILE__)));
-
-
$this -> dump_ = "";
$ends = array();
- if(!count($this->pap)){
-# $this->pap[] = new sieve_comment(NULL,preg_replace("/[^0-9]/","",microtime()),$this);
- }
+ $ends_complete_block = array();
+
foreach($this->pap as $key => $object){
if(is_object($object)){
- $end = $this->get_block_end($key,false);
+ $end = $this->get_block_end($key,false);
+ $end2 = $this->get_block_end($key);
+ if($end != $key && in_array(get_class($object),array("sieve_if"))){
+ $ends_complete_block[$end2] = $end2;
+ $this->dump_ .= "
";
+ $this->dump_ .= "";
+ }
if(isset($ends[$key])){
$this->dump_ .= $block_indent_stop;
}
@@ -76,6 +79,11 @@ class My_Tree extends Tree
$ends[$end] = $end;
$this->dump_ .= $block_indent_start;
}
+
+ if(isset($ends_complete_block[$key])){
+ $this->dump_ .= "
";
+ $this->dump_ .= "";
+ }
}
}
@@ -622,12 +630,12 @@ class My_Tree extends Tree
function check()
{
- $msgs = array();
+ $msgs = array();
/* Some logical checks.
* like : only sieve_comment can appear before require.
*/
-
+
/* Ensure that there are no command before require
* - Get id of last require tag
* - Collect object types in from of this tag.
@@ -651,14 +659,14 @@ class My_Tree extends Tree
$msgs[] = $str;
print_red($str);;
}
-
- foreach($this->pap as $obj){
- $o_msgs = $obj->check();
- foreach($o_msgs as $o_msg){
- $msgs[] = $o_msg;
- }
- }
- return($msgs);
+
+ foreach($this->pap as $obj){
+ $o_msgs = $obj->check();
+ foreach($o_msgs as $o_msg){
+ $msgs[] = $o_msg;
+ }
+ }
+ return($msgs);
}
@@ -674,7 +682,7 @@ class My_Tree extends Tree
$require_id = $key;
}
}
-
+
/* No require found, add one */
if($require_id == -1){
$require = new sieve_require(NULL,preg_replace("/[^0-9]/","",microtime()),$this);
@@ -727,7 +735,7 @@ function sieve_create_strings($data,$force_string = FALSE)
}
$ret = preg_replace("/\"\"/","\"",$ret);
$ret = preg_replace("/\n/","\r\n",$ret);
-
+
return($ret);
}
@@ -743,7 +751,7 @@ function sieve_get_strings($data,$id)
$ret = array();
if($data[$id]['class'] == "left-bracket"){
while(isset($data[$id]) && $data[$id]['class'] != "right-bracket" && $id < count($data)){
-
+
if($data[$id]['class'] == "quoted-string"){
$ret[] = $data[$id]['text'];
}
@@ -759,7 +767,7 @@ function sieve_get_strings($data,$id)
$str = trim(preg_replace("/\.$/","",$str));
$ret[] = $str;
}
-
+
return(array("OFFSET" => $id, "STRINGS" => $ret));
}