PHP Classes

File: vendor/symfony/css-selector/CssSelectorConverter.php

Recommend this page to a friend!
  Classes of Renato Lucena   PHP Pokemon Script   vendor/symfony/css-selector/CssSelectorConverter.php   Download  
File: vendor/symfony/css-selector/CssSelectorConverter.php
Role: Class source
Content type: text/plain
Description: Class source
Class: PHP Pokemon Script
Provides an API to manage a database of Pokemons
Author: By
Last change:
Date: 6 years ago
Size: 1,995 bytes
 

Contents

Class file image Download
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\CssSelector;

use
Symfony\Component\CssSelector\Parser\Shortcut\ClassParser;
use
Symfony\Component\CssSelector\Parser\Shortcut\ElementParser;
use
Symfony\Component\CssSelector\Parser\Shortcut\EmptyStringParser;
use
Symfony\Component\CssSelector\Parser\Shortcut\HashParser;
use
Symfony\Component\CssSelector\XPath\Extension\HtmlExtension;
use
Symfony\Component\CssSelector\XPath\Translator;

/**
 * CssSelectorConverter is the main entry point of the component and can convert CSS
 * selectors to XPath expressions.
 *
 * @author Christophe Coevoet <stof@notk.org>
 */
class CssSelectorConverter
{
    private
$translator;

   
/**
     * @param bool $html Whether HTML support should be enabled. Disable it for XML documents
     */
   
public function __construct($html = true)
    {
       
$this->translator = new Translator();

        if (
$html) {
           
$this->translator->registerExtension(new HtmlExtension($this->translator));
        }

       
$this->translator
           
->registerParserShortcut(new EmptyStringParser())
            ->
registerParserShortcut(new ElementParser())
            ->
registerParserShortcut(new ClassParser())
            ->
registerParserShortcut(new HashParser())
        ;
    }

   
/**
     * Translates a CSS expression to its XPath equivalent.
     *
     * Optionally, a prefix can be added to the resulting XPath
     * expression with the $prefix parameter.
     *
     * @param string $cssExpr The CSS expression
     * @param string $prefix An optional prefix for the XPath expression
     *
     * @return string
     */
   
public function toXPath($cssExpr, $prefix = 'descendant-or-self::')
    {
        return
$this->translator->cssToXPath($cssExpr, $prefix);
    }
}