Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. InstructionProcessor.php

interface InstructionProcessor

Provide an processor to handle embedded instructions.

XML defines a mechanism for inserting instructions (like PHP) into a document. These are called "Processor Instructions." The HTML5 parser provides an opportunity to handle these processor instructions during the tree-building phase (before the DOM is constructed), which makes it possible to alter the document as it is being created.

One could, for example, use this mechanism to execute well-formed PHP code embedded inside of an HTML5 document.

Hierarchy

  • interface \Masterminds\HTML5\InstructionProcessor

Expanded class hierarchy of InstructionProcessor

All classes that implement InstructionProcessor

1 file declares its use of InstructionProcessor
DOMTreeBuilder.php in vendor/masterminds/html5/src/HTML5/Parser/DOMTreeBuilder.php

File

vendor/masterminds/html5/src/HTML5/InstructionProcessor.php, line 20

Namespace

Masterminds\HTML5
View source
interface InstructionProcessor {
    
    /**
     * Process an individual processing instruction.
     *
     * The process() function is responsible for doing the following:
     * - Determining whether $name is an instruction type it can handle.
     * - Determining what to do with the data passed in.
     * - Making any subsequent modifications to the DOM by modifying the
     * DOMElement or its attached DOM tree.
     *
     * @param \DOMElement $element The parent element for the current processing instruction.
     * @param string      $name    The instruction's name. E.g. `<?php` has the name `php`.
     * @param string      $data    All of the data between the opening and closing PI marks.
     *
     * @return \DOMElement The element that should be considered "Current". This may just be
     *                     the element passed in, but if the processor added more elements,
     *                     it may choose to reset the current element to one of the elements
     *                     it created. (When in doubt, return the element passed in.)
     */
    public function process(\DOMElement $element, $name, $data);

}

Members

Title Sort descending Modifiers Object type Summary
InstructionProcessor::process public function Process an individual processing instruction.

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal