Page MenuHomePhabricator

Add a branch selector to Diffusion
ClosedPublic

Authored by chad on Jul 23 2017, 1:28 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 9:58 PM
Unknown Object (File)
Fri, Jan 24, 9:58 PM
Unknown Object (File)
Fri, Jan 24, 9:58 PM
Unknown Object (File)
Fri, Jan 24, 9:57 PM
Unknown Object (File)
Fri, Jan 24, 9:57 PM
Unknown Object (File)
Fri, Jan 24, 9:57 PM
Unknown Object (File)
Fri, Jan 24, 9:57 PM
Unknown Object (File)
Fri, Jan 24, 9:57 PM
Subscribers

Details

Summary

Fixes T12931. Adds a branch selector that's always visible if the repo has commits.

Test Plan

Test a plain hg, svn, git repository. Test setting a bad default branch. Test a good default branch. Test on desktop, mobile layouts.

image.png (1×942 px, 178 KB)

Diff Detail

Repository
rP Phabricator
Branch
wrong-branch (branched from master)
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 17781
Build 23875: Run Core Tests
Build 23874: arc lint + arc unit

Event Timeline

  • add see more link, test mobile layout
epriestley added inline comments.
src/applications/diffusion/controller/DiffusionRepositoryController.php
66

Although this value is correct anyway, consider passing $default instead of $drequest->getBranch() as the parameter.

The phrasing seems a little weird to me too, e.g. "The master sword is not in this dungeon." implies it's in some other dungeon. Maybe something like "This repository is configured with default branch "%s" but there is no branch with that name in this repository."

156–163

If getPath() throws an exception, $path will be left uninitialized and we'll fatal when trying to use it later. This (stuff a bunch of code in a try/catch block and ignore any exceptions) generally doesn't seem like the right approach to me. In what conditions can these methods throw? What made you decide to ignore (rather than handle) errors here?

186

This should be browseFuture, not branchFuture.

This revision now requires changes to proceed.Jul 24 2017, 3:11 PM
chad marked 2 inline comments as done.Jul 24 2017, 4:43 PM
chad added inline comments.
src/applications/diffusion/controller/DiffusionRepositoryController.php
156–163

Before, if we have no content, we don't build anything (or go into this method). However now we build out the branch selector if there are other branches, but not a default. So if that happens, this was fataling on $drequest->getCommit() because we're not in a branch.

The "wrong branch" error is still handled above. I'm not sure how else to better code this, it felt flimsy.

chad edited edge metadata.
  • per inline comments

Let me counter-diff you on rewriting buildNormalContent(), I think it'll be easier to just feel out the restructuring myself than try to do it inlines.

I plan to bring Tags back in a similar dropdown fashion. Then eventually get the courage up to make those two widgets all JS.

(feel free to click accept) 💵

If you want to split this into "selector" and "better behavior for a missing default branch", I'm happy to accept the selector.

I don't want to bring try { a bunch of stuff } catch ($ex) { just ignore it } upstream since I'm worried that kind of change is particularly likely to lead to support headaches.

chad planned changes to this revision.Jul 24 2017, 6:31 PM
This revision is now accepted and ready to land.Jul 24 2017, 8:39 PM
This revision was automatically updated to reflect the committed changes.