Page MenuHomePhabricator

Improve parsing of docblock specials
ClosedPublic

Authored by joshuaspence on Aug 23 2016, 12:26 AM.
Tags
None
Referenced Files
F18804060: D16431.id39516.diff
Sat, Oct 18, 5:44 AM
F18775354: D16431.id39519.diff
Fri, Oct 10, 6:46 PM
F18628305: D16431.id39518.diff
Sep 16 2025, 6:06 AM
F18622679: D16431.id39520.diff
Sep 15 2025, 12:38 PM
F18619752: D16431.id39517.diff
Sep 15 2025, 3:20 AM
F18618236: D16431.id.diff
Sep 14 2025, 11:31 PM
F18616332: D16431.id39517.diff
Sep 14 2025, 5:09 PM
F18524098: D16431.diff
Sep 6 2025, 11:33 AM
Subscribers

Details

Summary

Currently the tags of following docblock are parsed as array('special' => "foo\nbar"). This diff changes the output to be array('special' => array('foo', 'bar')).

/**
 * @special foo
 * @special bar
 */
Test Plan

Ran unit tests.

Diff Detail

Repository
rPHU libphutil
Branch
master
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 13393
Build 17193: Run Core Tests
Build 17192: arc lint + arc unit

Event Timeline

joshuaspence retitled this revision from to Improve parsing of docblock specials.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence added a reviewer: epriestley.

One inline -- and what does this produce (is there a test for it)?

@key value
@key
src/parser/PhutilDocblockParser.php
121

This seems a little odd to me, I'd expect:

@morse-code dot
@morse-code dot
@morse-code dash

...or whatever to produce array('dot', 'dot', 'dash'). Is there a particular reason for it?

src/parser/PhutilDocblockParser.php
121

Right, this was primarily intended for this case:

@special
@special
@special

In this case, I figured true was better than array(true, true, true).

joshuaspence edited edge metadata.

Add another test case

Ah, that makes sense for the no-strings case. Agreed that true is probably the right value there.

(I'm actually not really sure what I expect string + no string case to do.)

epriestley edited edge metadata.

Cool, those behaviors seem reasonable to me. Thanks!

(Does @stable @stable @stable have a test case?)

This revision is now accepted and ready to land.Aug 23 2016, 2:01 AM
joshuaspence edited edge metadata.

Add another test case

This revision was automatically updated to reflect the committed changes.