Page MenuHomePhabricator

Consolidate querying of things which we can use `git for-each-ref` for
ClosedPublic

Authored by epriestley on Oct 30 2013, 2:22 PM.
Tags
None
Referenced Files
F18590883: D7447.diff
Fri, Sep 12, 7:32 AM
F18283162: D7447.id.diff
Sat, Aug 23, 1:01 AM
F18283161: D7447.diff
Sat, Aug 23, 1:01 AM
F18097710: D7447.id16800.diff
Aug 8 2025, 3:07 PM
F18093825: D7447.id.diff
Aug 7 2025, 8:51 PM
F18088653: D7447.diff
Aug 6 2025, 8:49 AM
F18083682: D7447.id16800.diff
Aug 5 2025, 11:09 AM
Unknown Object (File)
Jun 3 2025, 10:29 PM
Subscribers

Details

Reviewers
btrahan
avivey
Maniphest Tasks
Restricted Maniphest Task
Commits
Restricted Diffusion Commit
rP3bf372c60c2e: Consolidate querying of things which we can use `git for-each-ref` for
Summary

Ref T2230. This cleans up D7442, by using git for-each-ref everywhere we can, in a basically reasonable way.

Test Plan

In bare and non-bare repositories:

  • Ran discovery with bin/repository discover;
  • listed branches on /diffusion/X/;
  • listed tags on /diffusion/X/;
  • listed tags, branches and refs on /diffusion/rXnnnn.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

Some of the offset/count logic was a bit goofy so I simplified that, too.

The overall change here is to get rid of code in this form:

if ($bare) {
  $stuff = do_something();
} else {
  $stuff = do_something_very_similar();
}

...and replace it with code in this form:

$stuff = do_something_query($repository);