From: umorigu Date: Mon, 12 Jun 2017 18:40:00 +0000 (+0900) Subject: BugTrack/782 Numbering tracker issue naturally : the biggest one + 1 X-Git-Tag: r1_5_4~216 X-Git-Url: http://git.osdn.net/view?p=pukiwiki%2Fpukiwiki.git;a=commitdiff_plain;h=32c7cdee02d7c2d5e71a384ad7377bcbf26b0b3d BugTrack/782 Numbering tracker issue naturally : the biggest one + 1 --- diff --git a/.gitignore b/.gitignore index 869577a..a2fe7cd 100644 --- a/.gitignore +++ b/.gitignore @@ -18,6 +18,7 @@ /wiki.en/*.txt /nbproject/** +/.vscode/ # Composer files /vendor/ diff --git a/plugin/tracker.inc.php b/plugin/tracker.inc.php index 56ecc4e..d7f6320 100644 --- a/plugin/tracker.inc.php +++ b/plugin/tracker.inc.php @@ -1,7 +1,7 @@ 'page name ('.htmlsc($base).') is not valid.' ); } - $num = 0; $name = (array_key_exists('_name',$post)) ? $post['_name'] : ''; - if (array_key_exists('_page',$post)) - { - $page = $real = $post['_page']; - } - else - { - $real = is_pagename($name) ? $name : ++$num; - $page = get_fullname('./'.$real,$base); - } - if (!is_pagename($page)) - { - $page = $base; - } - - while (is_page($page)) - { - $real = ++$num; - $page = "$base/$real"; + $_page = (array_key_exists('_page',$post)) ? $post['_page'] : ''; + if (is_pagename($_page)) { + // Create _page page if _page is in parameters + $page = $real = $_page; + } else if (is_pagename($name)) { + // Create "$base/$name" page if _name is in parameters + $real = $name; + $page = get_fullname('./' . $name, $base); + } else { + $page = ''; + } + if (!is_pagename($page) || is_page($page)) { + // Need new page name => Get last article number + 1 + $page_list = plugin_tracker_get_page_list($base, false); + usort($page_list, '_plugin_tracker_list_paganame_compare'); + if (count($page_list) === 0) { + $num = 1; + } else { + $latest_page = $page_list[count($page_list) - 1]['name']; + $num = intval(substr($latest_page, strlen($base) + 1)) + 1; + } + $real = '' . $num; + $page = $base . '/' . $num; } // ページデータを生成 $postdata = plugin_tracker_get_source($source); @@ -187,6 +191,35 @@ function plugin_tracker_action() header('Location: ' . get_script_uri() . '?' . $r_page); exit; } + +/** + * Page_list comparator + */ +function _plugin_tracker_list_paganame_compare($a, $b) +{ + return strnatcmp($a['name'], $b['name']); +} + +/** + * Get page list for "$page/" + */ +function plugin_tracker_get_page_list($page, $needs_filetime) { + $page_list = array(); + $pattern = $page . '/'; + $pattern_len = strlen($pattern); + foreach (get_existpages() as $p) { + if (strncmp($p, $pattern, $pattern_len) === 0 && pkwk_ctype_digit(substr($p, $pattern_len))) { + if ($needs_filetime) { + $page_list[] = array('name'=>$p,'filetime'=>get_filetime($p)); + } else { + $page_list[] = array('name'=>$p); + } + } + } + return $page_list; +} + + /* function plugin_tracker_inline() { diff --git a/plugin/tracker_list.inc.php b/plugin/tracker_list.inc.php index d3b2d41..f69ee83 100644 --- a/plugin/tracker_list.inc.php +++ b/plugin/tracker_list.inc.php @@ -1,6 +1,8 @@