Some more small tweaks for speed.

This commit is contained in:
jgen 2013-10-04 17:17:42 -04:00
parent 70428b2b5d
commit 0512858bd4
3 changed files with 26 additions and 19 deletions

View file

@ -148,9 +148,9 @@ class Image {
public static function count_images($tags=array()) {
assert(is_array($tags));
global $database;
$tag_count = count($tags);
if($tag_count == 0) {
$tag_count = count($tags);
if($tag_count === 0) {
$total = $database->cache->get("image-count");
if(!$total) {
$total = $database->get_one("SELECT COUNT(*) FROM images");
@ -158,7 +158,7 @@ class Image {
}
return $total;
}
else if($tag_count == 1 && !preg_match("/[:=><\*\?]/", $tags[0])) {
else if($tag_count === 1 && !preg_match("/[:=><\*\?]/", $tags[0])) {
$term = Tag::resolve_alias($tags[0]);
return $database->get_one(
$database->scoreql_to_sql("SELECT count FROM tags WHERE SCORE_STRNORM(tag) = SCORE_STRNORM(:tag)"),
@ -207,7 +207,7 @@ class Image {
$dir = "ASC";
}
if(count($tags) == 0) {
if(count($tags) === 0) {
$row = $database->get_row('SELECT images.* FROM images WHERE images.id '.$gtlt.' '.$this->id.' ORDER BY images.id '.$dir.' LIMIT 1');
}
else {
@ -584,14 +584,14 @@ class Image {
$_flexihash = new Flexihash();
foreach(explode(",", $opts) as $opt) {
$parts = explode("=", $opt);
$parts_count = count($parts);
$parts_count = count($parts);
$opt_val = "";
$opt_weight = 0;
if($parts_count == 2) {
if($parts_count === 2) {
$opt_val = $parts[0];
$opt_weight = $parts[1];
}
elseif($parts_count == 1) {
elseif($parts_count === 1) {
$opt_val = $parts[0];
$opt_weight = 1;
}
@ -694,9 +694,11 @@ class Image {
}
$img_search = new Querylet($sql, $terms);
// How many tag querylets are there?
$count_tag_querylets = count($tag_querylets);
// no tags, do a simple search (+image metadata if we have any)
if(count($tag_querylets) == 0) {
if(count_tag_querylets === 0) {
$query = new Querylet("SELECT images.* FROM images ");
if(!empty($img_search->sql)) {
@ -706,7 +708,7 @@ class Image {
}
// one positive tag (a common case), do an optimised search
else if(count($tag_querylets) == 1 && $tag_querylets[0]->positive) {
else if(count_tag_querylets === 1 && $tag_querylets[0]->positive) {
$query = new Querylet($database->scoreql_to_sql("
SELECT images.* FROM images
JOIN image_tags ON images.id=image_tags.image_id
@ -990,7 +992,7 @@ class Tag {
}
}
if(count($tag_array) == 0 && $tagme) {
if(count($tag_array) === 0 && $tagme) {
$tag_array = array("tagme");
}
@ -1106,8 +1108,8 @@ function move_upload_to_archive(DataUploadEvent $event) {
function get_thumbnail_size(/*int*/ $orig_width, /*int*/ $orig_height) {
global $config;
if($orig_width == 0) $orig_width = 192;
if($orig_height == 0) $orig_height = 192;
if($orig_width === 0) $orig_width = 192;
if($orig_height === 0) $orig_height = 192;
if($orig_width > $orig_height * 5) $orig_width = $orig_height * 5;
if($orig_height > $orig_width * 5) $orig_height = $orig_width * 5;

View file

@ -797,7 +797,7 @@ function data_path($filename) {
function transload($url, $mfile) {
global $config;
if($config->get_string("transload_engine") == "curl" && function_exists("curl_init")) {
if($config->get_string("transload_engine") === "curl" && function_exists("curl_init")) {
$ch = curl_init($url);
$fp = fopen($mfile, "w");
@ -814,7 +814,7 @@ function transload($url, $mfile) {
return true;
}
if($config->get_string("transload_engine") == "wget") {
if($config->get_string("transload_engine") === "wget") {
$s_url = escapeshellarg($url);
$s_mfile = escapeshellarg($mfile);
system("wget --no-check-certificate $s_url --output-document=$s_mfile");
@ -822,7 +822,7 @@ function transload($url, $mfile) {
return file_exists($mfile);
}
if($config->get_string("transload_engine") == "fopen") {
if($config->get_string("transload_engine") === "fopen") {
$fp = @fopen($url, "r");
if(!$fp) {
return false;

View file

@ -162,10 +162,13 @@ class Index extends Extension {
$search_terms = $event->get_search_terms();
$page_number = $event->get_page_number();
$page_size = $event->get_page_size();
$count_search_terms = count($search_terms);
try {
#log_debug("index", "Search for ".implode(" ", $search_terms), false, array("terms"=>$search_terms));
$total_pages = Image::count_pages($search_terms);
if(SPEED_HAX && count($search_terms) == 0 && ($page_number < 10)) { // extra caching for the first few post/list pages
if(SPEED_HAX && $count_search_terms === 0 && ($page_number < 10)) { // extra caching for the first few post/list pages
$images = $database->cache->get("post-list-$page_number");
if(!$images) {
$images = Image::find_images(($page_number-1)*$page_size, $page_size, $search_terms);
@ -182,11 +185,13 @@ class Index extends Extension {
$images = array();
}
if(count($search_terms) == 0 && count($images) == 0 && $page_number == 1) {
$count_images = count($images);
if($count_search_terms === 0 && $count_images === 0 && $page_number === 1) {
$this->theme->display_intro($page);
send_event(new PostListBuildingEvent($search_terms));
}
else if(count($search_terms) > 0 && count($images) == 1 && $page_number == 1) {
else if($count_search_terms > 0 && $count_images === 1 && $page_number === 1) {
$page->set_mode("redirect");
$page->set_redirect(make_link('post/view/'.$images[0]->id));
}