当前位置: 首页>>代码示例>>PHP>>正文


PHP resolve_pageid函数代码示例

本文整理汇总了PHP中resolve_pageid函数的典型用法代码示例。如果您正苦于以下问题:PHP resolve_pageid函数的具体用法?PHP resolve_pageid怎么用?PHP resolve_pageid使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。


在下文中一共展示了resolve_pageid函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: handle

 /**
  * Handle the match
  */
 function handle($match, $state, $pos, &$handler)
 {
     global $ID;
     $match = substr($match, 9, -11);
     // strip markup
     list($flags, $match) = explode('>', $match, 2);
     $flags = explode('&', substr($flags, 1));
     $items = explode('*', $match);
     $pages = array();
     $c = count($items);
     for ($i = 0; $i < $c; $i++) {
         if (!preg_match('/\\[\\[(.+?)\\]\\]/', $items[$i], $match)) {
             continue;
         }
         list($id, $title, $description) = explode('|', $match[1], 3);
         list($id, $section) = explode('#', $id, 2);
         if (!$id) {
             $id = $ID;
         }
         resolve_pageid(getNS($ID), $id, $exists);
         // page has an image title
         if ($title && preg_match('/\\{\\{(.+?)\\}\\}/', $title, $match)) {
             list($image, $title) = explode('|', $match[1], 2);
             list($ext, $mime) = mimetype($image);
             if (!substr($mime, 0, 5) == 'image') {
                 $image = '';
             }
             $pages[] = array('id' => $id, 'section' => cleanID($section), 'title' => trim($title), 'image' => trim($image), 'description' => trim($description), 'exists' => $exists);
             // text title (if any)
         } else {
             $pages[] = array('id' => $id, 'section' => cleanID($section), 'title' => trim($title), 'description' => trim($description), 'exists' => $exists);
         }
     }
     return array($flags, $pages);
 }
开发者ID:kosenconf,项目名称:kcweb,代码行数:38,代码来源:syntax.php

示例2: getMainPageId

 private function getMainPageId($ns)
 {
     $idMainPage = $ns['id'] . ':';
     resolve_pageid('', $idMainPage, $exist);
     //get the id of the main page of the ns
     return $exist ? $idMainPage : null;
 }
开发者ID:phillip-hopper,项目名称:nspages,代码行数:7,代码来源:namespacePreparer.php

示例3: tpl_processStartPage

/**
 * Table of content-function that will
 * create a hierarchical TOC for the site (by namespace)
 * and highlight the current page
 * The startpage if it exists, will always
 * be shown first in the menu
 */
function tpl_processStartPage($ns, $context)
{
    // Check if a start page exists and add it first
    global $conf;
    $pageExists = false;
    $startPageName = $conf['start'];
    if ($ns == "") {
        $startPageID = $startPageName;
    } else {
        $startPageID = $ns . ":" . $startPageName;
    }
    $startPagePath = $startPageID;
    resolve_pageid($ns, $startPagePath, $pageExists);
    if ($pageExists) {
        // Check if page is visible
        $perm = auth_quickaclcheck($startPageID);
        if ($perm > 0) {
            // Determine Page Title from first heading
            $firstHeading = p_get_first_heading($startPageID);
            if ($conf['useheading'] && !empty($firstHeading)) {
                $linkName = $firstHeading;
            } else {
                $linkName = $startPageName;
            }
            // echo "<b>" . $conf['useheading'] ."</b>";
            tpl_pageLinkCreate($startPageID, '<i class="icon-home"></i>' . $linkName, "tpl_processStartPage:{$context}");
        }
    }
}
开发者ID:jacobbates,项目名称:Help-Desk-Wiki-Theme,代码行数:36,代码来源:sidebar.php

示例4: internallink

 function internallink($id, $name = NULL, $search = NULL, $returnonly = false)
 {
     global $ID;
     // default name is based on $id as given
     $default = $this->_simpleTitle($id);
     // now first resolve and clean up the $id
     resolve_pageid(getNS($ID), $id, $exists);
     $name = $this->_getLinkTitle($name, $default, $isImage, $id);
     if (!$isImage) {
         if ($exists) {
             $class = 'wikilink1';
         } else {
             $class = 'wikilink2';
         }
     } else {
         $class = 'media';
     }
     //keep hash anchor
     list($id, $hash) = split('#', $id, 2);
     //prepare for formating
     $link['class'] = $class;
     $link['url'] = str_replace(':', '-', $id) . $this->ext;
     $link['name'] = $name;
     $link['title'] = str_replace(':', '-', $id) . $this->ext;
     //keep hash
     if ($hash) {
         $link['url'] .= '#' . $hash;
     }
     $this->doc .= $this->_formatLink($link);
 }
开发者ID:bomberstudios,项目名称:dokuwiki-offline-html,代码行数:30,代码来源:renderer.php

示例5: normalize

 function normalize($value, $hint)
 {
     global $ID;
     // fragment reference special case
     if (!empty($hint) && substr($hint, -1) == '#') {
         $value = $hint . $value;
         resolve_pageid(getNS($hint), $value, $exists);
         return $value;
     }
     $base = $hint ?: getNS($ID);
     // check for local link, and prefix full page id
     // (local links don't get resolved by resolve_pageid)
     if (preg_match('/^#.+/', $value)) {
         $value = $ID . $value;
     }
     // resolve page id with respect to selected base
     resolve_pageid($base, $value, $exists);
     // if the value is empty after resolving, it is a reference to the
     // root starting page. (We can not put the emtpy string into the
     // database as a normalized reference -- this will create problems)
     if ($value == '') {
         global $conf;
         $value = $conf['start'];
     }
     return $value;
 }
开发者ID:virk,项目名称:dokuwiki-strata,代码行数:26,代码来源:page.php

示例6: handleAjax

 /**
  * Autocompletion support for pages
  *
  * @return array
  */
 public function handleAjax()
 {
     global $INPUT;
     // check minimum length
     $lookup = trim($INPUT->str('search'));
     if (utf8_strlen($lookup) < $this->config['autocomplete']['mininput']) {
         return array();
     }
     // results wanted?
     $max = $this->config['autocomplete']['maxresult'];
     if ($max <= 0) {
         return array();
     }
     // lookup with namespace and postfix applied
     $namespace = $this->config['autocomplete']['namespace'];
     if ($namespace) {
         // namespace may be relative, resolve in current context
         $namespace .= ':foo';
         // resolve expects pageID
         resolve_pageid($INPUT->str('ns'), $namespace, $exists);
         $namespace = getNS($namespace);
     }
     $postfix = $this->config['autocomplete']['postfix'];
     if ($namespace) {
         $lookup .= ' @' . $namespace;
     }
     $data = ft_pageLookup($lookup, true, $this->config['usetitles']);
     if (!count($data)) {
         return array();
     }
     // this basically duplicates what we do in ajax_qsearch()
     $result = array();
     $counter = 0;
     foreach ($data as $id => $title) {
         if ($this->config['usetitles']) {
             $name = $title . ' (' . $id . ')';
         } else {
             $ns = getNS($id);
             if ($ns) {
                 $name = noNS($id) . ' (' . $ns . ')';
             } else {
                 $name = $id;
             }
         }
         // check suffix
         if ($postfix && substr($id, -1 * strlen($postfix)) != $postfix) {
             continue;
             // page does not end in postfix, don't suggest it
         }
         $result[] = array('label' => $name, 'value' => $id);
         $counter++;
         if ($counter > $max) {
             break;
         }
     }
     return $result;
 }
开发者ID:cosmocode,项目名称:dokuwiki-plugin-struct,代码行数:62,代码来源:Page.php

示例7: test_resolve_pageid_empty_homepage

 /**
  * Empty page on homepage should resolve to start page
  */
 function test_resolve_pageid_empty_homepage()
 {
     global $ID;
     $ID = '';
     global $conf;
     $conf['start'] = 'someverystrangestartname';
     $ns = '';
     $page = '';
     $exist = true;
     resolve_pageid($ns, $page, $exist);
     $this->assertEquals($page, $conf['start']);
 }
开发者ID:richmahn,项目名称:Door43,代码行数:15,代码来源:pageutils_resolve_pageid.test.php

示例8: handle

 /**
  * Handler to prepare matched data for the rendering process
  *
  * @param   string       $match   The text matched by the patterns
  * @param   int          $state   The lexer state for the match
  * @param   int          $pos     The character position of the matched text
  * @param   Doku_Handler $handler The Doku_Handler object
  * @return  bool|array Return an array with all data you want to use in render, false don't add an instruction
  */
 public function handle($match, $state, $pos, Doku_Handler $handler)
 {
     global $ID;
     $ns = substr($match, 8, strpos($match, '|') - 8);
     $id = $ns . ':start';
     resolve_pageid(getNS($ID), $id, $exists);
     $ns = getNS($id);
     $title = substr($match, strpos($match, '|') + 1, -2);
     $link = '?do=export_pdfns&book_ns=' . $ns . '&book_title=' . $title;
     $title = substr($title, 0, strpos($title, '&'));
     return array('link' => $link, 'title' => sprintf($this->getLang('export_ns'), $ns, $title), $state, $pos);
 }
开发者ID:phillip-hopper,项目名称:dokuwiki-plugin-dw2pdf,代码行数:21,代码来源:exportlink.php

示例9: run

 /**
  * Handle the user input [required]
  *
  * @param helper_plugin_bureaucracy_field[] $fields the list of fields in the form
  * @param string                            $thanks the thank you message as defined in the form
  *                                                  or default one. Might be modified by the action
  *                                                  before returned
  * @param array                             $argv   additional arguments passed to the action
  * @return bool|string false on error, $thanks on success
  */
 public function run($fields, $thanks, $argv)
 {
     global $ID;
     // prepare replacements
     $this->prepareNamespacetemplateReplacements();
     $this->prepareDateTimereplacements();
     $this->prepareLanguagePlaceholder();
     $this->prepareNoincludeReplacement();
     $this->prepareFieldReplacements($fields);
     //handle arguments
     $page_to_modify = array_shift($argv);
     if ($page_to_modify === '_self') {
         # shortcut to modify the same page as the submitter
         $page_to_modify = $ID;
     } else {
         //resolve against page which contains the form
         resolve_pageid(getNS($ID), $page_to_modify, $ignored);
     }
     $template_section_id = cleanID(array_shift($argv));
     if (!page_exists($page_to_modify)) {
         msg(sprintf($this->getLang('e_pagenotexists'), html_wikilink($page_to_modify)), -1);
         return false;
     }
     // check auth
     //
     // This is an important point.  In order to be able to modify a page via this method ALL you need is READ access to the page
     // This is good for admins to be able to only allow people to modify a page via a certain method.  If you want to protect the page
     // from people to WRITE via this method, deny access to the form page.
     $auth = $this->aclcheck($page_to_modify);
     // runas
     if ($auth < AUTH_READ) {
         msg($this->getLang('e_denied'), -1);
         return false;
     }
     // fetch template
     $template = rawWiki($page_to_modify);
     if (empty($template)) {
         msg(sprintf($this->getLang('e_template'), $page_to_modify), -1);
         return false;
     }
     // do the replacements
     $template = $this->updatePage($template, $template_section_id);
     if (!$template) {
         msg(sprintf($this->getLang('e_failedtoparse'), $page_to_modify), -1);
         return false;
     }
     // save page
     saveWikiText($page_to_modify, $template, sprintf($this->getLang('summary'), $ID));
     //thanks message with redirect
     $link = wl($page_to_modify);
     return sprintf($this->getLang('pleasewait'), "<script type='text/javascript' charset='utf-8'>location.replace('{$link}')</script>", html_wikilink($page_to_modify));
 }
开发者ID:nadabenlahbib,项目名称:dokuwiki-pagemod,代码行数:62,代码来源:pagemod.php

示例10: render

 function render($format, &$renderer, $data)
 {
     if ($format != 'xhtml') {
         return;
     }
     global $ID;
     $svg_wiki_page = trim(substr($data[1], 6, -2));
     //name of wiki page containing SVG image
     resolve_pageid(getNS($ID), $svg_wiki_page, $exists);
     //resolve relative IDs
     //detect image size for stupid browsers (like firefox) - ugly (fails if svg does not contain information about it's size)
     $svg_dimensions = '';
     preg_match('/width="[0-9]+" height="[0-9]+"/', $data[1] . rawWiki($svg_wiki_page), $_);
     if (isset($_[0])) {
         $svg_dimensions = $_[0];
     }
     // Check alignment
     $ralign = (bool) preg_match('/^\\{\\{ /', $data[1]);
     $lalign = (bool) preg_match('/ \\}\\}$/', $data[1]);
     switch (true) {
         case $lalign & $ralign:
             $align = 'center';
             break;
         case $ralign:
             $align = 'right';
             break;
         case $lalign:
             $align = 'left';
             break;
         default:
             $align = '';
     }
     if ($data[0] === '<svg') {
         $svgenc = $this->svg_base64_encode($data[1]);
         $renderer->doc .= $this->svg_format_embed($svgenc, 'inline-svg@' . $ID, $svg_dimensions);
         return true;
     }
     if ($data[0] === '{{sv' || $data[0] === '{{ s') {
         $svglink = exportlink($svg_wiki_page, 'svg');
         $renderer->doc .= $this->svg_format_embed($svglink, 'image:' . htmlspecialchars($svg_wiki_page), $svg_dimensions, $align);
         $renderer->doc .= '<br /><small>' . html_wikilink($svg_wiki_page, 'svg@' . $svg_wiki_page) . '</small>';
         return true;
     }
     if ($data[0] === '{{SV' || $data[0] === '{{ S') {
         $svgenc = $this->svg_base64_encode(rawWiki($svg_wiki_page));
         $renderer->doc .= $this->svg_format_embed($svgenc, 'image:' . htmlspecialchars($svg_wiki_page), $svg_dimensions, $align);
         $renderer->doc .= '<br /><small>' . html_wikilink($svg_wiki_page, 'SVG@' . $svg_wiki_page) . '</small>';
         return true;
     }
 }
开发者ID:rubyjedi,项目名称:DokuWiki-Plugin-SVGEdit,代码行数:50,代码来源:syntax.php

示例11: getNamespaceFromID

 /**
  * Returns an utf8 encoded Namespace for a Page and input Namespace
  * @param $NS
  * @param $PAGE
  */
 function getNamespaceFromID($NS, &$PAGE)
 {
     global $conf;
     // Check current page - if its an NS add the startpage
     $clean = true;
     resolve_pageid(getNS($NS), $NS, $clean);
     if (!page_exists($NS) && array_pop(explode(':', $NS)) != strtolower($conf['start'])) {
         // Compare to lowercase since clean lowers it.
         $NS .= ':' . $conf['start'];
         resolve_pageid(getNS($NS), $NS, $clean);
     }
     $PAGE = noNS($NS);
     $NS = getNS($NS);
     return utf8_encodeFN(str_replace(':', '/', $NS));
 }
开发者ID:omusico,项目名称:isle-web-framework,代码行数:20,代码来源:functions.php

示例12: handle

 /**
  * Handler to prepare matched data for the rendering process
  */
 function handle($match, $state, $pos, &$handler)
 {
     global $ID;
     if ($match == '~~BACKLINKS~~') {
         //check for deprecated syntax
         $match = $ID;
     } else {
         $match = substr($match, 12, -2);
         //strip {{backlinks> from start and }} from end
         $match = $match == '.' ? $ID : $match;
         if (strstr($match, ".:")) {
             resolve_pageid(getNS($ID), $match, $exists);
         }
     }
     return array($match);
 }
开发者ID:houshuang,项目名称:folders2web,代码行数:19,代码来源:syntax.php

示例13: _normalize_internallink

 /**
  * Normalizes an internal link.
  */
 function _normalize_internallink($instruction)
 {
     global $ID;
     // split off query string
     $parts = explode('?', $instruction[0], 2);
     $id = $parts[0];
     list($id, $hash) = explode('#', $id, 2);
     // normalize selflink
     if ($id === '') {
         $id = $ID;
     }
     // actually resolve the page
     resolve_pageid(getNS($ID), $id, $exists);
     // render the link
     return $this->_linkSyntax($instruction, $id . '#' . $hash);
 }
开发者ID:virk,项目名称:dokuwiki-strata,代码行数:19,代码来源:wiki.php

示例14: handle

 /**
  * Handler to prepare matched data for the rendering process.
  * @see DokuWiki_Syntax_Plugin::handle()
  */
 function handle($match, $state, $pos, &$handler)
 {
     // Take the id of the source
     // It can be a rendering of a sidebar
     global $INFO;
     global $ID;
     $id = $ID;
     // If it's a sidebar, get the original id.
     if ($INFO != null) {
         $id = $INFO['id'];
     }
     $match = substr($match, 12, -2);
     //strip {{backlinks> from start and }} from end
     $match = $match == '.' ? $id : $match;
     if (strstr($match, ".:")) {
         resolve_pageid(getNS($id), $match, $exists);
     }
     return array($match);
 }
开发者ID:rusidea,项目名称:analitika,代码行数:23,代码来源:syntax.php

示例15: dw_internal_links

function dw_internal_links($page)
{
    global $conf;
    $instructions = p_get_instructions(file_get_contents($page['file']));
    $links = array();
    $cns = getNS($page['id']);
    $exists = false;
    foreach ($instructions as $ins) {
        if ($ins[0] == 'internallink' || $conf['camelcase'] && $ins[0] == 'camelcaselink') {
            $mid = $ins[1][0];
            resolve_pageid($cns, $mid, $exists);
            if (!$exists) {
                list($mid) = explode('#', $mid);
                //record pages without hashs
                $links[] = $mid;
            }
        }
    }
    return $links;
}
开发者ID:omusico,项目名称:isle-web-framework,代码行数:20,代码来源:wantedpages.php


注:本文中的resolve_pageid函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。