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)); }