Simplify relative path handling.
--HG-- extra : rebase_source : d20290cad2dca3ea1f04a85f899c026c0991bbe5
This commit is contained in:
parent
881f76d87a
commit
30f801443e
23
epubfs.php
23
epubfs.php
|
@ -13,27 +13,34 @@ $book = new EPub ("c:/Temp/Phare.epub");
|
||||||
$book->initSpineComponent ();
|
$book->initSpineComponent ();
|
||||||
|
|
||||||
$component = $_GET["comp"];
|
$component = $_GET["comp"];
|
||||||
$elementPath = NULL;
|
|
||||||
if (!empty ($_GET) && isset($_GET["path"]) && $_GET["path"] != "") {
|
|
||||||
$elementPath = $_GET["path"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty ($component)) {
|
if (empty ($component)) {
|
||||||
notFound ();
|
notFound ();
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$data = $book->component ($component, $elementPath);
|
$data = $book->component ($component);
|
||||||
$directory = dirname ($component);
|
$directory = dirname ($component);
|
||||||
|
|
||||||
$data = preg_replace ("/src=[\"']([^:]*?)[\"']/", "src='epubfs.php?path=$1&comp=$component'", $data);
|
$callback = function ($m) use ($book, $component) {
|
||||||
$data = preg_replace ("/href=[\"']([^:]*?)[\"']/", "href='epubfs.php?path=$1&comp=$component'", $data);
|
$method = $m[1];
|
||||||
$data = preg_replace ("/\@import\s+[\"'](.*?)[\"'];/", "@import 'epubfs.php?comp={$directory}/$1';", $data);
|
$path = $m[2];
|
||||||
|
if (preg_match ("/^#/", $path)) {
|
||||||
|
return $path;
|
||||||
|
}
|
||||||
|
$comp = $book->getComponentName ($component, $path);
|
||||||
|
return "$method'epubfs.php?comp=$comp'";
|
||||||
|
};
|
||||||
|
|
||||||
|
$data = preg_replace_callback ("/(src=)[\"']([^:]*?)[\"']/", $callback, $data);
|
||||||
|
$data = preg_replace_callback ("/(href=)[\"']([^:]*?)[\"']/", $callback, $data);
|
||||||
|
$data = preg_replace_callback ("/(\@import\s+)[\"'](.*?)[\"'];/", $callback, $data);
|
||||||
|
|
||||||
header ("Content-Type: " . $book->componentContentType($component));
|
header ("Content-Type: " . $book->componentContentType($component));
|
||||||
echo $data;
|
echo $data;
|
||||||
}
|
}
|
||||||
catch (Exception $e) {
|
catch (Exception $e) {
|
||||||
|
error_log ($e);
|
||||||
notFound ();
|
notFound ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -153,9 +153,9 @@ class EPub {
|
||||||
/**
|
/**
|
||||||
* Get the component content
|
* Get the component content
|
||||||
*/
|
*/
|
||||||
public function component($comp, $elementPath) {
|
public function component($comp) {
|
||||||
$path = str_replace ("-SLASH-", "/", $comp);
|
$path = str_replace ("-SLASH-", "/", $comp);
|
||||||
$path = $this->getFullPath ($path, $elementPath);
|
$path = $this->getFullPath ($path);
|
||||||
if (!$this->zip->FileExists($path)) {
|
if (!$this->zip->FileExists($path)) {
|
||||||
throw new Exception ("Unable to find " . $path);
|
throw new Exception ("Unable to find " . $path);
|
||||||
}
|
}
|
||||||
|
@ -164,6 +164,15 @@ class EPub {
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getComponentName ($comp, $elementPath) {
|
||||||
|
$path = str_replace ("-SLASH-", "/", $comp);
|
||||||
|
$path = $this->getFullPath ($path, $elementPath);
|
||||||
|
if (!$this->zip->FileExists($path)) {
|
||||||
|
throw new Exception ("Unable to find " . $path);
|
||||||
|
}
|
||||||
|
return str_replace ("/", "-SLASH-", $path);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the component content type
|
* Get the component content type
|
||||||
*/
|
*/
|
||||||
|
@ -533,7 +542,7 @@ class EPub {
|
||||||
if (!empty ($context)) {
|
if (!empty ($context)) {
|
||||||
$path = $this->combine (dirname ($path), $context);
|
$path = $this->combine (dirname ($path), $context);
|
||||||
}
|
}
|
||||||
error_log ("FullPath : $path ($file / $context)");
|
//error_log ("FullPath : $path ($file / $context)");
|
||||||
return $path;
|
return $path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue