Page MenuHomePhabricator

Implicitly detect directories when updating a fragment from a ZIP
ClosedPublic

Authored by hach-que on Dec 7 2013, 3:17 AM.
Tags
None
Referenced Files
F18824137: D7733.id17478.diff
Thu, Oct 23, 2:30 PM
F18817608: D7733.id17489.diff
Tue, Oct 21, 4:58 PM
F18790324: D7733.diff
Wed, Oct 15, 1:38 PM
F18628380: D7733.id17490.diff
Sep 16 2025, 6:14 AM
F18624701: D7733.id17481.diff
Sep 15 2025, 8:50 PM
F18624699: D7733.id17481.diff
Sep 15 2025, 8:49 PM
F18617045: D7733.id17481.diff
Sep 14 2025, 8:01 PM
F18617043: D7733.id17481.diff
Sep 14 2025, 8:00 PM

Details

Summary

This fixes the update-from-ZIP functionality so that it will automatically detect directories in the ZIP that do not have explicit entries. Some ZIP programs do not create directory entries explicitly, so if we fail to do this then there's no way for users to access the sub-fragments (even though they exist, there is no directory fragment to click through).

Test Plan

Created and updated fragments from a ZIP that had implicit directories in it.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

hach-que updated this revision to Unknown Object (????).Dec 7 2013, 6:19 AM

Recurse up the directory tree when performing this check in case we have:

  • something.exe
  • blah/hello/path.txt
src/applications/phragment/storage/PhragmentFragment.php
166

"in the file" -> "if the file" typo?

173

"Whether" -> "Where" typo?

hach-que updated this revision to Unknown Object (????).Dec 7 2013, 6:41 AM

Spelling

Some minor inlines.

src/applications/phragment/storage/PhragmentFragment.php
185

This is sort of dangerous because dirname('/') is / -- it never reduces to ".". We've had at least one infinite loop bug with this, where I got it wrong inside some unit test stuff.

Maybe we should implement a method like Filesystem::walkToRoot() which doesn't look at the filesystem? phutil_walk_path() or similar. I believe there would be at least one callsite in arc for it.

186–188

in_array() is O(N). I think this is a little simpler, and is O(1):

if (array_key_exists($directory, $mappings)) {
  $mappings[$directory] = null;
}

Then $directories can be removed?

hach-que updated this revision to Unknown Object (????).Dec 8 2013, 1:09 AM

Prevented infinite loop with dirname() and removed need for $directories.