Page MenuHomePhabricator

Add external-json linter
AbandonedPublic

Authored by bgamari on Nov 22 2015, 8:04 PM.
Tags
None
Referenced Files
F14105917: D14535.diff
Wed, Nov 27, 3:52 AM
Unknown Object (File)
Sun, Nov 24, 10:27 AM
Unknown Object (File)
Sat, Nov 23, 11:36 AM
Unknown Object (File)
Tue, Nov 19, 3:05 PM
Unknown Object (File)
Fri, Nov 15, 8:58 AM
Unknown Object (File)
Sun, Nov 10, 8:47 PM
Unknown Object (File)
Fri, Nov 8, 1:48 AM
Unknown Object (File)
Fri, Nov 8, 1:48 AM
Subscribers

Details

Summary

This provides a facility for implementing external linters which can
report violations via a JSON representation.

Test Plan

Try it

Diff Detail

Branch
master
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 8972
Build 10533: arc lint + arc unit

Event Timeline

bgamari retitled this revision from to Add external-json linter.
bgamari updated this object.
bgamari edited the test plan for this revision. (Show Details)
This revision now requires changes to proceed.Nov 22 2015, 9:05 PM
bgamari edited edge metadata.

Correct comments

epriestley edited edge metadata.

Per T9827, I currently believe this would be used by only one install and don't want to bring it upstream without seeing much broader interest first.

This revision now requires changes to proceed.Nov 22 2015, 10:40 PM

This code looks good to me in a technical sense, we just don't want to take over maintaining it. Two minor suggestions:

  • phutil_utf8_strtolower() has better behavior than strtolower() on some utf8 inputs.
  • phutil_json_decode() has better behavior (throws a detailed exception) on invalid JSON than json_decode() (returns false).

We don't currently have a way to, say, sign an extension as "this code is broadly reasonable and won't root your box or destroy your data, just not something the upstream wants to maintain or take responsibility for", but we might after T5055.

This code looks good to me in a technical sense, we just don't want to take over maintaining it. Two minor suggestions:

  • phutil_utf8_strtolower() has better behavior than strtolower() on some utf8 inputs.
  • phutil_json_decode() has better behavior (throws a detailed exception) on invalid JSON than json_decode() (returns false).

Thanks for the review!

We don't currently have a way to, say, sign an extension as "this code is broadly reasonable and won't root your box or destroy your data, just not something the upstream wants to maintain or take responsibility for", but we might after T5055.

Sure. I'll be putting the code up here.