eac_tools 0.31.0 → 0.31.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile.lock +21 -16
- data/lib/eac_tools/version.rb +1 -1
- data/sub/avm/avm.gemspec +3 -3
- data/sub/avm/lib/avm/entries/base/uri_components_entries_values/component_factory.rb +42 -0
- data/sub/avm/lib/avm/entries/base/uri_components_entries_values/generic_component.rb +52 -0
- data/sub/avm/lib/avm/entries/base/uri_components_entries_values/path_component.rb +19 -0
- data/sub/avm/lib/avm/entries/base/uri_components_entries_values/url_component.rb +28 -0
- data/sub/avm/lib/avm/entries/base/uri_components_entries_values.rb +25 -0
- data/sub/avm/lib/avm/entries/base.rb +7 -0
- data/sub/avm/lib/avm/entries/keys_constants_set.rb +43 -0
- data/sub/avm/lib/avm/instances/base/install.rb +24 -0
- data/sub/avm/lib/avm/instances/base/web.rb +16 -0
- data/sub/avm/lib/avm/instances/base.rb +1 -1
- data/sub/avm/lib/avm/instances/entry_keys.rb +2 -21
- data/sub/avm/lib/avm/version.rb +1 -1
- data/sub/avm/spec/lib/avm/instances/base_spec.rb +1 -1
- data/sub/avm-tools/avm-tools.gemspec +2 -2
- data/sub/avm-tools/lib/avm/tools/version.rb +1 -1
- data/sub/eac_git/Gemfile +8 -0
- data/sub/eac_git/eac_git.gemspec +20 -0
- data/sub/eac_git/lib/eac_git/executables.rb +48 -0
- data/sub/eac_git/lib/eac_git/local/branch.rb +27 -0
- data/sub/eac_git/lib/eac_git/local/commit/archive.rb +19 -0
- data/sub/eac_git/lib/eac_git/local/commit/changed_file.rb +46 -0
- data/sub/eac_git/lib/eac_git/local/commit/diff_tree_line.rb +32 -0
- data/sub/eac_git/lib/eac_git/local/commit.rb +73 -0
- data/sub/eac_git/lib/eac_git/local/dirty_files.rb +37 -0
- data/sub/eac_git/lib/eac_git/local/log.rb +17 -0
- data/sub/eac_git/lib/eac_git/local/remote.rb +27 -0
- data/sub/eac_git/lib/eac_git/local/remotes.rb +20 -0
- data/sub/eac_git/lib/eac_git/local/subrepo/config.rb +43 -0
- data/sub/eac_git/lib/eac_git/local/subrepo.rb +49 -0
- data/sub/eac_git/lib/eac_git/local.rb +127 -0
- data/sub/eac_git/lib/eac_git/remote/ls_result.rb +20 -0
- data/sub/eac_git/lib/eac_git/remote.rb +19 -0
- data/sub/eac_git/lib/eac_git/rspec/setup.rb +23 -0
- data/sub/eac_git/lib/eac_git/rspec/stubbed_git_local_repo.rb +71 -0
- data/sub/eac_git/lib/eac_git/rspec.rb +9 -0
- data/sub/eac_git/lib/eac_git/version.rb +5 -0
- data/sub/eac_git/lib/eac_git.rb +7 -0
- data/sub/eac_git/spec/lib/eac_git/executables_spec.rb +13 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec.rb +13 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/add.source.out +1 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/add.target.yaml +7 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/modify.source.out +1 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/modify.target.yaml +7 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/remove.source.out +1 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/remove.target.yaml +7 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/rename.source.out +2 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/rename.target.yaml +13 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/rename_modify.source.out +2 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit/diff_tree_line_spec_files/rename_modify.target.yaml +13 -0
- data/sub/eac_git/spec/lib/eac_git/local/commit_spec.rb +58 -0
- data/sub/eac_git/spec/rubocop_spec.rb +3 -0
- data/sub/eac_git/spec/spec_helper.rb +4 -0
- data/sub/eac_git/vendor/git-subrepo/Changes +110 -0
- data/sub/eac_git/vendor/git-subrepo/Intro.pod +509 -0
- data/sub/eac_git/vendor/git-subrepo/License +21 -0
- data/sub/eac_git/vendor/git-subrepo/Makefile +82 -0
- data/sub/eac_git/vendor/git-subrepo/Meta +28 -0
- data/sub/eac_git/vendor/git-subrepo/ReadMe.pod +698 -0
- data/sub/eac_git/vendor/git-subrepo/doc/comparison.swim +35 -0
- data/sub/eac_git/vendor/git-subrepo/doc/git-subrepo.swim +608 -0
- data/sub/eac_git/vendor/git-subrepo/doc/intro-to-subrepo.swim +387 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/Changes +15 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/License +21 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/Makefile +45 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/Meta +28 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/ReadMe.pod +77 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/bin/bash+ +43 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/doc/bash+.swim +61 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/lib/bash+.bash +92 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/man/man1/bash+.1 +134 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/man/man3/bash+.3 +134 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/base.t +12 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/fcopy.t +22 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/lib/foo/bar.bash +3 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/lib/foo/foo.bash +3 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/source-bash+-std.t +18 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/source-bash+.t +23 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/test.bash +70 -0
- data/sub/eac_git/vendor/git-subrepo/ext/bashplus/test/use.t +19 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/Changes +15 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/License +21 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/Makefile +20 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/Meta +30 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ReadMe.pod +115 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/doc/test-more.swim +89 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Changes +15 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/License +21 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Makefile +45 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Meta +28 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/ReadMe.pod +77 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/bin/bash+ +43 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/doc/bash+.swim +61 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/lib/bash+.bash +92 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/man/man1/bash+.1 +134 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/man/man3/bash+.3 +134 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/base.t +12 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/fcopy.t +22 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/lib/foo/bar.bash +3 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/lib/foo/foo.bash +3 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/source-bash+-std.t +18 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/source-bash+.t +23 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/test.bash +70 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/use.t +19 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Changes +15 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/License +21 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Makefile +37 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Meta +28 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/ReadMe.pod +66 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/doc/test-tap.swim +48 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/lib/test/tap.bash +153 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/man/man3/test-tap.3 +119 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/bail_out.t +13 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/done.t +10 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/fail.t +20 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/fail_fast.t +15 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/helper.bash +9 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/pass.t +9 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/plan.t +10 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/skip_all.t +20 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/tap.t +13 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/bail.t +14 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/fail.t +7 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/fail_fast.t +12 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/skip-all-init.t +8 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/skip-all-plan.t +9 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/lib/test/more.bash +95 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/man/man3/test-more.3 +173 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/fail.t +20 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/more.t +20 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/pass.t +9 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/setup +8 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/skip_all.t +11 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/test/fail1.t +12 -0
- data/sub/eac_git/vendor/git-subrepo/ext/test-more-bash/test/test/skip_all.t +10 -0
- data/sub/eac_git/vendor/git-subrepo/lib/git-subrepo +1903 -0
- data/sub/eac_git/vendor/git-subrepo/lib/git-subrepo.d/bash+.bash +1 -0
- data/sub/eac_git/vendor/git-subrepo/lib/git-subrepo.d/help-functions.bash +339 -0
- data/sub/eac_git/vendor/git-subrepo/man/man1/git-subrepo.1 +743 -0
- data/sub/eac_git/vendor/git-subrepo/note/0.4.0 +12 -0
- data/sub/eac_git/vendor/git-subrepo/note/AllGitCmds +148 -0
- data/sub/eac_git/vendor/git-subrepo/note/Cases +32 -0
- data/sub/eac_git/vendor/git-subrepo/note/Commands +33 -0
- data/sub/eac_git/vendor/git-subrepo/note/Dags +199 -0
- data/sub/eac_git/vendor/git-subrepo/note/Gists +7 -0
- data/sub/eac_git/vendor/git-subrepo/note/Links +25 -0
- data/sub/eac_git/vendor/git-subrepo/note/Plugins +10 -0
- data/sub/eac_git/vendor/git-subrepo/note/Spec +39 -0
- data/sub/eac_git/vendor/git-subrepo/note/Story1 +57 -0
- data/sub/eac_git/vendor/git-subrepo/note/ToDo +55 -0
- data/sub/eac_git/vendor/git-subrepo/note/design.swim +137 -0
- data/sub/eac_git/vendor/git-subrepo/note/design2.swim +85 -0
- data/sub/eac_git/vendor/git-subrepo/note/init-test +38 -0
- data/sub/eac_git/vendor/git-subrepo/note/pull-dance.txt +18 -0
- data/sub/eac_git/vendor/git-subrepo/note/recreate-rebase-conflict.sh +56 -0
- data/sub/eac_git/vendor/git-subrepo/note/subtree-rebase-fail-example/test.bash +29 -0
- data/sub/eac_git/vendor/git-subrepo/note/test-subrepo-push.sh +69 -0
- data/sub/eac_git/vendor/git-subrepo/note/test.sh +58 -0
- data/sub/eac_git/vendor/git-subrepo/pkg/bin/generate-completion.pl +210 -0
- data/sub/eac_git/vendor/git-subrepo/pkg/bin/generate-help-functions.pl +89 -0
- data/sub/eac_git/vendor/git-subrepo/share/completion.bash +42 -0
- data/sub/eac_git/vendor/git-subrepo/share/enable-completion.sh +50 -0
- data/sub/eac_git/vendor/git-subrepo/share/git-completion.bash +2738 -0
- data/sub/eac_git/vendor/git-subrepo/share/zsh-completion/_git-subrepo +81 -0
- data/sub/eac_git/vendor/git-subrepo/test/branch-all.t +41 -0
- data/sub/eac_git/vendor/git-subrepo/test/branch-rev-list-one-path.t +43 -0
- data/sub/eac_git/vendor/git-subrepo/test/branch-rev-list.t +47 -0
- data/sub/eac_git/vendor/git-subrepo/test/branch.t +52 -0
- data/sub/eac_git/vendor/git-subrepo/test/clean.t +43 -0
- data/sub/eac_git/vendor/git-subrepo/test/clone-annotated-tag.t +45 -0
- data/sub/eac_git/vendor/git-subrepo/test/clone.t +107 -0
- data/sub/eac_git/vendor/git-subrepo/test/compile.t +19 -0
- data/sub/eac_git/vendor/git-subrepo/test/config.t +58 -0
- data/sub/eac_git/vendor/git-subrepo/test/encode.t +91 -0
- data/sub/eac_git/vendor/git-subrepo/test/error.t +171 -0
- data/sub/eac_git/vendor/git-subrepo/test/fetch.t +43 -0
- data/sub/eac_git/vendor/git-subrepo/test/gitignore.t +61 -0
- data/sub/eac_git/vendor/git-subrepo/test/init.t +64 -0
- data/sub/eac_git/vendor/git-subrepo/test/issue29.t +98 -0
- data/sub/eac_git/vendor/git-subrepo/test/issue95.t +98 -0
- data/sub/eac_git/vendor/git-subrepo/test/issue96.t +96 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-all.t +38 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-merge.t +113 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-message.t +88 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-new-branch.t +58 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-ours.t +90 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-theirs.t +82 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-twice.t +44 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull-worktree.t +40 -0
- data/sub/eac_git/vendor/git-subrepo/test/pull.t +99 -0
- data/sub/eac_git/vendor/git-subrepo/test/push-after-init.t +51 -0
- data/sub/eac_git/vendor/git-subrepo/test/push-force.t +56 -0
- data/sub/eac_git/vendor/git-subrepo/test/push-new-branch.t +61 -0
- data/sub/eac_git/vendor/git-subrepo/test/push-no-changes.t +29 -0
- data/sub/eac_git/vendor/git-subrepo/test/push-squash.t +56 -0
- data/sub/eac_git/vendor/git-subrepo/test/push.t +176 -0
- data/sub/eac_git/vendor/git-subrepo/test/reclone.t +45 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/HEAD +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/config +4 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/1f/0c4b264caed0126814a0ede851a1e0b4e16ae6 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/87/46903fdb1b9c2101377880125917c2e05b4d69 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/94/c86ffc745232d89f78c6f895e11e71272518db +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/c6/76c57b6576743fa56278527aa60ebd2e202a7c +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/objects/f6/2a8ff3feadf39b0a98f1a86ec6d1eb33858ee9 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/refs/heads/master +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/bar/refs/tags/A +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/HEAD +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/config +4 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/objects/a0/f4cdaaf533a936296cdebbed8206c3b9ededa8 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/objects/e2/1291a1ad392a9d4c51dd9586804f1467b28afd +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/foo/refs/heads/master +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/HEAD +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/config +5 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/11/523f5dcf03b4c89b592dc8a3d0308f68da2386 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/14/2addf8ec5f37334e837440122c62f2c68a29ad +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/32/5180321750a21cd7a4e7ecda319e557a4f6a09 +2 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/3d/918c6901c02f43af5d31779dd5e1f9166aeb36 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/3e/4cb596066dce63ba4d047abddb677389b65e19 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/4b/6e53022e7a04f07887697e4f3d7c377fd9822b +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/58/931fc1bd559b59c41ea738fc7ad04f9ad01bd3 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/5e/c0c28e1b806f25efdca18fcf7a74b49c3755bd +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/75/fa6584e748f57eff06eebdc55e9ac21d4fcbf2 +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/80/2d5edbd5e1cb7fca82b5bd38e7c8a0a496fb20 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/94/7b3d714c38791e95ad6f928b48c98bb8708acd +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/95/e1f2df3f4d5f3d7a60588c25a7ca8a913d3c2a +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/b1/5f4a7666baf40d949548ead946a3370e273479 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/c3/ee8978c4c5d84c3b7d00ba8e5906933d027882 +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/c8/b0bffbc405ef3fad7354ff833fbec36d67ddfa +3 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/dd/8bdb934ec848137f011fe423b185505c343626 +2 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/e2/9be58c767cfeb27235c995d293a7d71aac0135 +2 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/ee/1224401fc6aac595145fa727dcf6706ac8aec1 +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/objects/f1/cc1a657b2e805c400f5dcaaa76bd29c6178b1b +0 -0
- data/sub/eac_git/vendor/git-subrepo/test/repo/init/refs/heads/master +1 -0
- data/sub/eac_git/vendor/git-subrepo/test/setup +205 -0
- data/sub/eac_git/vendor/git-subrepo/test/status.t +68 -0
- data/sub/eac_git/vendor/git-subrepo/test/submodule.t +45 -0
- data/sub/eac_ruby_utils/eac_ruby_utils.gemspec +1 -1
- data/sub/eac_ruby_utils/lib/eac_ruby_utils/method_class.rb +4 -2
- data/sub/eac_ruby_utils/lib/eac_ruby_utils/patches/{module → class}/method_class.rb +0 -0
- data/sub/eac_ruby_utils/lib/eac_ruby_utils/patches/class/static_method_class.rb +9 -0
- data/sub/eac_ruby_utils/lib/eac_ruby_utils/static_method_class.rb +12 -0
- data/sub/eac_ruby_utils/lib/eac_ruby_utils/version.rb +1 -1
- data/sub/eac_ruby_utils/spec/lib/eac_ruby_utils/patches/{module → class}/method_class_spec.rb +1 -1
- data/sub/eac_ruby_utils/spec/lib/eac_ruby_utils/patches/class/static_method_class_spec.rb +20 -0
- data/sub/eac_ruby_utils/spec/lib/eac_ruby_utils/static_method_class_spec.rb +44 -0
- metadata +244 -13
- data/sub/avm/lib/avm/instances/base/auto_values/install.rb +0 -47
- data/sub/avm/lib/avm/instances/base/auto_values/web.rb +0 -46
- data/sub/avm-tools/lib/avm/tools/runner/eac_webapp_base0.rb +0 -14
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module EacGit
|
|
4
|
+
class Local
|
|
5
|
+
class Commit
|
|
6
|
+
class DiffTreeLine
|
|
7
|
+
DIFF_TREE_PATTERN = /\A:(\d{6}) (\d{6}) (\S+) (\S+) (\S+)\t(\S.*)\z/.freeze
|
|
8
|
+
FIELDS = %w[src_mode dst_mode src_sha1 dst_sha1 status path].freeze
|
|
9
|
+
GIT_COMMAND_ARGS = %w[-c core.quotepath=off diff-tree --no-commit-id -r --full-index].freeze
|
|
10
|
+
|
|
11
|
+
attr_reader(*FIELDS)
|
|
12
|
+
|
|
13
|
+
# line: a line of command "git [GIT_COMMAND_ARGS]"'s output.
|
|
14
|
+
# Reference: https://git-scm.com/docs/git-diff-tree
|
|
15
|
+
def initialize(line)
|
|
16
|
+
m = DIFF_TREE_PATTERN.match(line.strip)
|
|
17
|
+
raise "\"#{line}\" did not match pattern" unless m
|
|
18
|
+
|
|
19
|
+
FIELDS.count.times { |i| send("#{FIELDS[i]}=", m[i + 1]) }
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def fields
|
|
23
|
+
FIELDS.map { |field| [field, send(field)] }.to_h
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
private
|
|
27
|
+
|
|
28
|
+
attr_writer(*FIELDS)
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
|
4
|
+
|
|
5
|
+
module EacGit
|
|
6
|
+
class Local
|
|
7
|
+
class Commit
|
|
8
|
+
require_sub __FILE__, include_modules: true
|
|
9
|
+
enable_simple_cache
|
|
10
|
+
include ::Comparable
|
|
11
|
+
|
|
12
|
+
FIELDS = {
|
|
13
|
+
author_name: '%an', author_email: '%ae', author_date: '%ai',
|
|
14
|
+
subject: '%s',
|
|
15
|
+
author_all: '%an <%ae>, %ai',
|
|
16
|
+
commit_hash: '%H', abbreviated_commit_hash: '%h',
|
|
17
|
+
commiter_name: '%cn', commiter_email: '%ce', commiter_date: '%ci',
|
|
18
|
+
commiter_all: '%cn <%ce>, %ci',
|
|
19
|
+
raw_body: '%B'
|
|
20
|
+
}.freeze
|
|
21
|
+
|
|
22
|
+
common_constructor :repo, :id
|
|
23
|
+
|
|
24
|
+
def <=>(other)
|
|
25
|
+
[repo, id] <=> [other.repo, other.id]
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def format(format)
|
|
29
|
+
repo.command('--no-pager', 'log', '-1', "--pretty=format:#{format}", id).execute!.strip
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
FIELDS.each do |field, format|
|
|
33
|
+
define_method(field) { format(format) }
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def changed_files_uncached
|
|
37
|
+
diff_tree_execute.each_line.map do |line|
|
|
38
|
+
::EacGit::Local::Commit::ChangedFile.new(self, line)
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
def changed_files_size_uncached
|
|
43
|
+
changed_files.inject(0) { |a, e| a + e.dst_size }
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
# @return [EacGit::Local::Commit, nil]
|
|
47
|
+
def parent
|
|
48
|
+
ps = parents
|
|
49
|
+
raise "#{self} has more than one parent" if ps.count > 2
|
|
50
|
+
|
|
51
|
+
ps.empty? ? nil : ps.first
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
# @return [Array<EacGit::Local::Commit>]
|
|
55
|
+
def parents
|
|
56
|
+
format('%P').each_line.map { |line| repo.commitize(line) }
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def root_child?
|
|
60
|
+
parents.empty?
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
private
|
|
64
|
+
|
|
65
|
+
def diff_tree_execute
|
|
66
|
+
args = []
|
|
67
|
+
args << '--root' if root_child?
|
|
68
|
+
args << id
|
|
69
|
+
repo.command(*::EacGit::Local::Commit::DiffTreeLine::GIT_COMMAND_ARGS, *args).execute!
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
end
|
|
73
|
+
end
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
|
4
|
+
require 'ostruct'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
module DirtyFiles
|
|
9
|
+
STATUS_LINE_PATTERN = /\A(.)(.)\s(.+)\z/.freeze
|
|
10
|
+
|
|
11
|
+
def dirty?
|
|
12
|
+
dirty_files.any?
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def dirty_file?(path)
|
|
16
|
+
absolute_path = path.to_pathname.expand_path(root_path)
|
|
17
|
+
dirty_files.any? do |df|
|
|
18
|
+
df.absolute_path == absolute_path
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def dirty_files
|
|
23
|
+
command('status', '--porcelain=v1', '--untracked-files', '--no-renames')
|
|
24
|
+
.execute!.each_line.map { |line| parse_status_line(line.gsub(/\n\z/, '')) }
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
private
|
|
28
|
+
|
|
29
|
+
def parse_status_line(line)
|
|
30
|
+
STATUS_LINE_PATTERN.if_match(line) do |m|
|
|
31
|
+
::OpenStruct.new(index: m[1], worktree: m[2], path: m[3].to_pathname,
|
|
32
|
+
absolute_path: m[3].to_pathname.expand_path(root_path))
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/remote'
|
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
module Log
|
|
9
|
+
def log(until_commit = nil, from_commit = nil)
|
|
10
|
+
until_commit, from_commit = [until_commit, from_commit].map { |c| commitize(c) }
|
|
11
|
+
from_commit ||= head
|
|
12
|
+
command('log', '--format=%H', "#{until_commit.id}..#{from_commit.id}")
|
|
13
|
+
.execute!.each_line.map { |line| commitize(line.strip) }
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/remote'
|
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
class Remote
|
|
9
|
+
NO_SUCH_REMOTE_CODE = 128
|
|
10
|
+
|
|
11
|
+
enable_simple_cache
|
|
12
|
+
|
|
13
|
+
common_constructor :local, :name
|
|
14
|
+
|
|
15
|
+
def exist?
|
|
16
|
+
url
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
# @return [String, nil]
|
|
20
|
+
def url
|
|
21
|
+
local.command('remote', 'get-url', name)
|
|
22
|
+
.execute!(exit_outputs: { NO_SUCH_REMOTE_CODE => nil })
|
|
23
|
+
.if_present(nil, &:strip)
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
|
4
|
+
require 'eac_git/local/remote'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
module Remotes
|
|
9
|
+
def remote(name)
|
|
10
|
+
::EacGit::Local::Remote.new(self, name)
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def remotes
|
|
14
|
+
command('remote').execute!.each_line.map(&:strip).reject(&:blank?).map do |name|
|
|
15
|
+
remote(name)
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
20
|
+
end
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
|
4
|
+
require 'parseconfig'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
class Subrepo
|
|
9
|
+
class Config
|
|
10
|
+
MAPPING = {
|
|
11
|
+
command_version: :cmdver, commit_id: :commit, join_method: :method,
|
|
12
|
+
parent_commit_id: :parent, remote_branch: :branch, remote_uri: :remote
|
|
13
|
+
}.freeze
|
|
14
|
+
|
|
15
|
+
class << self
|
|
16
|
+
def from_file(file_path)
|
|
17
|
+
new(
|
|
18
|
+
::ParseConfig.new(file_path.to_pathname)['subrepo']
|
|
19
|
+
)
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
common_constructor :values do
|
|
24
|
+
self.values = values.with_indifferent_access
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
MAPPING.each do |method_name, _config_key|
|
|
28
|
+
define_method(method_name) do
|
|
29
|
+
values[MAPPING.fetch(method_name)]
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
define_method("#{method_name}=") do |value|
|
|
33
|
+
values[MAPPING.fetch(method_name)] = value
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def to_content
|
|
38
|
+
"[subrepo]\n" + MAPPING.map { |k, v| " #{v} = #{send(k)}\n" }.join
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
end
|
|
42
|
+
end
|
|
43
|
+
end
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/remote'
|
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
class Local
|
|
8
|
+
# A git-subrepo (https://github.com/ingydotnet/git-subrepo) in a [EacGit::Local].
|
|
9
|
+
class Subrepo
|
|
10
|
+
require_sub __FILE__
|
|
11
|
+
enable_simple_cache
|
|
12
|
+
|
|
13
|
+
common_constructor :local, :subpath do
|
|
14
|
+
self.subpath = subpath.to_pathname
|
|
15
|
+
local.raise_error "Config file \"#{config_absolute_path}\" not found" unless
|
|
16
|
+
config_absolute_path.file?
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def command(subrepo_subcommand, *subrepo_subcommand_args)
|
|
20
|
+
local.command('subrepo', subrepo_subcommand, subpath.to_path,
|
|
21
|
+
*subrepo_subcommand_args)
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
delegate(*::EacGit::Local::Subrepo::Config::MAPPING.keys, to: :config)
|
|
25
|
+
|
|
26
|
+
def write_config
|
|
27
|
+
config_absolute_path.write(config.to_content)
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
private
|
|
31
|
+
|
|
32
|
+
def config_uncached
|
|
33
|
+
::EacGit::Local::Subrepo::Config.from_file(config_absolute_path)
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def config_absolute_path_uncached
|
|
37
|
+
config_relative_path.expand_path(local.root_path)
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def config_relative_path_uncached
|
|
41
|
+
subpath.join('.gitrepo')
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def remote_uncached
|
|
45
|
+
::EacGit::Remote.new(remote_uri)
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/executables'
|
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
# A Git repository in local filesystem.
|
|
8
|
+
class Local
|
|
9
|
+
require_sub __FILE__, include_modules: true
|
|
10
|
+
include ::Comparable
|
|
11
|
+
|
|
12
|
+
HEAD_REFERENCE = 'HEAD'
|
|
13
|
+
|
|
14
|
+
class << self
|
|
15
|
+
def find(path)
|
|
16
|
+
path = path.to_pathname.expand_path
|
|
17
|
+
if path.join('.git').exist?
|
|
18
|
+
new(path)
|
|
19
|
+
elsif path.to_path != '/'
|
|
20
|
+
find(path.parent)
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
common_constructor :root_path do
|
|
26
|
+
self.root_path = root_path.to_pathname
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def <=>(other)
|
|
30
|
+
root_path <=> other.root_path
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
# Retrieves a local branch.
|
|
34
|
+
#
|
|
35
|
+
# @param name [String] Ex.: for "refs/heads/master", name should be "master".
|
|
36
|
+
# @return [EacGit::Local::Branch]
|
|
37
|
+
def branch(name)
|
|
38
|
+
::EacGit::Local::Branch.new(self, name)
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def commit(ref, required = false)
|
|
42
|
+
rev_parse(ref, required).if_present { |v| ::EacGit::Local::Commit.new(self, v) }
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def commitize(source)
|
|
46
|
+
if source.is_a?(::EacGit::Local::Commit)
|
|
47
|
+
return source if source.repo == self
|
|
48
|
+
|
|
49
|
+
source = source.id
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
source.to_s.strip.if_present(nil) { |v| ::EacGit::Local::Commit.new(self, v) }
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
# Retrieves the current local branch.
|
|
56
|
+
#
|
|
57
|
+
# @return [EacGit::Local::Branch, nil]
|
|
58
|
+
def current_branch
|
|
59
|
+
command('symbolic-ref', '--quiet', HEAD_REFERENCE)
|
|
60
|
+
.execute!(exit_outputs: { 256 => '' })
|
|
61
|
+
.gsub(%r{\Arefs/heads/}, '').strip
|
|
62
|
+
.if_present { |v| branch(v) }
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
def descendant?(descendant, ancestor)
|
|
66
|
+
base = merge_base(descendant, ancestor)
|
|
67
|
+
return false if base.blank?
|
|
68
|
+
|
|
69
|
+
revparse = command('rev-parse', '--verify', ancestor).execute!.strip
|
|
70
|
+
base == revparse
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
# @return [EacGit::Local::Commit
|
|
74
|
+
def head(required = true)
|
|
75
|
+
commit(HEAD_REFERENCE, required)
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
def merge_base(*commits)
|
|
79
|
+
refs = commits.dup
|
|
80
|
+
while refs.count > 1
|
|
81
|
+
refs[1] = merge_base_pair(refs[0], refs[1])
|
|
82
|
+
return nil if refs[1].blank?
|
|
83
|
+
|
|
84
|
+
refs.shift
|
|
85
|
+
end
|
|
86
|
+
refs.first
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
def command(*args)
|
|
90
|
+
::EacGit::Executables.git.command('-C', root_path.to_path, *args)
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
def raise_error(message)
|
|
94
|
+
raise "#{root_path}: #{message}"
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
def rev_parse(ref, required = false)
|
|
98
|
+
r = command('rev-parse', ref).execute!(exit_outputs: { 128 => nil, 32_768 => nil })
|
|
99
|
+
r.strip! if r.is_a?(String)
|
|
100
|
+
return r if r.present?
|
|
101
|
+
return nil unless required
|
|
102
|
+
|
|
103
|
+
raise_error "Reference \"#{ref}\" not found"
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
def subrepo(subpath)
|
|
107
|
+
::EacGit::Local::Subrepo.new(self, subpath)
|
|
108
|
+
end
|
|
109
|
+
|
|
110
|
+
# @return [Array<EacGit::Local::Subrepo>]
|
|
111
|
+
def subrepos
|
|
112
|
+
command('subrepo', '-q', 'status').execute!.split("\n").map(&:strip).select(&:present?)
|
|
113
|
+
.map { |subpath| subrepo(subpath) }
|
|
114
|
+
end
|
|
115
|
+
|
|
116
|
+
def to_s
|
|
117
|
+
"#{self.class}[#{root_path}]"
|
|
118
|
+
end
|
|
119
|
+
|
|
120
|
+
private
|
|
121
|
+
|
|
122
|
+
def merge_base_pair(commit1, commit2)
|
|
123
|
+
command('merge-base', commit1, commit2).execute!(exit_outputs: { 256 => nil })
|
|
124
|
+
.if_present(nil, &:strip)
|
|
125
|
+
end
|
|
126
|
+
end
|
|
127
|
+
end
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
|
4
|
+
|
|
5
|
+
module EacGit
|
|
6
|
+
class Remote
|
|
7
|
+
class LsResult
|
|
8
|
+
class << self
|
|
9
|
+
def by_ls_remote_command_output(output)
|
|
10
|
+
new(
|
|
11
|
+
output.each_line.map { |line| line.strip.split(/\s+/) }.map { |x| [x[1], x[0]] }.to_h
|
|
12
|
+
)
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
common_constructor :hashes
|
|
17
|
+
delegate :fetch, :'[]', :count, :any?, :empty?, to: :hashes
|
|
18
|
+
end
|
|
19
|
+
end
|
|
20
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/executables'
|
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
# A Git remote repository referenced by URI.
|
|
8
|
+
class Remote
|
|
9
|
+
require_sub __FILE__
|
|
10
|
+
|
|
11
|
+
common_constructor :uri
|
|
12
|
+
|
|
13
|
+
def ls
|
|
14
|
+
::EacGit::Remote::LsResult.by_ls_remote_command_output(
|
|
15
|
+
::EacGit::Executables.git.command('ls-remote', uri).execute!
|
|
16
|
+
)
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/executables'
|
|
4
|
+
require 'eac_git/rspec/stubbed_git_local_repo'
|
|
5
|
+
|
|
6
|
+
module EacGit
|
|
7
|
+
module Rspec
|
|
8
|
+
module Setup
|
|
9
|
+
def self.extended(setup_obj)
|
|
10
|
+
setup_obj.setup_conditional_git
|
|
11
|
+
setup_obj.setup_stubbed_git_local_repo
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def setup_conditional_git
|
|
15
|
+
conditional(:git) { ::EacGit::Executables.git.validate }
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
def setup_stubbed_git_local_repo
|
|
19
|
+
rspec_config.include ::EacGit::Rspec::StubbedGitLocalRepo
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/local'
|
|
4
|
+
require 'eac_ruby_utils/envs'
|
|
5
|
+
require 'fileutils'
|
|
6
|
+
require 'securerandom'
|
|
7
|
+
require 'tmpdir'
|
|
8
|
+
|
|
9
|
+
module EacGit
|
|
10
|
+
module Rspec
|
|
11
|
+
module StubbedGitLocalRepo
|
|
12
|
+
def stubbed_git_local_repo(bare = false)
|
|
13
|
+
path = ::Dir.mktmpdir
|
|
14
|
+
::EacRubyUtils::Envs.local.command(stubbed_git_local_repo_args(path, bare)).execute!
|
|
15
|
+
repo = StubbedGitRepository.new(path)
|
|
16
|
+
repo.command('config', 'user.email', 'theuser@example.net').execute!
|
|
17
|
+
repo.command('config', 'user.name', 'The User').execute!
|
|
18
|
+
repo
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
private
|
|
22
|
+
|
|
23
|
+
def stubbed_git_local_repo_args(path, bare)
|
|
24
|
+
r = %w[git init]
|
|
25
|
+
r << '--bare' if bare
|
|
26
|
+
r + [path]
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
class StubbedGitRepository < ::EacGit::Local
|
|
30
|
+
def file(*subpath)
|
|
31
|
+
StubbedGitRepositoryFile.new(self, subpath)
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
# @return [EacGit::Local::Commit
|
|
35
|
+
def random_commit
|
|
36
|
+
content = ::SecureRandom.hex
|
|
37
|
+
file = "#{content}.txt"
|
|
38
|
+
file(file).write(content)
|
|
39
|
+
command('add', file).execute!
|
|
40
|
+
command('commit', '-m', "Random commit: #{file}.").execute!
|
|
41
|
+
head
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
class StubbedGitRepositoryFile
|
|
46
|
+
attr_reader :git, :subpath
|
|
47
|
+
|
|
48
|
+
def initialize(git, subpath)
|
|
49
|
+
@git = git
|
|
50
|
+
@subpath = subpath
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def path
|
|
54
|
+
git.root_path.join(*subpath)
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def touch
|
|
58
|
+
::FileUtils.touch(path.to_path)
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
def delete
|
|
62
|
+
path.unlink
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
def write(content)
|
|
66
|
+
path.write(content)
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
end
|
|
70
|
+
end
|
|
71
|
+
end
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/executables'
|
|
4
|
+
|
|
5
|
+
RSpec.describe(::EacGit::Executables, git: true) do
|
|
6
|
+
it 'output version' do
|
|
7
|
+
expect(described_class.git.command('--version').execute!).to be_present
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
it 'subrepo output version' do
|
|
11
|
+
expect(described_class.git.command('subrepo', '--version').execute!).to be_present
|
|
12
|
+
end
|
|
13
|
+
end
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'eac_git/local/commit/diff_tree_line'
|
|
4
|
+
|
|
5
|
+
RSpec.describe ::EacGit::Local::Commit::DiffTreeLine, git: true do
|
|
6
|
+
include_examples 'source_target_fixtures', __FILE__ do
|
|
7
|
+
def source_data(source_file)
|
|
8
|
+
::File.read(source_file).each_line.map do |line|
|
|
9
|
+
described_class.new(line).fields
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
:000000 100644 0000000000000000000000000000000000000000 f380aec0bd8dd777edac43b11636e46cad04273a A nomes.txt
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
:100644 100644 40bcdecb4214cd8a3fcf96cd25a2beb87e7e7cd8 4a30dfae816b984f05cfb594e0d5958bb8c387ae M nomes.txt
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
:100644 000000 10728718a2915256ab162f1e05178ebff9efa6ce 0000000000000000000000000000000000000000 D nomes3.txt
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
---
|
|
2
|
+
- src_mode: '100644'
|
|
3
|
+
dst_mode: '000000'
|
|
4
|
+
src_sha1: 4a30dfae816b984f05cfb594e0d5958bb8c387ae
|
|
5
|
+
dst_sha1: '0000000000000000000000000000000000000000'
|
|
6
|
+
status: D
|
|
7
|
+
path: nomes.txt
|
|
8
|
+
- src_mode: '000000'
|
|
9
|
+
dst_mode: '100644'
|
|
10
|
+
src_sha1: '0000000000000000000000000000000000000000'
|
|
11
|
+
dst_sha1: 4a30dfae816b984f05cfb594e0d5958bb8c387ae
|
|
12
|
+
status: A
|
|
13
|
+
path: nomes2.txt
|