X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/33080d973223a1f322f2c1248bc896efe8b59dfc..v3.2-15-gf08646f0f4:/thumb/index.php?ds=inline diff --git a/thumb/index.php b/thumb/index.php index f7c36d9..2849bb5 100644 --- a/thumb/index.php +++ b/thumb/index.php @@ -13,33 +13,44 @@ if (!file_exists($imgpath)) { } } -$target = "thumb/$height/$imgpath"; -if (!file_exists($target)) { - try { - mkthumb($imgpath, $target, $width, $height); - } - catch (Exception $e) { - http_response_code($e->getCode() ?: 500); - $target = '500.png'; - if (file_exists($target)) { - header("X-Error: ".$e->getMessage()); - header('Content-type: '.mime_content_type($target)); - readfile($target); - exit; - } - trigger_error("thumbnail creation failed: ".$e->getMessage(), E_USER_WARNING); +try { + $target = mkthumb($imgpath, $width, $height); +} +catch (Exception $e) { + http_response_code($e->getCode() ?: 500); + $target = '500.png'; + if (file_exists($target)) { + header("X-Error: ".$e->getMessage()); + header('Content-type: '.mime_content_type($target)); + readfile($target); exit; } + trigger_error("thumbnail creation failed: ".$e->getMessage(), E_USER_WARNING); + exit; } header('Content-type: '.mime_content_type($target)); readfile($target); exit; -function mkthumb($source, $target, $width, $height) +function mkthumb($source, $width, $height) { + $target = "thumb/$height/$source"; + + if (isset($_GET['backend'])) { + $backend = $_GET['backend']; + } + elseif (file_exists($target)) { + return; + } + else { + $backend = 'exec'; + } + $backend = "mkthumb_$backend"; + @mkdir(dirname($target), 0777, TRUE); - return mkthumb_exec($source, $target, $width, $height); + $backend($source, $target, $width, $height); + return $target; } function mkthumb_exec($source, $target, $width, $height)