Skip to content
This repository has been archived by the owner on Jul 28, 2023. It is now read-only.

Experiment with WP_HTML_Tag_Processor #118

Closed
wants to merge 54 commits into from
Closed
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
0f3426c
Remove ssr.mjs
ockham Dec 13, 2022
2618b45
Remove now-obsolete SSR helpers
ockham Dec 13, 2022
d246f70
Copy WP_HTML_Tag_Processor code from Gutenberg
ockham Dec 13, 2022
ac78938
Use more complex code for Tabs block
ockham Dec 13, 2022
4c41dd0
Add basic Tag Processor based logic
ockham Dec 13, 2022
1933d53
Abstract directive processors
ockham Dec 13, 2022
0e3722c
Components can't have directives
ockham Dec 13, 2022
f333a1f
Remove debug output
ockham Dec 13, 2022
3d3fa5b
Change order a bit
ockham Dec 13, 2022
e5f052f
Use array_replace_recursive instead of array_merge_recursive
ockham Dec 14, 2022
6a4a9c5
Support more per-directive data
ockham Dec 14, 2022
d6ca85b
Fix wp-context as a component
ockham Dec 14, 2022
7701c23
Unify attribute/content handling
ockham Dec 14, 2022
6dd686b
Update HTML (Tag) Processor from gb#46345
ockham Dec 14, 2022
81e866d
Add HTML Processor to index.php
ockham Dec 14, 2022
5a26936
Have wp-show directive processor return template-wrapped content
ockham Dec 14, 2022
27f129c
Update WP_HTML_Processor from gb#46345
ockham Dec 15, 2022
14fc264
Remove currently unneeded WP_HTML_Attribute_Sourcer
ockham Dec 15, 2022
4cef805
Remove now-obsolete code
ockham Dec 15, 2022
faae6d8
Add PHPUnit files from Gutenberg
ockham Dec 19, 2022
5bdf348
Install phpunit and polyfills
ockham Dec 19, 2022
548f8fe
Upgrade wordpress/env package
ockham Dec 19, 2022
1c167e9
Comment out some stuff in PHPUnit bootstrap
ockham Dec 19, 2022
493f7ce
Add mappings to .wp-env.json
ockham Dec 19, 2022
cc58408
Add test:unit:php script
ockham Dec 19, 2022
2b90183
Move directives code into separate files
ockham Dec 19, 2022
0dd2f20
More permissive unit test names
ockham Dec 19, 2022
051d290
Add basic unit test for wp-context
ockham Dec 19, 2022
f8dd300
Slightly more sophisticated test
ockham Dec 19, 2022
bf4d7f6
Minor cleanup
ockham Dec 19, 2022
f968773
Add basic test coverage for wp-show
ockham Dec 19, 2022
c084f4a
wp-show: Assert context is unmodified
ockham Dec 19, 2022
e866958
Add unit-test.yml workflow from Gutenberg
ockham Dec 19, 2022
0a474b9
Trim down unit test workflow
ockham Dec 19, 2022
556dc14
Workflow: Install composer dependencies
ockham Dec 19, 2022
1f6572f
Add get_attributes_by_prefix() method
ockham Dec 20, 2022
7073116
Pass directive name, retrieve all matching directives
ockham Dec 20, 2022
07ff956
Change argument order
ockham Dec 20, 2022
d3497ea
Typo
ockham Dec 20, 2022
8334591
Make WP_HTML_Tag_Processor the interface
ockham Dec 20, 2022
e4228c1
Extract expression parser
ockham Dec 20, 2022
751027c
Add basic wp-bind code
ockham Dec 20, 2022
70d85d1
Added link to bugfix PR
ockham Dec 20, 2022
2a38762
Fix bug in wp-directives
ockham Dec 21, 2022
685ac76
Make wp-context more error-tolerant
ockham Dec 21, 2022
21d598a
Implement basic context stacking
ockham Dec 21, 2022
6f45299
Introduce WP_Directive_Context helper class
ockham Dec 21, 2022
cc402da
Use in other directive processors
ockham Dec 21, 2022
4f1e83d
Update directives processing logic to use context object
ockham Dec 21, 2022
b2e7ccc
A bit more test coverage still
ockham Dec 21, 2022
fb11797
Short-circuit
ockham Dec 21, 2022
4ff88d5
Organize code slightly differently
ockham Dec 21, 2022
68d6100
Add TODO comment
ockham Dec 21, 2022
d6195c4
Include closing tags
ockham Dec 22, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 2 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@
"test": "jest",
"test:watch": "jest --watch",
"plugin-zip": "wp-scripts plugin-zip",
"wp-env": "wp-env",
"ssr": "node ssr.mjs"
"wp-env": "wp-env"
},
"prettier": {
"useTabs": true,
Expand Down Expand Up @@ -39,7 +38,6 @@
"dependencies": {
"@preact/signals": "^1.1.2",
"hpq": "^1.3.0",
"preact": "^10.10.6",
"ultrahtml": "^0.4.0"
"preact": "^10.10.6"
}
}
13 changes: 11 additions & 2 deletions src/blocks/tabs/render.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,14 @@
]); ?>

<h3>The tabs!</h3>
<wp-show when="state.show"><div>I should be shown</div></wp-show>
<wp-show when="state.dontShow"><div>I should not be shown</div></wp-show>
<div wp-context='{ "myblock": { "open": false } }'>
<div wp-context='{ "myblock": { "open": true } }'>
<wp-show when="context.myblock.open">
<div>I should be shown!</div>
</wp-show>
</div>

<wp-show when="context.myblock.open">
<div>I should not be shown!</div>
</wp-show>
</div>
89 changes: 89 additions & 0 deletions src/html/class-wp-html-attribute-token.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
<?php
/**
* HTML Tag Processor: Attribute token structure class.
*
* @package WordPress
* @subpackage HTML
* @since 6.2.0
*/

/**
* Data structure for the attribute token that allows to drastically improve performance.
*
* This class is for internal usage of the WP_HTML_Tag_Processor class.
*
* @access private
* @since 6.2.0
*
* @see WP_HTML_Tag_Processor
*/
class WP_HTML_Attribute_Token {
/**
* Attribute name.
*
* @since 6.2.0
* @var string
*/
public $name;

/**
* Attribute value.
*
* @since 6.2.0
* @var int
*/
public $value_starts_at;

/**
* How many bytes the value occupies in the input HTML.
*
* @since 6.2.0
* @var int
*/
public $value_length;

/**
* The string offset where the attribute name starts.
*
* @since 6.2.0
* @var int
*/
public $start;

/**
* The string offset after the attribute value or its name.
*
* @since 6.2.0
* @var int
*/
public $end;

/**
* Whether the attribute is a boolean attribute with value `true`.
*
* @since 6.2.0
* @var bool
*/
public $is_true;

/**
* Constructor.
*
* @since 6.2.0
*
* @param string $name Attribute name.
* @param int $value_start Attribute value.
* @param int $value_length Number of bytes attribute value spans.
* @param int $start The string offset where the attribute name starts.
* @param int $end The string offset after the attribute value or its name.
* @param bool $is_true Whether the attribute is a boolean attribute with true value.
*/
public function __construct( $name, $value_start, $value_length, $start, $end, $is_true ) {
$this->name = $name;
$this->value_starts_at = $value_start;
$this->value_length = $value_length;
$this->start = $start;
$this->end = $end;
$this->is_true = $is_true;
}
}
52 changes: 52 additions & 0 deletions src/html/class-wp-html-span.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
<?php
/**
* HTML Span: Represents a textual span inside an HTML document.
*
* @package WordPress
* @subpackage HTML
* @since 6.2.0
*/

/**
* Represents a textual span inside an HTML document.
*
* This is a two-tuple in disguise, used to avoid the memory
* overhead involved in using an array for the same purpose.
*
* This class is for internal usage of the WP_HTML_Tag_Processor class.
*
* @access private
* @since 6.2.0
*
* @see WP_HTML_Tag_Processor
*/
class WP_HTML_Span {
/**
* Byte offset into document where span begins.
*
* @since 6.2.0
* @var int
*/
public $start;

/**
* Byte offset into document where span ends.
*
* @since 6.2.0
* @var int
*/
public $end;

/**
* Constructor.
*
* @since 6.2.0
*
* @param int $start Byte offset into document where replacement span begins.
* @param int $end Byte offset into document where replacement span ends.
*/
public function __construct( $start, $end ) {
$this->start = $start;
$this->end = $end;
}
}
Loading