Cheetah
Public Member Functions | Static Public Member Functions | Public Attributes | List of all members
HTMLPurifier_ElementDef Class Reference

Public Member Functions

 mergeIn ($def)
 

Static Public Member Functions

static create ($content_model, $content_model_type, $attr)
 

Public Attributes

 $standalone = true
 
 $attr = array()
 
 $attr_transform_pre = array()
 
 $attr_transform_post = array()
 
 $child
 
 $content_model
 
 $content_model_type
 
 $descendants_are_inline = false
 
 $required_attr = array()
 
 $excludes = array()
 
 $autoclose = array()
 
 $wrap
 
 $formatting
 

Detailed Description

Structure that stores an HTML element definition. Used by HTMLPurifier_HTMLDefinition and HTMLPurifier_HTMLModule.

Note
This class is inspected by HTMLPurifier_Printer_HTMLDefinition. Please update that class too.
Warning
If you add new properties to this class, you MUST update the mergeIn() method.

Definition at line 3619 of file HTMLPurifier.standalone.php.

Member Function Documentation

◆ create()

static HTMLPurifier_ElementDef::create (   $content_model,
  $content_model_type,
  $attr 
)
static

Low-level factory constructor for creating new standalone element defs

Definition at line 3746 of file HTMLPurifier.standalone.php.

◆ mergeIn()

HTMLPurifier_ElementDef::mergeIn (   $def)

Merges the values of another element definition into this one. Values from the new element def take precedence if a value is not mergeable.

Parameters
HTMLPurifier_ElementDef$def

Definition at line 3761 of file HTMLPurifier.standalone.php.

Member Data Documentation

◆ $attr

HTMLPurifier_ElementDef::$attr = array()

Associative array of attribute name to HTMLPurifier_AttrDef. @type array

Note
Before being processed by HTMLPurifier_AttrCollections when modules are finalized during HTMLPurifier_HTMLDefinition->setup(), this array may also contain an array at index 0 that indicates which attribute collections to load into the full array. It may also contain string indentifiers in lieu of HTMLPurifier_AttrDef, see HTMLPurifier_AttrTypes on how they are expanded during HTMLPurifier_HTMLDefinition->setup() processing.

Definition at line 3640 of file HTMLPurifier.standalone.php.

◆ $attr_transform_post

HTMLPurifier_ElementDef::$attr_transform_post = array()

List of tags HTMLPurifier_AttrTransform to be done after validation. @type array

Definition at line 3664 of file HTMLPurifier.standalone.php.

◆ $attr_transform_pre

HTMLPurifier_ElementDef::$attr_transform_pre = array()

List of tags HTMLPurifier_AttrTransform to be done before validation. @type array

Definition at line 3658 of file HTMLPurifier.standalone.php.

◆ $autoclose

HTMLPurifier_ElementDef::$autoclose = array()

This tag is explicitly auto-closed by the following tags. @type array

Definition at line 3726 of file HTMLPurifier.standalone.php.

◆ $child

HTMLPurifier_ElementDef::$child

HTMLPurifier_ChildDef of this tag. @type HTMLPurifier_ChildDef

Definition at line 3670 of file HTMLPurifier.standalone.php.

◆ $content_model

HTMLPurifier_ElementDef::$content_model

Abstract string representation of internal ChildDef rules.

See also
HTMLPurifier_ContentSets for how this is parsed and then transformed into an HTMLPurifier_ChildDef.
Warning
This is a temporary variable that is not available after being processed by HTMLDefinition @type string

Definition at line 3680 of file HTMLPurifier.standalone.php.

◆ $content_model_type

HTMLPurifier_ElementDef::$content_model_type

Value of $child->type, used to determine which ChildDef to use, used in combination with $content_model.

Warning
This must be lowercase
This is a temporary variable that is not available after being processed by HTMLDefinition @type string

Definition at line 3690 of file HTMLPurifier.standalone.php.

◆ $descendants_are_inline

HTMLPurifier_ElementDef::$descendants_are_inline = false

Does the element have a content model (#PCDATA | Inline)*? This is important for chameleon ins and del processing in HTMLPurifier_ChildDef_Chameleon. Dynamically set: modules don't have to worry about this one. @type bool

Definition at line 3699 of file HTMLPurifier.standalone.php.

◆ $excludes

HTMLPurifier_ElementDef::$excludes = array()

Lookup table of tags excluded from all descendants of this tag. @type array

Note
SGML permits exclusions for all descendants, but this is not possible with DTDs or XML Schemas. W3C has elected to use complicated compositions of content_models to simulate exclusion for children, but we go the simpler, SGML-style route of flat-out exclusions, which correctly apply to all descendants and not just children. Note that the XHTML Modularization Abstract Modules are blithely unaware of such distinctions.

Definition at line 3720 of file HTMLPurifier.standalone.php.

◆ $formatting

HTMLPurifier_ElementDef::$formatting

Whether or not this is a formatting element affected by the "Active Formatting Elements" algorithm. @type bool

Definition at line 3741 of file HTMLPurifier.standalone.php.

◆ $required_attr

HTMLPurifier_ElementDef::$required_attr = array()

List of the names of required attributes this element has. Dynamically populated by HTMLPurifier_HTMLDefinition::getElement() @type array

Definition at line 3706 of file HTMLPurifier.standalone.php.

◆ $standalone

HTMLPurifier_ElementDef::$standalone = true

Does the definition work by itself, or is it created solely for the purpose of merging into another definition? @type bool

Definition at line 3626 of file HTMLPurifier.standalone.php.

◆ $wrap

HTMLPurifier_ElementDef::$wrap

If a foreign element is found in this element, test if it is allowed by this sub-element; if it is, instead of closing the current element, place it inside this element. @type string

Definition at line 3734 of file HTMLPurifier.standalone.php.


The documentation for this class was generated from the following file: