Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98993025
PhutilRemarkupBlockStorage.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sat, Jan 18, 07:45
Size
1 KB
Mime Type
text/x-php
Expires
Mon, Jan 20, 07:45 (2 d)
Engine
blob
Format
Raw Data
Handle
23682358
Attached To
rPHU libphutil
PhutilRemarkupBlockStorage.php
View Options
<?php
/**
* Remarkup prevents several classes of text-processing problems by replacing
* tokens in the text as they are marked up. For example, if you write something
* like this:
*
* //D12//
*
* It is processed in several stages. First the "D12" matches and is replaced:
*
* //\11Z//
*
* Now the italics match and are replaced:
*
* \12Z
*
* When processing completes, all the tokens are replaced again in reverse
* order:
*
* <em>\11Z</em>
*
* Then:
*
* <em><a href="http://...">...</a></em>
*
* If we didn't do this, the italics rule could match the "//" in "http://",
* or any other number of processing mistakes could occur, some of which create
* security risks.
*
* This class generates keys, and stores the map of keys to replacement text.
*
* @group markup
*/
final
class
PhutilRemarkupBlockStorage
{
const
MAGIC_BYTE
=
"
\1
"
;
private
$map
=
array
();
private
$index
;
public
function
store
(
$text
)
{
$key
=
self
::
MAGIC_BYTE
.(++
$this
->
index
).
'Z'
;
$this
->
map
[
$key
]
=
$text
;
return
$key
;
}
public
function
restore
(
$corpus
,
$text_mode
=
false
)
{
if
(
$this
->
map
)
{
if
(
$text_mode
)
{
$corpus
=
str_replace
(
array_reverse
(
array_keys
(
$this
->
map
)),
array_reverse
(
$this
->
map
),
$corpus
);
}
else
{
$corpus
=
phutil_safe_html
(
str_replace
(
array_reverse
(
array_keys
(
$this
->
map
)),
array_map
(
'phutil_escape_html'
,
array_reverse
(
$this
->
map
)),
phutil_escape_html
(
$corpus
)));
}
}
return
$corpus
;
}
public
function
overwrite
(
$key
,
$new_text
)
{
$this
->
map
[
$key
]
=
$new_text
;
return
$this
;
}
public
function
getMap
()
{
return
$this
->
map
;
}
public
function
setMap
(
array
$map
)
{
$this
->
map
=
$map
;
return
$this
;
}
}
Event Timeline
Log In to Comment