<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.cmark.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'class.commonmark-cql.php',
    1 => 'CommonMark\\CQL',
    2 => 'Класс CommonMark\\CQL',
  ),
  'up' => 
  array (
    0 => 'book.cmark.php',
    1 => 'CommonMark',
  ),
  'prev' => 
  array (
    0 => 'commonmark-parser.finish.php',
    1 => 'CommonMark\\Parser::finish',
  ),
  'next' => 
  array (
    0 => 'commonmark-cql.construct.php',
    1 => 'CommonMark\\CQL::__construct',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/cmark/commonmark.cql.xml',
  ),
  'history' => 
  array (
  ),
  'extra_header_links' => 
  array (
    'rel' => 'alternate',
    'href' => '/manual/en/feeds/class.commonmark-cql.atom',
    'type' => 'application/atom+xml',
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="class.commonmark-cql" class="reference">

 <h1 class="title">Класс CommonMark\CQL</h1>
 

 <div class="partintro"><p class="verinfo">(cmark &gt;= 1.1.0)</p>

  
  <div class="section" id="commonmark-cql.intro">
   <h2 class="title">Введение</h2>
   <p class="simpara">
    CommonMark Query Language - это DSL для описания того, как проходить через дерево узлов CommonMark, реализованное в виде синтаксического анализатора и компилятора для небольшого набора инструкций, и виртуальной машины для выполнения этих инструкций.
   </p>
   <p class="formalpara">
    <h5 class="title">Пути:</h5>
    <p class="para">
     В наиболее упрощённой форме запрос CQL объединяет следующие пути и <code class="literal">/</code>, чтобы описать, как перемещаться по дереву:
     <ul class="simplelist">
      <li>firstChild</li>
      <li>lastChild</li>
      <li>previous</li>
      <li>next</li>
      <li>parent</li>
     </ul>
     Например, <code class="literal">/firstChild/lastChild</code> будет перемещаться к последнему дочернему узлу первого дочернего узла.
    </p>
   </p>
   <p class="formalpara">
    <h5 class="title">Циклы</h5>
    <p class="para">
     В CQL может быть задан цикл, например, через дочерние элементы или дочерние элементы к определённому узлу с использованием пути <code class="literal">children</code> или <code class="literal">siblings</code>. Например, <code class="literal">/firstChild/children</code> будет перемещаться по всем дочерним элементам первого дочернего узла.
    </p>
   </p>
   <p class="formalpara">
    <h5 class="title">Подзапросы</h5>
    <p class="para">
     CQL можно проинструктировать, как перемещаться, используя подзапрос, такой как <code class="literal">[/firstChild]</code>. Например, <code class="literal">/firstChild/children[/firstChild]</code> перейдёт к первому дочернему узлу всех дочерних узлов первого дочернего узла.
    </p>
   </p>
   <p class="formalpara">
    <h5 class="title">Ограничения циклов</h5>
    <p class="para">
     Во время цикла CQL может быть проинструктирован ограничивать пройденный путь до узлов определённого типа. Например, <code class="literal">/children(BlockQuote)</code> будет перемещаться к дочерним элементам узла, где типом является <code class="literal">BlockQuote</code>. Следующие типы распознаются (без учёта регистра):
     <ul class="simplelist">
      <li>BlockQuote</li>
      <li>List</li>
      <li>Item</li>
      <li>CodeBlock</li>
      <li>HtmlBlock</li>
      <li>CustomBlock</li>
      <li>Paragraph</li>
      <li>Heading</li>
      <li>ThematicBreak</li>
      <li>Text</li>
      <li>SoftBreak</li>
      <li>LineBreak</li>
      <li>Code</li>
      <li>HtmlInline</li>
      <li>CustomInline</li>
      <li>Emphasis</li>
      <li>Strong</li>
      <li>Link</li>
      <li>Image</li>
     </ul>
     Типы могут использоваться как объединение, например, <code class="literal">/children(BlockQuote|List)</code> будет перемещаться к дочерним элементам узла, где типом является <code class="literal">BlockQuote</code> или <code class="literal">List</code>. Типы или объединения типов, также могут быть отменены. Например, <code class="literal">/children(~BlockQuote)</code> будет перемещаться к дочерним элементам узла, где тип не является <code class="literal">BlockQuote</code>, а <code class="literal">/children(~BlockQuote|Paragraph)</code> будет перемещаться к дочерним узлам, где тип не является <code class="literal">BlockQuote</code> или <code class="literal">Paragraph</code>.
    </p>
   </p>
   <p class="formalpara">
    <h5 class="title">Ограничения путей</h5>
    <p class="para">
     CQL можно поручить создать цикл для перемещения к узлу определённого типа по определённому пути. Например, <code class="literal">/firstChild(BlockQuote)</code> перейдёт к первому дочернему узлу с типом <code class="literal">BlockQuote</code>. Обратите внимание, что как и другие циклы, для <code class="literal">children</code> и <code class="literal">siblings</code>, этот тип пути может сопровождаться только подзапросом.
    </p>
   </p>
   <p class="formalpara">
    <h5 class="title">Замечания по реализации</h5>
    <p class="para">
     Хотя CQL реализован как часть модуля PHP CommonMark, он стоит отдельно от PHP и не использует виртуальную машину PHP или внутреннее представление значений.
    </p>
   </p>
  </div>
  

  <div class="section" id="commonmark-cql.synopsis">
   <h2 class="title">Обзор класса</h2>

   
   <div class="classsynopsis">
    <span class="ooclass"><strong class="classname"></strong></span>

    
    <div class="classsynopsisinfo">
     <span class="ooclass">
      <span class="modifier">class</span> <strong class="classname">CommonMark\CQL</strong>
     </span>
     {</div>
    

    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Конструктор */</div>
    <div class="constructorsynopsis dc-description">
   <span class="modifier">public</span> <span class="methodname"><a href="commonmark-cql.construct.php" class="methodname">__construct</a></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$query</code></span>)</div>


    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Методы */</div>
    <div class="methodsynopsis dc-description"><span class="modifier">public</span> <span class="methodname"><a href="commonmark-cql.invoke.php" class="methodname">__invoke</a></span>(<span class="methodparam"><span class="type"><a href="class.commonmark-node.php" class="type CommonMark\Node">CommonMark\Node</a></span> <code class="parameter">$root</code></span>, <span class="methodparam"><span class="type"><a href="language.types.callable.php" class="type callable">callable</a></span> <code class="parameter">$handler</code></span>)</div>

   }</div>
   

  </div>

 </div>

 





 






<h2>Содержание</h2><ul class="chunklist chunklist_reference"><li><a href="commonmark-cql.construct.php">CommonMark\CQL::__construct</a> — Конструктор класса CQL</li><li><a href="commonmark-cql.invoke.php">CommonMark\CQL::__invoke</a> — Выполнение CQL</li></ul>
</div>
<?php manual_footer($setup); ?>