Page MenuHomePhabricator

Simplify the use of `phutil_get_library_root`
ClosedPublic

Authored by joshuaspence on Jan 11 2015, 10:50 AM.
Tags
None
Referenced Files
F14502868: D11326.id27197.diff
Sun, Jan 5, 11:28 AM
Unknown Object (File)
Fri, Jan 3, 11:30 AM
Unknown Object (File)
Tue, Dec 31, 9:11 PM
Unknown Object (File)
Tue, Dec 17, 2:51 PM
Unknown Object (File)
Tue, Dec 17, 6:35 AM
Unknown Object (File)
Sun, Dec 15, 1:58 PM
Unknown Object (File)
Mon, Dec 9, 11:46 AM
Unknown Object (File)
Sun, Dec 8, 4:16 PM
Subscribers

Details

Summary

Currently, in order to retrieve the library root of the current phutil module, the following code is required:

$library = phutil_get_current_library_name();
$root = phutil_get_library_root($library);

This can be simplified by allowing the use of phutil_get_library_root() (without any arguments) to mean "get the library root for the current module".

Test Plan

N/A

Diff Detail

Repository
rPHU libphutil
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

joshuaspence retitled this revision from to Simplify the use of `phutil_get_library_root`.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence added a reviewer: epriestley.
joshuaspence edited edge metadata.

Use this change to simplify some other code

epriestley edited edge metadata.

I'm very slightly concerned that this may break silently when code is moved between libraries. Although this is rare, we've moved a decent amount of code from phabricator to libphutil in the past, and some between libphutil and arcanist, and a bit between arcanist and phabricator. Probably none of it actually called phutil_get_library_root(), but the scenario (where we move code that does) doesn't seem totally impossible to me.

If we're explicit with library names, the code will continue functioning correctly (or throw a very visible/obvious error, in the case of moving to a lower level library with the higher-level library not loaded). With implicit names, it may silently change the behavior of the code.

If this seems like a net positive even given that consideration, I'm fine with it. It seems pretty borderline to me (although I could also imagine library authors having a much easier time with this version of the function in the future, and facing nearly zero risk of cross-library code moves).

This revision is now accepted and ready to land.Jan 11 2015, 5:18 PM

I think that this change makes phutil_get_library_root() more useful, although I agree that extra care will be required when moving code between libraries. Let me strip this back a bit to only include the "more safe" parts.

This revision was automatically updated to reflect the committed changes.