X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/bc6019f39a712d18437161942174649589635cb9..f6a56971c28026ca8f67783518b0ba6a39e1f8bc:/article.inc.php
diff --git a/article.inc.php b/article.inc.php
index d42e498..503c5a1 100644
--- a/article.inc.php
+++ b/article.inc.php
@@ -23,20 +23,26 @@ class ArchiveArticle
{
$this->page = preg_replace('{^\.(?:/|$)}', '', $path);
$this->link = preg_replace('{(?:/index)?\.html$}', '', $this->page);
- if (file_exists($this->page)) {
- $this->raw = file_get_contents($this->page);
-
- if (preg_match_all('{
- \G \s*
- }x', $this->raw, $meta)) {
- $matchlen = array_sum(array_map('strlen', $meta[0]));
- $this->raw = substr($this->raw, $matchlen); # delete matched contents
- $this->meta = array_combine($meta[1], $meta[2]); # [property => content]
- }
+ $this->raw($this->page);
+ }
- @list ($this->preface, $this->title, $this->body) =
- preg_split('{
(.*?)
\s*}', $this->raw, 2, PREG_SPLIT_DELIM_CAPTURE);
+ function raw($page)
+ {
+ if (!file_exists($page)) {
+ return;
+ }
+ $this->raw = file_get_contents($page);
+
+ if (preg_match_all('{
+ \G \s*
+ }x', $this->raw, $meta)) {
+ $matchlen = array_sum(array_map('strlen', $meta[0]));
+ $this->raw = substr($this->raw, $matchlen); # delete matched contents
+ $this->meta = array_combine($meta[1], $meta[2]); # [property => content]
}
+
+ @list ($this->preface, $this->title, $this->body) =
+ preg_split('{(.*?)
\s*}s', $this->raw, 2, PREG_SPLIT_DELIM_CAPTURE);
}
function __get($col)
@@ -44,6 +50,30 @@ class ArchiveArticle
return $this->$col = $this->$col(); # run method and cache
}
+ function handler()
+ {
+ $path = $this->link;
+ $this->path = '';
+ $this->restricted = FALSE;
+ while (TRUE) {
+ if (file_exists("$path/.private")) {
+ $this->restricted = $path;
+ }
+
+ if (file_exists("$path/index.php")) {
+ return $path;
+ }
+
+ $up = strrpos($path, '/');
+ $this->path = substr($path, $up) . $this->path;
+ $path = substr($path, 0, $up);
+ if ($up === FALSE) {
+ break;
+ }
+ }
+ return;
+ }
+
function safetitle()
{
return trim($this->meta['og:title'] ?? strip_tags($this->title));
@@ -80,7 +110,7 @@ class ArchiveArticle
function story()
{
if ( preg_match('{
- \n (?: < (?: p | figure [^>]* ) >\s* )+ (]*>) | \n
+ (?: < (?: p | figure [^>]* ) >\s* )+ (]*>) | \n
}x', $this->body, $img, PREG_OFFSET_CAPTURE) ) {
# strip part after matching divider (image)
if (isset($img[1])) {
@@ -109,7 +139,7 @@ class ArchiveArticle
# starting paragraph for documents without title (assumed simple/partial)
if (strpos($this->raw, ' \s* (.*?)
+ \A (?: ]*> \s* )*
\s* (.*?)
}sx', $this->raw, $bodyp)) {
return $bodyp[1];
}