Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F2899212
D25436.1737260492.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Flag For Later
Advanced/Developer...
View Handle
View Hovercard
Size
3 KB
Referenced Files
None
Subscribers
None
D25436.1737260492.diff
View Options
diff --git a/src/utils/PhutilCowsay.php b/src/utils/PhutilCowsay.php
--- a/src/utils/PhutilCowsay.php
+++ b/src/utils/PhutilCowsay.php
@@ -41,34 +41,29 @@
$template = $this->template;
// Real ".cow" files are Perl scripts which define a variable called
- // "$the_cow". We aren't going to interpret Perl, so strip all this stuff
- // (and any comments in the file) away.
- $template = phutil_split_lines($template, true);
- $keep = array();
- $is_perl_cowfile = false;
- foreach ($template as $key => $line) {
- if (preg_match('/^#/', $line)) {
- continue;
- }
- if (preg_match('/^\s*\\$the_cow/', $line)) {
- $is_perl_cowfile = true;
- continue;
- }
- if (preg_match('/^\s*EOC\s*$/', $line)) {
- continue;
- }
- $keep[] = $line;
- }
- $template = implode('', $keep);
-
- // Original .cow files are perl scripts which contain escaped sequences.
- // We attempt to unescape here by replacing any character preceded by a
- // backslash/escape with just that character.
- if ($is_perl_cowfile) {
+ // "$the_cow". We aren't going to interpret Perl, so just get everything
+ // between the EOC (End Of Cow) tokens. The initial EOC might be in
+ // quotes, and might have a semicolon.
+ // We apply regexp modifiers
+ // * 's' to make . match newlines within the EOC ... EOC block
+ // * 'm' so we can use ^ to match start of line within the multiline string
+ $matches = null;
+ if (
+ preg_match('/\$the_cow/', $template) &&
+ preg_match('/EOC[\'"]?;?.*?^(.*?)^EOC/sm', $template, $matches)
+ ) {
+ $template = $matches[1];
+
+ // Original .cow files are perl scripts which contain escaped sequences.
+ // We attempt to unescape here by replacing any character preceded by a
+ // backslash/escape with just that character.
$template = preg_replace(
'/\\\\(.)/',
'$1',
$template);
+ } else {
+ // Text template. Just strip away comments.
+ $template = preg_replace('/^#.*$/', '', $template);
}
$token_patterns = array(
diff --git a/src/utils/__tests__/cowsay/cube_perl.test b/src/utils/__tests__/cowsay/cube_perl.test
--- a/src/utils/__tests__/cowsay/cube_perl.test
+++ b/src/utils/__tests__/cowsay/cube_perl.test
@@ -1,5 +1,5 @@
# test case for original perl-script cowfile
-$the_cow =
+$the_cow = <<EOC
$thoughts
$thoughts
/---\\__/---\\\\
@@ -9,6 +9,7 @@
/ ..--.. \\\\
| \\ .... / ||
\\---/--\\---//
+EOC
~~~~~~~~~~
{
"text": "I made a friend!",
diff --git a/src/utils/__tests__/cowsay/small.expect b/src/utils/__tests__/cowsay/small.expect
new file mode 100644
--- /dev/null
+++ b/src/utils/__tests__/cowsay/small.expect
@@ -0,0 +1,7 @@
+ __________________
+< How are my eyes? >
+ ------------------
+ \ ,__,
+ \ (oo)____
+ (__) )\
+ ||--|| *
diff --git a/src/utils/__tests__/cowsay/small.test b/src/utils/__tests__/cowsay/small.test
new file mode 100644
--- /dev/null
+++ b/src/utils/__tests__/cowsay/small.test
@@ -0,0 +1,12 @@
+$eyes = ".." unless ($eyes);
+$the_cow = <<EOC;
+ $thoughts ,__,
+ $thoughts ($eyes)____
+ (__) )\\
+ $tongue||--|| *
+EOC
+~~~~~~~~~~
+{
+ "text": "How are my eyes?",
+ "eyes": "oo"
+}
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sun, Jan 19, 04:21 (8 h, 56 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
1111654
Default Alt Text
D25436.1737260492.diff (3 KB)
Attached To
Mode
D25436: Update PhutilCowsay.php to work for small cows
Attached
Detach File
Event Timeline
Log In to Comment