Page MenuHomePhabricator

Make all bin/* scripts locate their workflows dynamically
ClosedPublic

Authored by epriestley on Dec 26 2013, 9:50 PM.
Tags
None
Referenced Files
F14714268: D7840.diff
Fri, Jan 17, 5:10 PM
F14706188: D7840.diff
Thu, Jan 16, 11:46 PM
Unknown Object (File)
Thu, Jan 2, 1:02 AM
Unknown Object (File)
Mon, Dec 30, 5:48 PM
Unknown Object (File)
Sat, Dec 28, 4:05 PM
Unknown Object (File)
Sun, Dec 22, 6:49 PM
Unknown Object (File)
Sun, Dec 22, 6:49 PM
Unknown Object (File)
Dec 13 2024, 2:05 AM
Subscribers

Details

Summary

Ref T2015. Not directly related to Drydock, but I bumped into this. All these scripts currently enumerate their workflows explicitly.

Instead, use PhutilSymbolLoader to automatically discover workflows. This reduces code duplication and errors (see all the bad extends this diff fixes) and lets third parties add new workflows (not clearly valuable?).

Test Plan

Ran bin/x help for each modified script.

Diff Detail

Branch
ddock5
Lint
Lint Passed
Unit
No Test Coverage

Event Timeline

I can't imagine 3rd party scripts being made too often; basically everything they could need is already there, and if it isn't they are more likely to just ask than build something...

Yeah, I don't have any real use cases in mind for that. I could maybe imagine something like a third-party file storage engine adding some commands to bin/files or something, but that's quite a stretch.