From bb07324f762708142f2158da1a8060f9f812c28b Mon Sep 17 00:00:00 2001 From: rvelices Date: Wed, 19 Sep 2007 03:06:16 +0000 Subject: - fix: quick search error if the query term contained " or ' - optimized sql query in sync_users (called every time on admin page) - a lot faster when #user_cache_categories is big - added function Template->delete_block_vars (opposite of assign_block_vars) git-svn-id: http://piwigo.org/svn/branches/branch-1_7@2094 68402e56-0260-453c-a942-63ccdbb3a9ee --- admin/include/functions.php | 4 ++-- include/category_cats.inc.php | 10 +++++----- include/template.php | 37 +++++++++++++++++++++++++++++++++++++ qsearch.php | 2 +- 4 files changed, 45 insertions(+), 8 deletions(-) diff --git a/admin/include/functions.php b/admin/include/functions.php index 3614c0904..23cf41180 100644 --- a/admin/include/functions.php +++ b/admin/include/functions.php @@ -1159,7 +1159,7 @@ SELECT user_id foreach ($tables as $table) { $query = ' -SELECT user_id +SELECT DISTINCT user_id FROM '.$table.' ;'; $to_delete = array_diff( @@ -1989,4 +1989,4 @@ UPDATE '.USER_CACHE_TABLE.' pwg_query($query); trigger_action('invalidate_user_cache'); } -?> +?> \ No newline at end of file diff --git a/include/category_cats.inc.php b/include/category_cats.inc.php index 3ef955b4c..82d1eb11d 100644 --- a/include/category_cats.inc.php +++ b/include/category_cats.inc.php @@ -223,13 +223,13 @@ if (count($categories) > 0) '
' ), 'DESCRIPTION' => - trigger_event('render_category_literal_description', - trigger_event('render_category_description', + trigger_event('render_category_literal_description', + trigger_event('render_category_description', @$category['comment'])), 'NAME' => $name, ) ); - + //plugins need to add/modify sth in this loop ? trigger_action('loc_index_category_thumbnail', $category, 'categories.category' ); @@ -314,8 +314,8 @@ if (count($categories) > 0) } $template->assign_var_from_handle('CATEGORIES', 'thumbnails'); - unset( $template->_tpldata['thumbnails.'] );//maybe write a func for that + $template->delete_block_vars('thumbnails', true); // category_default reuse them } trigger_action('loc_end_index_category_thumbnails', $categories); } -?> +?> \ No newline at end of file diff --git a/include/template.php b/include/template.php index 0e8f626f0..7d93237e6 100644 --- a/include/template.php +++ b/include/template.php @@ -295,6 +295,43 @@ class Template { return true; } + /** + * Block-level variable deletion. Deletes the last block iteration. + * if all is true - all blocks are removed + * return true if a deletion occured + */ + function delete_block_vars($blockname, $all=false) + { + $blocks = explode('.', $blockname); + $blockcount = count($blocks); + $str = '$this->_tpldata'; + for ($i = 0; $i < $blockcount; $i++) + { + $str .= '[\'' . $blocks[$i] . '.\']'; + eval('$lastiteration = isset('.$str.') ? sizeof('.$str.')-1:-1;'); + if ($lastiteration==-1) + { + return false; + } + if ($i==$blockcount-1) + { + break; + } + $str .= '[' . $lastiteration . ']'; + } + + if ($all==true or $lastiteration==0) + { + $str ='unset('.$str.');'; + } + else + { + $str ='unset('.$str.'['.$lastiteration.']);'; + } + eval($str); + return true; + } + /** * Root-level variable assignment. Adds to current assignments, overriding * any existing variable assignment with the same name. diff --git a/qsearch.php b/qsearch.php index a7fc1d956..2635ea31a 100644 --- a/qsearch.php +++ b/qsearch.php @@ -43,7 +43,7 @@ $query =' INSERT INTO '.SEARCH_TABLE.' (rules, last_seen) VALUES - (\''.serialize($search).'\', NOW() ) + (\''.addslashes(serialize($search)).'\', NOW() ) ;'; pwg_query($query); -- cgit v1.2.3