wayfarer 0.4.2 → 0.4.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +10 -0
- data/Gemfile.lock +2 -2
- data/docs/cookbook/batch_routing.md +1 -1
- data/docs/cookbook/navigation.md +43 -0
- data/docs/guides/error_handling.md +23 -1
- data/docs/guides/jobs.md +4 -4
- data/docs/guides/navigation.md +1 -1
- data/docs/guides/{browser_automation → networking}/capybara.md +3 -1
- data/docs/guides/{browser_automation → networking}/custom_adapters.md +0 -0
- data/docs/guides/{browser_automation → networking}/ferrum.md +0 -0
- data/docs/guides/networking/http.md +33 -0
- data/docs/guides/{browser_automation → networking}/selenium.md +0 -0
- data/docs/reference/configuration_keys.md +1 -0
- data/lib/wayfarer/base.rb +37 -27
- data/lib/wayfarer/cli/base.rb +19 -1
- data/lib/wayfarer/cli/job.rb +4 -8
- data/lib/wayfarer/config/networking.rb +3 -0
- data/lib/wayfarer/gc.rb +3 -4
- data/lib/wayfarer/handler.rb +15 -0
- data/lib/wayfarer/middleware/base.rb +19 -0
- data/lib/wayfarer/middleware/chain.rb +8 -0
- data/lib/wayfarer/middleware/controller.rb +40 -0
- data/lib/wayfarer/middleware/dedup.rb +5 -0
- data/lib/wayfarer/middleware/dispatch.rb +22 -0
- data/lib/wayfarer/middleware/fetch.rb +24 -15
- data/lib/wayfarer/middleware/lazy.rb +11 -0
- data/lib/wayfarer/middleware/normalize.rb +2 -0
- data/lib/wayfarer/middleware/router.rb +20 -14
- data/lib/wayfarer/middleware/stage.rb +6 -2
- data/lib/wayfarer/networking/context.rb +2 -1
- data/lib/wayfarer/networking/ferrum.rb +1 -0
- data/lib/wayfarer/networking/follow.rb +22 -0
- data/lib/wayfarer/networking/result.rb +0 -8
- data/lib/wayfarer/routing/matchers/host.rb +3 -1
- data/lib/wayfarer/routing/matchers/path.rb +1 -1
- data/lib/wayfarer/routing/result.rb +0 -5
- data/lib/wayfarer/routing/router.rb +3 -2
- data/lib/wayfarer/serializer.rb +2 -2
- data/lib/wayfarer/task.rb +4 -2
- data/lib/wayfarer.rb +2 -9
- data/spec/base_spec.rb +33 -42
- data/spec/cli/job_spec.rb +9 -5
- data/spec/gc_spec.rb +5 -9
- data/spec/handler_spec.rb +11 -0
- data/spec/integration/callbacks_spec.rb +85 -0
- data/spec/integration/page_spec.rb +62 -0
- data/spec/integration/params_spec.rb +56 -0
- data/spec/integration/stage_spec.rb +51 -0
- data/spec/integration/steering_spec.rb +57 -0
- data/spec/middleware/chain_spec.rb +15 -2
- data/spec/middleware/controller_spec.rb +86 -0
- data/spec/middleware/dedup_spec.rb +20 -8
- data/spec/middleware/dispatch_spec.rb +43 -0
- data/spec/middleware/fetch_spec.rb +109 -54
- data/spec/middleware/normalize_spec.rb +5 -4
- data/spec/middleware/router_spec.rb +73 -48
- data/spec/middleware/stage_spec.rb +42 -19
- data/spec/networking/context_spec.rb +17 -0
- data/spec/networking/follow_spec.rb +41 -0
- data/spec/spec_helpers.rb +11 -3
- data/spec/support/static/git-scm.com/assets/application-38b0d42ff05ffea45841edebbd14b75b89585646153808e82907c2c5c11f324b.js +772 -0
- data/spec/support/static/git-scm.com/assets/application-cafcf280f67db0e6d8168ba98a38da878769a9d5f37793b68ffb963a02d185e0.css +1 -0
- data/spec/support/static/git-scm.com/assets/modernize-b3ebe0c31c24f230dc62179d3e1030d2e57a53b1668d9382c0a27dbd44a94beb.js +20 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-Bash.html +751 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-PowerShell.html +804 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-Sublime-Text.html +728 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-Visual-Studio-Code.html +751 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-Visual-Studio.html +740 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Git-in-Zsh.html +765 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Graphical-Interfaces.html +931 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-A:-Git-in-Other-Environments-Summary.html +702 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-B:-Embedding-Git-in-your-Applications-Command-line-Git.html +720 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-B:-Embedding-Git-in-your-Applications-Dulwich.html +746 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-B:-Embedding-Git-in-your-Applications-JGit.html +889 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-B:-Embedding-Git-in-your-Applications-Libgit2.html +1003 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-B:-Embedding-Git-in-your-Applications-go-git.html +792 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Administration.html +745 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Basic-Snapshotting.html +840 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Branching-and-Merging.html +829 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Debugging.html +731 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Email.html +766 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-External-Systems.html +721 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Getting-and-Creating-Projects.html +746 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Inspection-and-Comparison.html +735 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Patching.html +742 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Plumbing-Commands.html +715 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Setup-and-Config.html +863 -0
- data/spec/support/static/git-scm.com/book/en/v2/Appendix-C:-Git-Commands-Sharing-and-Updating-Projects.html +802 -0
- data/spec/support/static/git-scm.com/book/en/v2/Customizing-Git-An-Example-Git-Enforced-Policy.html +1200 -0
- data/spec/support/static/git-scm.com/book/en/v2/Customizing-Git-Git-Attributes.html +1134 -0
- data/spec/support/static/git-scm.com/book/en/v2/Customizing-Git-Git-Configuration.html +1315 -0
- data/spec/support/static/git-scm.com/book/en/v2/Customizing-Git-Git-Hooks.html +876 -0
- data/spec/support/static/git-scm.com/book/en/v2/Customizing-Git-Summary.html +704 -0
- data/spec/support/static/git-scm.com/book/en/v2/Distributed-Git-Contributing-to-a-Project.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/Distributed-Git-Distributed-Workflows.html +859 -0
- data/spec/support/static/git-scm.com/book/en/v2/Distributed-Git-Maintaining-a-Project.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/Distributed-Git-Summary.html +704 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-A-Short-History-of-Git.html +735 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-About-Version-Control.html +783 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup.html +889 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-Getting-Help.html +750 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-Installing-Git.html +879 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-Summary.html +704 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-The-Command-Line.html +711 -0
- data/spec/support/static/git-scm.com/book/en/v2/Getting-Started-What-is-Git?.html +857 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository.html +816 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Git-Aliases.html +775 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Summary.html +703 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Tagging.html +1049 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Undoing-Things.html +998 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Viewing-the-Commit-History.html +1172 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Basics-Working-with-Remotes.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Basic-Branching-and-Merging.html +1102 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Branch-Management.html +946 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Branches-in-a-Nutshell.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Branching-Workflows.html +786 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Rebasing.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Remote-Branches.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Branching-Summary.html +705 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Environment-Variables.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Git-Objects.html +1209 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Git-References.html +939 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Maintenance-and-Data-Recovery.html +1086 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Packfiles.html +876 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Plumbing-and-Porcelain.html +745 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Summary.html +708 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-The-Refspec.html +872 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Internals-Transfer-Protocols.html +1043 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Advanced-Merging.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Bundling.html +888 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Credential-Storage.html +1035 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Debugging-with-Git.html +861 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Interactive-Staging.html +920 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Replace.html +949 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Rerere.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Reset-Demystified.html +1236 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Revision-Selection.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Rewriting-History.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Searching.html +875 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Signing-Your-Work.html +922 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Stashing-and-Cleaning.html +1039 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Submodules.html +1864 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-Tools-Summary.html +705 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-and-Other-Systems-Git-as-a-Client.html +2656 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-and-Other-Systems-Migrating-to-Git.html +1741 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-and-Other-Systems-Summary.html +703 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Generating-Your-SSH-Public-Key.html +759 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Getting-Git-on-a-Server.html +827 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Git-Daemon.html +775 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-GitLab.html +872 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-GitWeb.html +776 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Setting-Up-the-Server.html +870 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Smart-HTTP.html +789 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Summary.html +709 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-The-Protocols.html +963 -0
- data/spec/support/static/git-scm.com/book/en/v2/Git-on-the-Server-Third-Party-Hosted-Options.html +711 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Account-Setup-and-Configuration.html +858 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Contributing-to-a-Project.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Maintaining-a-Project.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Managing-an-organization.html +797 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Scripting-GitHub.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/GitHub-Summary.html +704 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_abort_merge.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_add_email_addresses.html +858 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_advanced_merging.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_an_example_git_enforced_policy.html +1200 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_annotated_tags.html +1049 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_api_comment.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_bare_repo.html +827 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_basic_branching.html +1102 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_basic_merge_conflicts.html +1102 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_basic_merging.html +1102 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_binary_search.html +861 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_branch_management.html +946 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_branch_references.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_build_number.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_bundling.html +888 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_changing_multiple.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_checking_out_conflicts.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_checking_out_remotes.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_checking_status.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_cloning_submodules.html +1864 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_commit_guidelines.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_commit_ranges.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_commit_status.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_committing_changes.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_contrib_file.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_contributing_project.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_create_new_branch.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_credential_caching.html +1035 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_custom_importer.html +1741 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_data_recovery.html +1086 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_delete_branches.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_editor.html +889 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_eg_task_lists.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_email_hooks.html +876 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_email_notification.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_email_notifications.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_email_pr.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_enforcing_commit_message_format.html +1200 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_example_markdown.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_external_merge_tools.html +1315 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_fetch_and_push_on_different_repositories.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_fetching_and_pulling.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_file_annotation.html +861 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_first_time.html +889 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_generate_ssh_key.html +759 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_getting_a_repo.html +816 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_getting_git_on_a_server.html +827 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_aliases.html +775 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_am.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_amend.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_branches_overview.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_clean.html +1039 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_cloning.html +816 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_commit_objects.html +1209 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_config.html +1315 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_diff_staged.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_gc.html +1086 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_grep.html +875 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_help.html +750 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_hooks.html +876 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_mv.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_p4.html +1741 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_p4_branches.html +2656 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_reflog.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_refs.html +939 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_reset.html +1236 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_stashing.html +1039 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_submodules.html +1864 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_svn.html +2656 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_git_tagging.html +1049 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_gitlab_groups_section.html +872 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_ignoring.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_inspecting_remote.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_integration_manager.html +859 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_interactive_staging.html +920 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_keyword_expansion.html +1134 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_libgit2_bindings.html +1003 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_manual_remerge.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_md_code.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_md_drag.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_md_emoji.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_md_quote.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_merge_button.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_merge_log.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_merge_rebase_work.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_new_repo_dropdown.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_not_center.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_org_page.html +797 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_other_client_hooks.html +876 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_p4_git_fusion.html +2656 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_patches_from_email.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_personal_avatar.html +858 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_plumbing_porcelain.html +745 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_closed.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_discussion.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_fail.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_final.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_references.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_references_render.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pr_refs.html +1218 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pre_merge_rebase_work.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_preparing_release.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_private_team.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_project_over_email.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_public_project.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_publishing_submodules.html +1864 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pushing_branches.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pushing_refspecs.html +872 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_pushing_remotes.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rebase_cherry_pick.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rebase_peril.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rebase_rebase.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rebase_rebase_work.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rebasing.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_refspec.html +872 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_remote_branches.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_remote_repos.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_removing_file_every_commit.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_removing_files.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_removing_objects.html +1086 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_replace.html +949 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_reverse_commit.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_revision_selection.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_rewriting_history.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_searching.html +875 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_service_config.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_services_hooks.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_setting_up_server.html +870 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_sharing_tags.html +1049 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_signing.html +922 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_signing_commits.html +922 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_squashing.html +1182 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_starting_submodules.html +1864 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_subtree_merge.html +1605 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_switching_branches.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_tagging_releases.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_task_list_progress.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_team_page.html +797 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_the_index.html +1236 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_the_shortlog.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_topic_branch.html +786 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_tracking_branches.html +1009 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_tracking_files.html +1432 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_tree_objects.html +1209 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_triple_dot.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_undoing.html +998 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_unstaging.html +998 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_viewing_history.html +1172 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_web_hook.html +1059 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/_what_is_introduced.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch01-getting-started.html +783 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch02-git-basics-chapter.html +816 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch03-git-branching.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch05-distributed-git.html +859 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch06-github.html +858 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch06-github_flow.html +1502 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch10-git-internals.html +745 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ch_core_editor.html +863 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/divergent_history.html +1020 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/double_dot.html +1178 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/filters_a.html +1134 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/filters_b.html +1134 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/limit_options.html +1172 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/log_options.html +1172 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_a.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_b.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_c.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_d.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_e.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/merwf_f.html +1354 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/oh_my_zsh_git.html +765 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/pretty_format.html +1172 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/psp_b.html +1667 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/rbdiag_e.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/rbdiag_g.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/rbdiag_h.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/rbdiag_i.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/rebasing-merging-example.html +1028 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ref_rerere.html +983 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/ref_the_ref.html +939 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/wfdiag_b.html +859 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/wfdiag_c.html +859 -0
- data/spec/support/static/git-scm.com/book/en/v2/ch00/what_is_git_section.html +857 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/2fa-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/account-settings.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/advance-master.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/advance-testing.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/areas.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/avatar-crop.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-branching-6.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-merging-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-merging-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-rebase-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-rebase-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-rebase-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/basic-rebase-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/benevolent-dictator.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-01-start.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-02-pr.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-03-pull-request-open.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-04-email.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-04-pr-comment.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-05-general-comment.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/blink-06-final.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/branch-and-history.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/branch_widget_mac.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/branch_widget_win.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/centralized.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/centralized_workflow.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/checkout-master.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/clean.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/collaborators.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/commit-and-tree.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/commits-and-parents.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/data-model-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/data-model-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/data-model-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/data-model-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/deltas.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/distributed.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/double-dot.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/email-settings.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/forkbutton.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-bash.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-diff-check.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-fusion-boot.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-fusion-perforce-graph.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-gui.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-instaweb.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/git-osx-installer.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/github_mac.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/github_win.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/gitk.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/gitlab-groups.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/gitlab-menu.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/gitlab-users.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/head-to-master.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/head-to-testing.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/integration-manager.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/interesting-rebase-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/interesting-rebase-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/interesting-rebase-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/interesting-rebase-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/interesting-rebase-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/jb.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/large-merges-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/large-merges-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/lifecycle.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/local.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/lr-branches-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/lr-branches-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-01-email.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-02-merge.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-03-email-resp.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-04-target.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-05-mentions.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-06-unsubscribe.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-07-notifications.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-08-notifications-page.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-09-contrib.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-10-default-branch.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/maint-11-transfer.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/managed-team-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/managed-team-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/managed-team-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/managed-team-flow.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-01-example.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-02-tasks.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-03-task-summary.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-04-fenced-code.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-05-quote.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-06-emoji-complete.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-07-emoji.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/markdown-08-drag-drop.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/mentions-01-syntax.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/mentions-02-render.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/mentions-03-closed.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/merging-workflows-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/merging-workflows-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/merging-workflows-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/merging-workflows-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/merging-workflows-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/new-repo.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/neworg.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/newrepo.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/newrepoform.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/orgs-01-page.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/orgs-02-teams.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/orgs-03-audit.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/p4merge.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/perils-of-rebasing-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/perils-of-rebasing-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/perils-of-rebasing-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/perils-of-rebasing-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/perils-of-rebasing-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/posh-git.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/pr-01-fail.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/pr-02-merge-fix.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/public-small-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/public-small-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/public-small-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/rebasing-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/rebasing-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/remote-branches-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/remote-branches-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/remote-branches-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/remote-branches-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/remote-branches-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/replace1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/replace2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/replace3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/replace4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/replace5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reposettingslink.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/rerere1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/rerere2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/rerere3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-checkout.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-ex6.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-hard.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-mixed.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-path1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-path2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-path3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-soft.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-squash-r1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-squash-r2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-squash-r3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-start.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/reset-workflow.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-01-services.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-02-email-service.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-03-webhook.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-04-webhook-debug.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-05-access-token.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-06-comment.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/scripting-07-status.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/signup.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-4.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-5.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-6.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-7.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/small-team-flow.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/smudge.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/snapshots.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/ssh-keys.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/topic-branches-1.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/topic-branches-2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/two-branches.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/undomerge-reset.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/undomerge-revert.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/undomerge-revert2.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/undomerge-revert3.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/undomerge-start.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/your-profile.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/zsh-oh-my.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2/images/zsh-prompt.png +0 -0
- data/spec/support/static/git-scm.com/book/en/v2.html +688 -0
- data/spec/support/static/git-scm.com/favicon.ico +0 -0
- data/spec/support/static/git-scm.com/images/bg/body.jpg +0 -0
- data/spec/support/static/git-scm.com/images/bg/isometric-grid.png +0 -0
- data/spec/support/static/git-scm.com/images/bg/isometric-grid@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/bg/search-header.jpg +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/android.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/android@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/eclipse.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/eclipse@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/facebook.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/facebook@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/gnome.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/gnome@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/google.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/google@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/kde.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/kde@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/linked-in.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/linked-in@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/linux.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/linux@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/microsoft.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/microsoft@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/netflix.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/netflix@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/perl.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/perl@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/postgresql.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/postgresql@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/qt.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/qt@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/rails.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/rails@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/twitter.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/twitter@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/x.png +0 -0
- data/spec/support/static/git-scm.com/images/company-project-logos/x@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/epub.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/admin-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/admin-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/apple.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/apple@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/book.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/book@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/box.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/box@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/branch-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/branch-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/camera-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/camera-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/chevron-up@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/code.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/code@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/debugging-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/debugging-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/document.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/document@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/download.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/email-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/email-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/external-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/external-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/gui.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/gui@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/info.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/info@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/inspection-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/inspection-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/linux.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/linux@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/nav-circles.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/nav-circles@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/patching-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/patching-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/plumbing-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/plumbing-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/projects-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/projects-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/search.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/search@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/server-admin-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/server-admin-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/setup-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/setup-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/sharing-sm.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/sharing-sm@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/sidebar.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/sidebar@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/source-code.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/source-code@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/windows.png +0 -0
- data/spec/support/static/git-scm.com/images/icons/windows@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/logo@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/mobi.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-default.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-default@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-linux.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-linux@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-mac.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-mac@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-windows.png +0 -0
- data/spec/support/static/git-scm.com/images/monitor-windows@2x.png +0 -0
- data/spec/support/static/git-scm.com/images/pdf.png +0 -0
- data/spec/support/static/git-scm.com/images/progit2.png +0 -0
- data/spec/support/static/git-scm.com/images/sidebar-divider.png +0 -0
- data/spec/support/static/git-scm.com/images/sidebar-divider@2x.png +0 -0
- data/spec/support/static/git-scm.com/robots.txt +0 -0
- data/spec/task_spec.rb +7 -0
- data/wayfarer.gemspec +2 -2
- metadata +605 -9
- data/lib/wayfarer/middleware/worker.rb +0 -30
- data/spec/middleware/worker_spec.rb +0 -117
@@ -0,0 +1,1134 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html lang="en">
|
3
|
+
|
4
|
+
<head>
|
5
|
+
<!-- Global site tag (gtag.js) - Google Analytics -->
|
6
|
+
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-49925874-3"></script>
|
7
|
+
<script>
|
8
|
+
window.dataLayer = window.dataLayer || [];
|
9
|
+
function gtag(){dataLayer.push(arguments);}
|
10
|
+
gtag('js', new Date());
|
11
|
+
|
12
|
+
gtag('config', 'UA-49925874-3');
|
13
|
+
</script>
|
14
|
+
|
15
|
+
<meta charset='utf-8'>
|
16
|
+
<meta content='IE=edge,chrome=1' http-equiv='X-UA-Compatible'>
|
17
|
+
<meta name="viewport" content="width=device-width, initial-scale=1">
|
18
|
+
<title>Git - Git Attributes</title>
|
19
|
+
|
20
|
+
<link href='../../../../favicon.ico' rel='shortcut icon' type='image/x-icon'>
|
21
|
+
|
22
|
+
<link rel="stylesheet" media="screen" href="../../../../assets/application-cafcf280f67db0e6d8168ba98a38da878769a9d5f37793b68ffb963a02d185e0.css" />
|
23
|
+
<script src="../../../../assets/modernize-b3ebe0c31c24f230dc62179d3e1030d2e57a53b1668d9382c0a27dbd44a94beb.js"></script>
|
24
|
+
<!--[if (gte IE 6)&(lte IE 8)]>
|
25
|
+
<script src="/javascripts/selectivizr-min.js"></script>
|
26
|
+
<![endif]-->
|
27
|
+
|
28
|
+
</head>
|
29
|
+
|
30
|
+
<body id="documentation">
|
31
|
+
|
32
|
+
<div class="inner">
|
33
|
+
<header>
|
34
|
+
|
35
|
+
<a href="https://git-scm.com/"><img src="../../../../images/logo@2x.png" width="110" height="46" alt="Git" /></a>
|
36
|
+
<span id="tagline"></span>
|
37
|
+
<script type="text/javascript">
|
38
|
+
var taglines = ["fast-version-control","everything-is-local","distributed-even-if-your-workflow-isnt","local-branching-on-the-cheap","distributed-is-the-new-centralized"];
|
39
|
+
var tagline = taglines[Math.floor(Math.random() * taglines.length)];
|
40
|
+
document.getElementById('tagline').innerHTML = '--' + tagline;
|
41
|
+
</script>
|
42
|
+
<form id="search" action="https://git-scm.com/search/results">
|
43
|
+
<input id="search-text" name="search" placeholder="Search entire site..." autocomplete="off" type="text" />
|
44
|
+
</form>
|
45
|
+
<div id="search-results"></div>
|
46
|
+
|
47
|
+
</header>
|
48
|
+
|
49
|
+
</div> <!-- .inner -->
|
50
|
+
|
51
|
+
<div class="inner">
|
52
|
+
<div id="content-wrapper">
|
53
|
+
<button class="sidebar-btn"></button>
|
54
|
+
<aside class="sidebar" id="sidebar">
|
55
|
+
<nav>
|
56
|
+
<ul>
|
57
|
+
<li>
|
58
|
+
<a href="https://git-scm.com/about">About</a>
|
59
|
+
<ul class="">
|
60
|
+
<li>
|
61
|
+
<a href="https://git-scm.com/about">Branching and Merging</a>
|
62
|
+
</li>
|
63
|
+
<li>
|
64
|
+
<a href="https://git-scm.com/about/small-and-fast">Small and Fast</a>
|
65
|
+
</li>
|
66
|
+
<li>
|
67
|
+
<a href="https://git-scm.com/about/distributed">Distributed</a>
|
68
|
+
</li>
|
69
|
+
<li>
|
70
|
+
<a href="https://git-scm.com/about/info-assurance">Data Assurance</a>
|
71
|
+
</li>
|
72
|
+
<li>
|
73
|
+
<a href="https://git-scm.com/about/staging-area">Staging Area</a>
|
74
|
+
</li>
|
75
|
+
<li>
|
76
|
+
<a href="https://git-scm.com/about/free-and-open-source">Free and Open Source</a>
|
77
|
+
</li>
|
78
|
+
<li>
|
79
|
+
<a href="https://git-scm.com/about/trademark">Trademark</a>
|
80
|
+
</li>
|
81
|
+
</ul>
|
82
|
+
</li>
|
83
|
+
<li>
|
84
|
+
<a class="active" href="https://git-scm.com/doc">Documentation</a>
|
85
|
+
<ul class="expanded">
|
86
|
+
<li>
|
87
|
+
<a href="https://git-scm.com/docs">Reference</a>
|
88
|
+
</li>
|
89
|
+
<li>
|
90
|
+
<a class="active" href="https://git-scm.com/book">Book</a>
|
91
|
+
</li>
|
92
|
+
<li>
|
93
|
+
<a href="https://git-scm.com/videos">Videos</a>
|
94
|
+
</li>
|
95
|
+
<li>
|
96
|
+
<a href="https://git-scm.com/doc/ext">External Links</a>
|
97
|
+
</li>
|
98
|
+
</ul>
|
99
|
+
</li>
|
100
|
+
<li>
|
101
|
+
<a href="https://git-scm.com/downloads">Downloads</a>
|
102
|
+
<ul class="">
|
103
|
+
<li>
|
104
|
+
<a href="https://git-scm.com/downloads/guis">GUI Clients</a>
|
105
|
+
</li>
|
106
|
+
<li>
|
107
|
+
<a href="https://git-scm.com/downloads/logos">Logos</a>
|
108
|
+
</li>
|
109
|
+
</ul>
|
110
|
+
</li>
|
111
|
+
<li>
|
112
|
+
<a href="https://git-scm.com/community">Community</a>
|
113
|
+
</li>
|
114
|
+
</ul>
|
115
|
+
<hr class="sidebar">
|
116
|
+
<p>
|
117
|
+
This book is available in
|
118
|
+
<a href="https://git-scm.com/book/en">English</a>.
|
119
|
+
</p>
|
120
|
+
<p>
|
121
|
+
Full translation available in
|
122
|
+
<table>
|
123
|
+
<tr><td><a href="https://git-scm.com/book/az">azərbaycan dili</a>,</td></tr>
|
124
|
+
<tr><td><a href="https://git-scm.com/book/bg">български език</a>,</td></tr>
|
125
|
+
<tr><td><a href="https://git-scm.com/book/de">Deutsch</a>,</td></tr>
|
126
|
+
<tr><td><a href="https://git-scm.com/book/es">Español</a>,</td></tr>
|
127
|
+
<tr><td><a href="https://git-scm.com/book/fr">Français</a>,</td></tr>
|
128
|
+
<tr><td><a href="https://git-scm.com/book/gr">Ελληνικά</a>,</td></tr>
|
129
|
+
<tr><td><a href="https://git-scm.com/book/ja">日本語</a>,</td></tr>
|
130
|
+
<tr><td><a href="https://git-scm.com/book/ko">한국어</a>,</td></tr>
|
131
|
+
<tr><td><a href="https://git-scm.com/book/nl">Nederlands</a>,</td></tr>
|
132
|
+
<tr><td><a href="https://git-scm.com/book/ru">Русский</a>,</td></tr>
|
133
|
+
<tr><td><a href="https://git-scm.com/book/sl">Slovenščina</a>,</td></tr>
|
134
|
+
<tr><td><a href="https://git-scm.com/book/tl">Tagalog</a>,</td></tr>
|
135
|
+
<tr><td><a href="https://git-scm.com/book/uk">Українська</a></td></tr>
|
136
|
+
<tr><td><a href="https://git-scm.com/book/zh">简体中文</a>,</td></tr>
|
137
|
+
</table>
|
138
|
+
</p>
|
139
|
+
<p>
|
140
|
+
Partial translations available in
|
141
|
+
<table>
|
142
|
+
<tr><td><a href="https://git-scm.com/book/cs">Čeština</a>,</td></tr>
|
143
|
+
<tr><td><a href="https://git-scm.com/book/mk">Македонски</a>,</td></tr>
|
144
|
+
<tr><td><a href="https://git-scm.com/book/pl">Polski</a>,</td></tr>
|
145
|
+
<tr><td><a href="https://git-scm.com/book/sr">Српски</a>,</td></tr>
|
146
|
+
<tr><td><a href="https://git-scm.com/book/uz">Ўзбекча</a>,</td></tr>
|
147
|
+
<tr><td><a href="https://git-scm.com/book/zh-tw">繁體中文</a>,</td></tr>
|
148
|
+
</table>
|
149
|
+
</p>
|
150
|
+
<p>
|
151
|
+
Translations started for
|
152
|
+
<table>
|
153
|
+
<tr><td><a href="https://git-scm.com/book/be">Беларуская</a>,</td></tr>
|
154
|
+
<tr><td><a href="https://git-scm.com/book/fa" dir="rtl">فارسی</a>,</td></tr>
|
155
|
+
<tr><td><a href="https://git-scm.com/book/id">Indonesian</a>,</td></tr>
|
156
|
+
<tr><td><a href="https://git-scm.com/book/it">Italiano</a>,</td></tr>
|
157
|
+
<tr><td><a href="https://git-scm.com/book/ms">Bahasa Melayu</a>,</td></tr>
|
158
|
+
<tr><td><a href="https://git-scm.com/book/pt-br">Português (Brasil)</a>,</td></tr>
|
159
|
+
<tr><td><a href="https://git-scm.com/book/pt-pt">Português (Portugal)</a>,</td></tr>
|
160
|
+
<tr><td><a href="https://git-scm.com/book/sv">Svenska</a>,</td></tr>
|
161
|
+
<tr><td><a href="https://git-scm.com/book/tr">Türkçe</a>.</td></tr>
|
162
|
+
</table>
|
163
|
+
</p>
|
164
|
+
<hr class="sidebar"/>
|
165
|
+
<p>
|
166
|
+
The source of this book is <a href="https://github.com/progit/progit2">hosted on GitHub.</a></br>
|
167
|
+
Patches, suggestions and comments are welcome.
|
168
|
+
</p>
|
169
|
+
|
170
|
+
|
171
|
+
</nav>
|
172
|
+
</aside>
|
173
|
+
|
174
|
+
<div id="content">
|
175
|
+
|
176
|
+
|
177
|
+
<div id='book-chapters'>
|
178
|
+
<a class="dropdown-trigger" id="book-chapters-trigger" data-panel-id="chapters-dropdown" href="_keyword_expansion.html#">Chapters ▾</a>
|
179
|
+
<div class='dropdown-panel' id='chapters-dropdown'>
|
180
|
+
<div class="three-column">
|
181
|
+
<div class='column-left'>
|
182
|
+
<ol class='book-toc'>
|
183
|
+
<li class='chapter'>
|
184
|
+
<h2>1. <a href="ch01-getting-started.html">Getting Started</a></h2>
|
185
|
+
<ol>
|
186
|
+
<li>
|
187
|
+
1.1
|
188
|
+
<a href="ch01-getting-started.html" >About Version Control </a>
|
189
|
+
</li>
|
190
|
+
<li>
|
191
|
+
1.2
|
192
|
+
<a href="../Getting-Started-A-Short-History-of-Git.html" >A Short History of Git </a>
|
193
|
+
</li>
|
194
|
+
<li>
|
195
|
+
1.3
|
196
|
+
<a href="what_is_git_section.html" >What is Git? </a>
|
197
|
+
</li>
|
198
|
+
<li>
|
199
|
+
1.4
|
200
|
+
<a href="../Getting-Started-The-Command-Line.html" >The Command Line </a>
|
201
|
+
</li>
|
202
|
+
<li>
|
203
|
+
1.5
|
204
|
+
<a href="../Getting-Started-Installing-Git.html" >Installing Git </a>
|
205
|
+
</li>
|
206
|
+
<li>
|
207
|
+
1.6
|
208
|
+
<a href="_editor.html" >First-Time Git Setup </a>
|
209
|
+
</li>
|
210
|
+
<li>
|
211
|
+
1.7
|
212
|
+
<a href="_git_help.html" >Getting Help </a>
|
213
|
+
</li>
|
214
|
+
<li>
|
215
|
+
1.8
|
216
|
+
<a href="../Getting-Started-Summary.html" >Summary </a>
|
217
|
+
</li>
|
218
|
+
</ol>
|
219
|
+
</li>
|
220
|
+
<li class='chapter'>
|
221
|
+
<h2>2. <a href="_git_cloning.html">Git Basics</a></h2>
|
222
|
+
<ol>
|
223
|
+
<li>
|
224
|
+
2.1
|
225
|
+
<a href="_git_cloning.html" >Getting a Git Repository </a>
|
226
|
+
</li>
|
227
|
+
<li>
|
228
|
+
2.2
|
229
|
+
<a href="_git_mv.html" >Recording Changes to the Repository </a>
|
230
|
+
</li>
|
231
|
+
<li>
|
232
|
+
2.3
|
233
|
+
<a href="_viewing_history.html" >Viewing the Commit History </a>
|
234
|
+
</li>
|
235
|
+
<li>
|
236
|
+
2.4
|
237
|
+
<a href="_unstaging.html" >Undoing Things </a>
|
238
|
+
</li>
|
239
|
+
<li>
|
240
|
+
2.5
|
241
|
+
<a href="_remote_repos.html" >Working with Remotes </a>
|
242
|
+
</li>
|
243
|
+
<li>
|
244
|
+
2.6
|
245
|
+
<a href="_annotated_tags.html" >Tagging </a>
|
246
|
+
</li>
|
247
|
+
<li>
|
248
|
+
2.7
|
249
|
+
<a href="_git_aliases.html" >Git Aliases </a>
|
250
|
+
</li>
|
251
|
+
<li>
|
252
|
+
2.8
|
253
|
+
<a href="../Git-Basics-Summary.html" >Summary </a>
|
254
|
+
</li>
|
255
|
+
</ol>
|
256
|
+
</li>
|
257
|
+
<li class='chapter'>
|
258
|
+
<h2>3. <a href="_switching_branches.html">Git Branching</a></h2>
|
259
|
+
<ol>
|
260
|
+
<li>
|
261
|
+
3.1
|
262
|
+
<a href="_switching_branches.html" >Branches in a Nutshell </a>
|
263
|
+
</li>
|
264
|
+
<li>
|
265
|
+
3.2
|
266
|
+
<a href="_basic_branching.html" >Basic Branching and Merging </a>
|
267
|
+
</li>
|
268
|
+
<li>
|
269
|
+
3.3
|
270
|
+
<a href="_branch_management.html" >Branch Management </a>
|
271
|
+
</li>
|
272
|
+
<li>
|
273
|
+
3.4
|
274
|
+
<a href="_topic_branch.html" >Branching Workflows </a>
|
275
|
+
</li>
|
276
|
+
<li>
|
277
|
+
3.5
|
278
|
+
<a href="_delete_branches.html" >Remote Branches </a>
|
279
|
+
</li>
|
280
|
+
<li>
|
281
|
+
3.6
|
282
|
+
<a href="_rebase_rebase.html" >Rebasing </a>
|
283
|
+
</li>
|
284
|
+
<li>
|
285
|
+
3.7
|
286
|
+
<a href="../Git-Branching-Summary.html" >Summary </a>
|
287
|
+
</li>
|
288
|
+
</ol>
|
289
|
+
</li>
|
290
|
+
<li class='chapter'>
|
291
|
+
<h2>4. <a href="../Git-on-the-Server-The-Protocols.html">Git on the Server</a></h2>
|
292
|
+
<ol>
|
293
|
+
<li>
|
294
|
+
4.1
|
295
|
+
<a href="../Git-on-the-Server-The-Protocols.html" >The Protocols </a>
|
296
|
+
</li>
|
297
|
+
<li>
|
298
|
+
4.2
|
299
|
+
<a href="_bare_repo.html" >Getting Git on a Server </a>
|
300
|
+
</li>
|
301
|
+
<li>
|
302
|
+
4.3
|
303
|
+
<a href="_generate_ssh_key.html" >Generating Your SSH Public Key </a>
|
304
|
+
</li>
|
305
|
+
<li>
|
306
|
+
4.4
|
307
|
+
<a href="_setting_up_server.html" >Setting Up the Server </a>
|
308
|
+
</li>
|
309
|
+
<li>
|
310
|
+
4.5
|
311
|
+
<a href="../Git-on-the-Server-Git-Daemon.html" >Git Daemon </a>
|
312
|
+
</li>
|
313
|
+
<li>
|
314
|
+
4.6
|
315
|
+
<a href="../Git-on-the-Server-Smart-HTTP.html" >Smart HTTP </a>
|
316
|
+
</li>
|
317
|
+
<li>
|
318
|
+
4.7
|
319
|
+
<a href="../Git-on-the-Server-GitWeb.html" >GitWeb </a>
|
320
|
+
</li>
|
321
|
+
<li>
|
322
|
+
4.8
|
323
|
+
<a href="_gitlab_groups_section.html" >GitLab </a>
|
324
|
+
</li>
|
325
|
+
<li>
|
326
|
+
4.9
|
327
|
+
<a href="../Git-on-the-Server-Third-Party-Hosted-Options.html" >Third Party Hosted Options </a>
|
328
|
+
</li>
|
329
|
+
<li>
|
330
|
+
4.10
|
331
|
+
<a href="../Git-on-the-Server-Summary.html" >Summary </a>
|
332
|
+
</li>
|
333
|
+
</ol>
|
334
|
+
</li>
|
335
|
+
<li class='chapter'>
|
336
|
+
<h2>5. <a href="_integration_manager.html">Distributed Git</a></h2>
|
337
|
+
<ol>
|
338
|
+
<li>
|
339
|
+
5.1
|
340
|
+
<a href="_integration_manager.html" >Distributed Workflows </a>
|
341
|
+
</li>
|
342
|
+
<li>
|
343
|
+
5.2
|
344
|
+
<a href="_project_over_email.html" >Contributing to a Project </a>
|
345
|
+
</li>
|
346
|
+
<li>
|
347
|
+
5.3
|
348
|
+
<a href="_git_am.html" >Maintaining a Project </a>
|
349
|
+
</li>
|
350
|
+
<li>
|
351
|
+
5.4
|
352
|
+
<a href="../Distributed-Git-Summary.html" >Summary </a>
|
353
|
+
</li>
|
354
|
+
</ol>
|
355
|
+
</li>
|
356
|
+
</ol>
|
357
|
+
|
358
|
+
</div>
|
359
|
+
<div class='column-middle'>
|
360
|
+
<ol class='book-toc'>
|
361
|
+
<li class='chapter'>
|
362
|
+
<h2>6. <a href="_personal_avatar.html">GitHub</a></h2>
|
363
|
+
<ol>
|
364
|
+
<li>
|
365
|
+
6.1
|
366
|
+
<a href="_personal_avatar.html" >Account Setup and Configuration </a>
|
367
|
+
</li>
|
368
|
+
<li>
|
369
|
+
6.2
|
370
|
+
<a href="_fetch_and_push_on_different_repositories.html" >Contributing to a Project </a>
|
371
|
+
</li>
|
372
|
+
<li>
|
373
|
+
6.3
|
374
|
+
<a href="_email_notifications.html" >Maintaining a Project </a>
|
375
|
+
</li>
|
376
|
+
<li>
|
377
|
+
6.4
|
378
|
+
<a href="_team_page.html" >Managing an organization </a>
|
379
|
+
</li>
|
380
|
+
<li>
|
381
|
+
6.5
|
382
|
+
<a href="_commit_status.html" >Scripting GitHub </a>
|
383
|
+
</li>
|
384
|
+
<li>
|
385
|
+
6.6
|
386
|
+
<a href="../GitHub-Summary.html" >Summary </a>
|
387
|
+
</li>
|
388
|
+
</ol>
|
389
|
+
</li>
|
390
|
+
<li class='chapter'>
|
391
|
+
<h2>7. <a href="_git_reflog.html">Git Tools</a></h2>
|
392
|
+
<ol>
|
393
|
+
<li>
|
394
|
+
7.1
|
395
|
+
<a href="_git_reflog.html" >Revision Selection </a>
|
396
|
+
</li>
|
397
|
+
<li>
|
398
|
+
7.2
|
399
|
+
<a href="_interactive_staging.html" >Interactive Staging </a>
|
400
|
+
</li>
|
401
|
+
<li>
|
402
|
+
7.3
|
403
|
+
<a href="_git_clean.html" >Stashing and Cleaning </a>
|
404
|
+
</li>
|
405
|
+
<li>
|
406
|
+
7.4
|
407
|
+
<a href="_signing_commits.html" >Signing Your Work </a>
|
408
|
+
</li>
|
409
|
+
<li>
|
410
|
+
7.5
|
411
|
+
<a href="_git_grep.html" >Searching </a>
|
412
|
+
</li>
|
413
|
+
<li>
|
414
|
+
7.6
|
415
|
+
<a href="_removing_file_every_commit.html" >Rewriting History </a>
|
416
|
+
</li>
|
417
|
+
<li>
|
418
|
+
7.7
|
419
|
+
<a href="_the_index.html" >Reset Demystified </a>
|
420
|
+
</li>
|
421
|
+
<li>
|
422
|
+
7.8
|
423
|
+
<a href="_reverse_commit.html" >Advanced Merging </a>
|
424
|
+
</li>
|
425
|
+
<li>
|
426
|
+
7.9
|
427
|
+
<a href="ref_rerere.html" >Rerere </a>
|
428
|
+
</li>
|
429
|
+
<li>
|
430
|
+
7.10
|
431
|
+
<a href="_file_annotation.html" >Debugging with Git </a>
|
432
|
+
</li>
|
433
|
+
<li>
|
434
|
+
7.11
|
435
|
+
<a href="_publishing_submodules.html" >Submodules </a>
|
436
|
+
</li>
|
437
|
+
<li>
|
438
|
+
7.12
|
439
|
+
<a href="_bundling.html" >Bundling </a>
|
440
|
+
</li>
|
441
|
+
<li>
|
442
|
+
7.13
|
443
|
+
<a href="_replace.html" >Replace </a>
|
444
|
+
</li>
|
445
|
+
<li>
|
446
|
+
7.14
|
447
|
+
<a href="_credential_caching.html" >Credential Storage </a>
|
448
|
+
</li>
|
449
|
+
<li>
|
450
|
+
7.15
|
451
|
+
<a href="../Git-Tools-Summary.html" >Summary </a>
|
452
|
+
</li>
|
453
|
+
</ol>
|
454
|
+
</li>
|
455
|
+
<li class='chapter'>
|
456
|
+
<h2>8. <a href="_external_merge_tools.html">Customizing Git</a></h2>
|
457
|
+
<ol>
|
458
|
+
<li>
|
459
|
+
8.1
|
460
|
+
<a href="_external_merge_tools.html" >Git Configuration </a>
|
461
|
+
</li>
|
462
|
+
<li>
|
463
|
+
8.2
|
464
|
+
<a href="_keyword_expansion.html" class=active>Git Attributes </a>
|
465
|
+
</li>
|
466
|
+
<li>
|
467
|
+
8.3
|
468
|
+
<a href="_email_hooks.html" >Git Hooks </a>
|
469
|
+
</li>
|
470
|
+
<li>
|
471
|
+
8.4
|
472
|
+
<a href="_enforcing_commit_message_format.html" >An Example Git-Enforced Policy </a>
|
473
|
+
</li>
|
474
|
+
<li>
|
475
|
+
8.5
|
476
|
+
<a href="../Customizing-Git-Summary.html" >Summary </a>
|
477
|
+
</li>
|
478
|
+
</ol>
|
479
|
+
</li>
|
480
|
+
<li class='chapter'>
|
481
|
+
<h2>9. <a href="_git_svn.html">Git and Other Systems</a></h2>
|
482
|
+
<ol>
|
483
|
+
<li>
|
484
|
+
9.1
|
485
|
+
<a href="_git_svn.html" >Git as a Client </a>
|
486
|
+
</li>
|
487
|
+
<li>
|
488
|
+
9.2
|
489
|
+
<a href="_git_p4.html" >Migrating to Git </a>
|
490
|
+
</li>
|
491
|
+
<li>
|
492
|
+
9.3
|
493
|
+
<a href="../Git-and-Other-Systems-Summary.html" >Summary </a>
|
494
|
+
</li>
|
495
|
+
</ol>
|
496
|
+
</li>
|
497
|
+
<li class='chapter'>
|
498
|
+
<h2>10. <a href="_plumbing_porcelain.html">Git Internals</a></h2>
|
499
|
+
<ol>
|
500
|
+
<li>
|
501
|
+
10.1
|
502
|
+
<a href="_plumbing_porcelain.html" >Plumbing and Porcelain </a>
|
503
|
+
</li>
|
504
|
+
<li>
|
505
|
+
10.2
|
506
|
+
<a href="_git_commit_objects.html" >Git Objects </a>
|
507
|
+
</li>
|
508
|
+
<li>
|
509
|
+
10.3
|
510
|
+
<a href="ref_the_ref.html" >Git References </a>
|
511
|
+
</li>
|
512
|
+
<li>
|
513
|
+
10.4
|
514
|
+
<a href="../Git-Internals-Packfiles.html" >Packfiles </a>
|
515
|
+
</li>
|
516
|
+
<li>
|
517
|
+
10.5
|
518
|
+
<a href="_pushing_refspecs.html" >The Refspec </a>
|
519
|
+
</li>
|
520
|
+
<li>
|
521
|
+
10.6
|
522
|
+
<a href="../Git-Internals-Transfer-Protocols.html" >Transfer Protocols </a>
|
523
|
+
</li>
|
524
|
+
<li>
|
525
|
+
10.7
|
526
|
+
<a href="_git_gc.html" >Maintenance and Data Recovery </a>
|
527
|
+
</li>
|
528
|
+
<li>
|
529
|
+
10.8
|
530
|
+
<a href="../Git-Internals-Environment-Variables.html" >Environment Variables </a>
|
531
|
+
</li>
|
532
|
+
<li>
|
533
|
+
10.9
|
534
|
+
<a href="../Git-Internals-Summary.html" >Summary </a>
|
535
|
+
</li>
|
536
|
+
</ol>
|
537
|
+
</li>
|
538
|
+
</ol>
|
539
|
+
|
540
|
+
</div>
|
541
|
+
<div class='column-right'>
|
542
|
+
<ol class='book-toc'>
|
543
|
+
<li class='chapter'>
|
544
|
+
<h2>A1. <a href="../Appendix-A:-Git-in-Other-Environments-Graphical-Interfaces.html">Appendix A: Git in Other Environments</a></h2>
|
545
|
+
<ol>
|
546
|
+
<li>
|
547
|
+
A1.1
|
548
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Graphical-Interfaces.html" >Graphical Interfaces </a>
|
549
|
+
</li>
|
550
|
+
<li>
|
551
|
+
A1.2
|
552
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-Visual-Studio.html" >Git in Visual Studio </a>
|
553
|
+
</li>
|
554
|
+
<li>
|
555
|
+
A1.3
|
556
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-Visual-Studio-Code.html" >Git in Visual Studio Code </a>
|
557
|
+
</li>
|
558
|
+
<li>
|
559
|
+
A1.4
|
560
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-IntelliJ-%252F-PyCharm-%252F-WebStorm-%252F-PhpStorm-%252F-RubyMine.html" >Git in IntelliJ / PyCharm / WebStorm / PhpStorm / RubyMine </a>
|
561
|
+
</li>
|
562
|
+
<li>
|
563
|
+
A1.5
|
564
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-Sublime-Text.html" >Git in Sublime Text </a>
|
565
|
+
</li>
|
566
|
+
<li>
|
567
|
+
A1.6
|
568
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-Bash.html" >Git in Bash </a>
|
569
|
+
</li>
|
570
|
+
<li>
|
571
|
+
A1.7
|
572
|
+
<a href="oh_my_zsh_git.html" >Git in Zsh </a>
|
573
|
+
</li>
|
574
|
+
<li>
|
575
|
+
A1.8
|
576
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Git-in-PowerShell.html" >Git in PowerShell </a>
|
577
|
+
</li>
|
578
|
+
<li>
|
579
|
+
A1.9
|
580
|
+
<a href="../Appendix-A:-Git-in-Other-Environments-Summary.html" >Summary </a>
|
581
|
+
</li>
|
582
|
+
</ol>
|
583
|
+
</li>
|
584
|
+
<li class='chapter'>
|
585
|
+
<h2>A2. <a href="../Appendix-B:-Embedding-Git-in-your-Applications-Command-line-Git.html">Appendix B: Embedding Git in your Applications</a></h2>
|
586
|
+
<ol>
|
587
|
+
<li>
|
588
|
+
A2.1
|
589
|
+
<a href="../Appendix-B:-Embedding-Git-in-your-Applications-Command-line-Git.html" >Command-line Git </a>
|
590
|
+
</li>
|
591
|
+
<li>
|
592
|
+
A2.2
|
593
|
+
<a href="_libgit2_bindings.html" >Libgit2 </a>
|
594
|
+
</li>
|
595
|
+
<li>
|
596
|
+
A2.3
|
597
|
+
<a href="../Appendix-B:-Embedding-Git-in-your-Applications-JGit.html" >JGit </a>
|
598
|
+
</li>
|
599
|
+
<li>
|
600
|
+
A2.4
|
601
|
+
<a href="../Appendix-B:-Embedding-Git-in-your-Applications-go-git.html" >go-git </a>
|
602
|
+
</li>
|
603
|
+
<li>
|
604
|
+
A2.5
|
605
|
+
<a href="../Appendix-B:-Embedding-Git-in-your-Applications-Dulwich.html" >Dulwich </a>
|
606
|
+
</li>
|
607
|
+
</ol>
|
608
|
+
</li>
|
609
|
+
<li class='chapter'>
|
610
|
+
<h2>A3. <a href="ch_core_editor.html">Appendix C: Git Commands</a></h2>
|
611
|
+
<ol>
|
612
|
+
<li>
|
613
|
+
A3.1
|
614
|
+
<a href="ch_core_editor.html" >Setup and Config </a>
|
615
|
+
</li>
|
616
|
+
<li>
|
617
|
+
A3.2
|
618
|
+
<a href="../Appendix-C:-Git-Commands-Getting-and-Creating-Projects.html" >Getting and Creating Projects </a>
|
619
|
+
</li>
|
620
|
+
<li>
|
621
|
+
A3.3
|
622
|
+
<a href="../Appendix-C:-Git-Commands-Basic-Snapshotting.html" >Basic Snapshotting </a>
|
623
|
+
</li>
|
624
|
+
<li>
|
625
|
+
A3.4
|
626
|
+
<a href="../Appendix-C:-Git-Commands-Branching-and-Merging.html" >Branching and Merging </a>
|
627
|
+
</li>
|
628
|
+
<li>
|
629
|
+
A3.5
|
630
|
+
<a href="../Appendix-C:-Git-Commands-Sharing-and-Updating-Projects.html" >Sharing and Updating Projects </a>
|
631
|
+
</li>
|
632
|
+
<li>
|
633
|
+
A3.6
|
634
|
+
<a href="../Appendix-C:-Git-Commands-Inspection-and-Comparison.html" >Inspection and Comparison </a>
|
635
|
+
</li>
|
636
|
+
<li>
|
637
|
+
A3.7
|
638
|
+
<a href="../Appendix-C:-Git-Commands-Debugging.html" >Debugging </a>
|
639
|
+
</li>
|
640
|
+
<li>
|
641
|
+
A3.8
|
642
|
+
<a href="../Appendix-C:-Git-Commands-Patching.html" >Patching </a>
|
643
|
+
</li>
|
644
|
+
<li>
|
645
|
+
A3.9
|
646
|
+
<a href="../Appendix-C:-Git-Commands-Email.html" >Email </a>
|
647
|
+
</li>
|
648
|
+
<li>
|
649
|
+
A3.10
|
650
|
+
<a href="../Appendix-C:-Git-Commands-External-Systems.html" >External Systems </a>
|
651
|
+
</li>
|
652
|
+
<li>
|
653
|
+
A3.11
|
654
|
+
<a href="../Appendix-C:-Git-Commands-Administration.html" >Administration </a>
|
655
|
+
</li>
|
656
|
+
<li>
|
657
|
+
A3.12
|
658
|
+
<a href="../Appendix-C:-Git-Commands-Plumbing-Commands.html" >Plumbing Commands </a>
|
659
|
+
</li>
|
660
|
+
</ol>
|
661
|
+
</li>
|
662
|
+
</ol>
|
663
|
+
|
664
|
+
</div>
|
665
|
+
</div>
|
666
|
+
</div>
|
667
|
+
|
668
|
+
<span class="light" id="edition">
|
669
|
+
2nd Edition
|
670
|
+
</span>
|
671
|
+
</div>
|
672
|
+
|
673
|
+
<div id='main' class="book edition2">
|
674
|
+
<h1>8.2 Customizing Git - Git Attributes</h1>
|
675
|
+
<div>
|
676
|
+
<h2 id="_git_attributes">Git Attributes</h2>
|
677
|
+
<div class="paragraph">
|
678
|
+
<p>
|
679
|
+
Some of these settings can also be specified for a path, so that Git applies those settings only for a subdirectory or subset of files.
|
680
|
+
These path-specific settings are called Git attributes and are set either in a <code>.gitattributes</code> file in one of your directories (normally the root of your project) or in the <code>.git/info/attributes</code> file if you don’t want the attributes file committed with your project.</p>
|
681
|
+
</div>
|
682
|
+
<div class="paragraph">
|
683
|
+
<p>Using attributes, you can do things like specify separate merge strategies for individual files or directories in your project, tell Git how to diff non-text files, or have Git filter content before you check it into or out of Git.
|
684
|
+
In this section, you’ll learn about some of the attributes you can set on your paths in your Git project and see a few examples of using this feature in practice.</p>
|
685
|
+
</div>
|
686
|
+
<div class="sect3">
|
687
|
+
<h3 id="_binary_files">Binary Files</h3>
|
688
|
+
<div class="paragraph">
|
689
|
+
<p>
|
690
|
+
One cool trick for which you can use Git attributes is telling Git which files are binary (in cases it otherwise may not be able to figure out) and giving Git special instructions about how to handle those files.
|
691
|
+
For instance, some text files may be machine generated and not diffable, whereas some binary files can be diffed.
|
692
|
+
You’ll see how to tell Git which is which.</p>
|
693
|
+
</div>
|
694
|
+
<div class="sect4">
|
695
|
+
<h4 id="_identifying_binary_files">Identifying Binary Files</h4>
|
696
|
+
<div class="paragraph">
|
697
|
+
<p>Some files look like text files but for all intents and purposes are to be treated as binary data.
|
698
|
+
For instance, Xcode projects on macOS contain a file that ends in <code>.pbxproj</code>, which is basically a JSON (plain-text JavaScript data format) dataset written out to disk by the IDE, which records your build settings and so on.
|
699
|
+
Although it’s technically a text file (because it’s all UTF-8), you don’t want to treat it as such because it’s really a lightweight database – you can’t merge the contents if two people change it, and diffs generally aren’t helpful.
|
700
|
+
The file is meant to be consumed by a machine.
|
701
|
+
In essence, you want to treat it like a binary file.</p>
|
702
|
+
</div>
|
703
|
+
<div class="paragraph">
|
704
|
+
<p>To tell Git to treat all <code>pbxproj</code> files as binary data, add the following line to your <code>.gitattributes</code> file:</p>
|
705
|
+
</div>
|
706
|
+
<div class="listingblock">
|
707
|
+
<div class="content">
|
708
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">*.pbxproj binary</code></pre>
|
709
|
+
</div>
|
710
|
+
</div>
|
711
|
+
<div class="paragraph">
|
712
|
+
<p>Now, Git won’t try to convert or fix CRLF issues; nor will it try to compute or print a diff for changes in this file when you run <code>git show</code> or <code>git diff</code> on your project.</p>
|
713
|
+
</div>
|
714
|
+
</div>
|
715
|
+
<div class="sect4">
|
716
|
+
<h4 id="_diffing_binary_files">Diffing Binary Files</h4>
|
717
|
+
<div class="paragraph">
|
718
|
+
<p>You can also use the Git attributes functionality to effectively diff binary files.
|
719
|
+
You do this by telling Git how to convert your binary data to a text format that can be compared via the normal diff.</p>
|
720
|
+
</div>
|
721
|
+
<div class="paragraph">
|
722
|
+
<p>First, you’ll use this technique to solve one of the most annoying problems known to humanity: version-controlling Microsoft Word documents.
|
723
|
+
Everyone knows that Word is the most horrific editor around, but oddly, everyone still uses it.
|
724
|
+
If you want to version-control Word documents, you can stick them in a Git repository and commit every once in a while; but what good does that do?
|
725
|
+
If you run <code>git diff</code> normally, you only see something like this:</p>
|
726
|
+
</div>
|
727
|
+
<div class="listingblock">
|
728
|
+
<div class="content">
|
729
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git diff
|
730
|
+
diff --git a/chapter1.docx b/chapter1.docx
|
731
|
+
index 88839c4..4afcb7c 100644
|
732
|
+
Binary files a/chapter1.docx and b/chapter1.docx differ</code></pre>
|
733
|
+
</div>
|
734
|
+
</div>
|
735
|
+
<div class="paragraph">
|
736
|
+
<p>You can’t directly compare two versions unless you check them out and scan them manually, right?
|
737
|
+
It turns out you can do this fairly well using Git attributes.
|
738
|
+
Put the following line in your <code>.gitattributes</code> file:</p>
|
739
|
+
</div>
|
740
|
+
<div class="listingblock">
|
741
|
+
<div class="content">
|
742
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">*.docx diff=word</code></pre>
|
743
|
+
</div>
|
744
|
+
</div>
|
745
|
+
<div class="paragraph">
|
746
|
+
<p>This tells Git that any file that matches this pattern (<code>.docx</code>) should use the “word” filter when you try to view a diff that contains changes.
|
747
|
+
What is the “word” filter?
|
748
|
+
You have to set it up.
|
749
|
+
Here you’ll configure Git to use the <code>docx2txt</code> program to convert Word documents into readable text files, which it will then diff properly.</p>
|
750
|
+
</div>
|
751
|
+
<div class="paragraph">
|
752
|
+
<p>First, you’ll need to install <code>docx2txt</code>; you can download it from <a href="https://sourceforge.net/projects/docx2txt" class="bare">https://sourceforge.net/projects/docx2txt</a>.
|
753
|
+
Follow the instructions in the <code>INSTALL</code> file to put it somewhere your shell can find it.
|
754
|
+
Next, you’ll write a wrapper script to convert output to the format Git expects.
|
755
|
+
Create a file that’s somewhere in your path called <code>docx2txt</code>, and add these contents:</p>
|
756
|
+
</div>
|
757
|
+
<div class="listingblock">
|
758
|
+
<div class="content">
|
759
|
+
<pre class="highlight"><code class="language-console" data-lang="console">#!/bin/bash
|
760
|
+
docx2txt.pl "$1" -</code></pre>
|
761
|
+
</div>
|
762
|
+
</div>
|
763
|
+
<div class="paragraph">
|
764
|
+
<p>Don’t forget to <code>chmod a+x</code> that file.
|
765
|
+
Finally, you can configure Git to use this script:</p>
|
766
|
+
</div>
|
767
|
+
<div class="listingblock">
|
768
|
+
<div class="content">
|
769
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git config diff.word.textconv docx2txt</code></pre>
|
770
|
+
</div>
|
771
|
+
</div>
|
772
|
+
<div class="paragraph">
|
773
|
+
<p>Now Git knows that if it tries to do a diff between two snapshots, and any of the files end in <code>.docx</code>, it should run those files through the “word” filter, which is defined as the <code>docx2txt</code> program.
|
774
|
+
This effectively makes nice text-based versions of your Word files before attempting to diff them.</p>
|
775
|
+
</div>
|
776
|
+
<div class="paragraph">
|
777
|
+
<p>Here’s an example: Chapter 1 of this book was converted to Word format and committed in a Git repository.
|
778
|
+
Then a new paragraph was added.
|
779
|
+
Here’s what <code>git diff</code> shows:</p>
|
780
|
+
</div>
|
781
|
+
<div class="listingblock">
|
782
|
+
<div class="content">
|
783
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git diff
|
784
|
+
diff --git a/chapter1.docx b/chapter1.docx
|
785
|
+
index 0b013ca..ba25db5 100644
|
786
|
+
--- a/chapter1.docx
|
787
|
+
+++ b/chapter1.docx
|
788
|
+
@@ -2,6 +2,7 @@
|
789
|
+
This chapter will be about getting started with Git. We will begin at the beginning by explaining some background on version control tools, then move on to how to get Git running on your system and finally how to get it setup to start working with. At the end of this chapter you should understand why Git is around, why you should use it and you should be all setup to do so.
|
790
|
+
1.1. About Version Control
|
791
|
+
What is "version control", and why should you care? Version control is a system that records changes to a file or set of files over time so that you can recall specific versions later. For the examples in this book you will use software source code as the files being version controlled, though in reality you can do this with nearly any type of file on a computer.
|
792
|
+
+Testing: 1, 2, 3.
|
793
|
+
If you are a graphic or web designer and want to keep every version of an image or layout (which you would most certainly want to), a Version Control System (VCS) is a very wise thing to use. It allows you to revert files back to a previous state, revert the entire project back to a previous state, compare changes over time, see who last modified something that might be causing a problem, who introduced an issue and when, and more. Using a VCS also generally means that if you screw things up or lose files, you can easily recover. In addition, you get all this for very little overhead.
|
794
|
+
1.1.1. Local Version Control Systems
|
795
|
+
Many people's version-control method of choice is to copy files into another directory (perhaps a time-stamped directory, if they're clever). This approach is very common because it is so simple, but it is also incredibly error prone. It is easy to forget which directory you're in and accidentally write to the wrong file or copy over files you don't mean to.</code></pre>
|
796
|
+
</div>
|
797
|
+
</div>
|
798
|
+
<div class="paragraph">
|
799
|
+
<p>Git successfully and succinctly tells us that we added the string “Testing: 1, 2, 3.”, which is correct.
|
800
|
+
It’s not perfect – formatting changes wouldn’t show up here – but it certainly works.</p>
|
801
|
+
</div>
|
802
|
+
<div class="paragraph">
|
803
|
+
<p>Another interesting problem you can solve this way involves diffing image files.
|
804
|
+
One way to do this is to run image files through a filter that extracts their EXIF information – metadata that is recorded with most image formats.
|
805
|
+
If you download and install the <code>exiftool</code> program, you can use it to convert your images into text about the metadata, so at least the diff will show you a textual representation of any changes that happened.
|
806
|
+
Put the following line in your <code>.gitattributes</code> file:</p>
|
807
|
+
</div>
|
808
|
+
<div class="listingblock">
|
809
|
+
<div class="content">
|
810
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">*.png diff=exif</code></pre>
|
811
|
+
</div>
|
812
|
+
</div>
|
813
|
+
<div class="paragraph">
|
814
|
+
<p>Configure Git to use this tool:</p>
|
815
|
+
</div>
|
816
|
+
<div class="listingblock">
|
817
|
+
<div class="content">
|
818
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git config diff.exif.textconv exiftool</code></pre>
|
819
|
+
</div>
|
820
|
+
</div>
|
821
|
+
<div class="paragraph">
|
822
|
+
<p>If you replace an image in your project and run <code>git diff</code>, you see something like this:</p>
|
823
|
+
</div>
|
824
|
+
<div class="listingblock">
|
825
|
+
<div class="content">
|
826
|
+
<pre class="highlight"><code class="language-diff" data-lang="diff">diff --git a/image.png b/image.png
|
827
|
+
index 88839c4..4afcb7c 100644
|
828
|
+
--- a/image.png
|
829
|
+
+++ b/image.png
|
830
|
+
@@ -1,12 +1,12 @@
|
831
|
+
ExifTool Version Number : 7.74
|
832
|
+
-File Size : 70 kB
|
833
|
+
-File Modification Date/Time : 2009:04:21 07:02:45-07:00
|
834
|
+
+File Size : 94 kB
|
835
|
+
+File Modification Date/Time : 2009:04:21 07:02:43-07:00
|
836
|
+
File Type : PNG
|
837
|
+
MIME Type : image/png
|
838
|
+
-Image Width : 1058
|
839
|
+
-Image Height : 889
|
840
|
+
+Image Width : 1056
|
841
|
+
+Image Height : 827
|
842
|
+
Bit Depth : 8
|
843
|
+
Color Type : RGB with Alpha</code></pre>
|
844
|
+
</div>
|
845
|
+
</div>
|
846
|
+
<div class="paragraph">
|
847
|
+
<p>You can easily see that the file size and image dimensions have both changed.</p>
|
848
|
+
</div>
|
849
|
+
</div>
|
850
|
+
</div>
|
851
|
+
<div class="sect3">
|
852
|
+
<h3 id="_keyword_expansion">Keyword Expansion</h3>
|
853
|
+
<div class="paragraph">
|
854
|
+
<p>
|
855
|
+
SVN- or CVS-style keyword expansion is often requested by developers used to those systems.
|
856
|
+
The main problem with this in Git is that you can’t modify a file with information about the commit after you’ve committed, because Git checksums the file first.
|
857
|
+
However, you can inject text into a file when it’s checked out and remove it again before it’s added to a commit.
|
858
|
+
Git attributes offers you two ways to do this.</p>
|
859
|
+
</div>
|
860
|
+
<div class="paragraph">
|
861
|
+
<p>First, you can inject the SHA-1 checksum of a blob into an <code>$Id$</code> field in the file automatically.
|
862
|
+
If you set this attribute on a file or set of files, then the next time you check out that branch, Git will replace that field with the SHA-1 of the blob.
|
863
|
+
It’s important to notice that it isn’t the SHA-1 of the commit, but of the blob itself.
|
864
|
+
Put the following line in your <code>.gitattributes</code> file:</p>
|
865
|
+
</div>
|
866
|
+
<div class="listingblock">
|
867
|
+
<div class="content">
|
868
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">*.txt ident</code></pre>
|
869
|
+
</div>
|
870
|
+
</div>
|
871
|
+
<div class="paragraph">
|
872
|
+
<p>Add an <code>$Id$</code> reference to a test file:</p>
|
873
|
+
</div>
|
874
|
+
<div class="listingblock">
|
875
|
+
<div class="content">
|
876
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ echo '$Id$' > test.txt</code></pre>
|
877
|
+
</div>
|
878
|
+
</div>
|
879
|
+
<div class="paragraph">
|
880
|
+
<p>The next time you check out this file, Git injects the SHA-1 of the blob:</p>
|
881
|
+
</div>
|
882
|
+
<div class="listingblock">
|
883
|
+
<div class="content">
|
884
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ rm test.txt
|
885
|
+
$ git checkout -- test.txt
|
886
|
+
$ cat test.txt
|
887
|
+
$Id: 42812b7653c7b88933f8a9d6cad0ca16714b9bb3 $</code></pre>
|
888
|
+
</div>
|
889
|
+
</div>
|
890
|
+
<div class="paragraph">
|
891
|
+
<p>However, that result is of limited use.
|
892
|
+
If you’ve used keyword substitution in CVS or Subversion, you can include a datestamp – the SHA-1 isn’t all that helpful, because it’s fairly random and you can’t tell if one SHA-1 is older or newer than another just by looking at them.</p>
|
893
|
+
</div>
|
894
|
+
<div class="paragraph">
|
895
|
+
<p>It turns out that you can write your own filters for doing substitutions in files on commit/checkout.
|
896
|
+
These are called “clean” and “smudge” filters.
|
897
|
+
In the <code>.gitattributes</code> file, you can set a filter for particular paths and then set up scripts that will process files just before they’re checked out (“smudge”, see <a href="filters_a.html">The “smudge” filter is run on checkout</a>) and just before they’re staged (“clean”, see <a href="filters_b.html">The “clean” filter is run when files are staged</a>).
|
898
|
+
These filters can be set to do all sorts of fun things.</p>
|
899
|
+
</div>
|
900
|
+
<div id="filters_a" class="imageblock">
|
901
|
+
<div class="content">
|
902
|
+
<img src="../images/smudge.png" alt="The “smudge” filter is run on checkout">
|
903
|
+
</div>
|
904
|
+
<div class="title">Figure 143. The “smudge” filter is run on checkout</div>
|
905
|
+
</div>
|
906
|
+
<div id="filters_b" class="imageblock">
|
907
|
+
<div class="content">
|
908
|
+
<img src="../images/clean.png" alt="The “clean” filter is run when files are staged">
|
909
|
+
</div>
|
910
|
+
<div class="title">Figure 144. The “clean” filter is run when files are staged</div>
|
911
|
+
</div>
|
912
|
+
<div class="paragraph">
|
913
|
+
<p>The original commit message for this feature gives a simple example of running all your C source code through the <code>indent</code> program before committing.
|
914
|
+
You can set it up by setting the filter attribute in your <code>.gitattributes</code> file to filter <code>\*.c</code> files with the “indent” filter:</p>
|
915
|
+
</div>
|
916
|
+
<div class="listingblock">
|
917
|
+
<div class="content">
|
918
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">*.c filter=indent</code></pre>
|
919
|
+
</div>
|
920
|
+
</div>
|
921
|
+
<div class="paragraph">
|
922
|
+
<p>Then, tell Git what the “indent” filter does on smudge and clean:</p>
|
923
|
+
</div>
|
924
|
+
<div class="listingblock">
|
925
|
+
<div class="content">
|
926
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git config --global filter.indent.clean indent
|
927
|
+
$ git config --global filter.indent.smudge cat</code></pre>
|
928
|
+
</div>
|
929
|
+
</div>
|
930
|
+
<div class="paragraph">
|
931
|
+
<p>In this case, when you commit files that match <code>*.c</code>, Git will run them through the indent program before it stages them and then run them through the <code>cat</code> program before it checks them back out onto disk.
|
932
|
+
The <code>cat</code> program does essentially nothing: it spits out the same data that it comes in.
|
933
|
+
This combination effectively filters all C source code files through <code>indent</code> before committing.</p>
|
934
|
+
</div>
|
935
|
+
<div class="paragraph">
|
936
|
+
<p>Another interesting example gets <code>$Date$</code> keyword expansion, RCS style.
|
937
|
+
To do this properly, you need a small script that takes a filename, figures out the last commit date for this project, and inserts the date into the file.
|
938
|
+
Here is a small Ruby script that does that:</p>
|
939
|
+
</div>
|
940
|
+
<div class="listingblock">
|
941
|
+
<div class="content">
|
942
|
+
<pre class="highlight"><code class="language-ruby" data-lang="ruby">#! /usr/bin/env ruby
|
943
|
+
data = STDIN.read
|
944
|
+
last_date = `git log --pretty=format:"%ad" -1`
|
945
|
+
puts data.gsub('$Date$', '$Date: ' + last_date.to_s + '$')</code></pre>
|
946
|
+
</div>
|
947
|
+
</div>
|
948
|
+
<div class="paragraph">
|
949
|
+
<p>All the script does is get the latest commit date from the <code>git log</code> command, stick that into any <code>$Date$</code> strings it sees in stdin, and print the results – it should be simple to do in whatever language you’re most comfortable in.
|
950
|
+
You can name this file <code>expand_date</code> and put it in your path.
|
951
|
+
Now, you need to set up a filter in Git (call it <code>dater</code>) and tell it to use your <code>expand_date</code> filter to smudge the files on checkout.
|
952
|
+
You’ll use a Perl expression to clean that up on commit:</p>
|
953
|
+
</div>
|
954
|
+
<div class="listingblock">
|
955
|
+
<div class="content">
|
956
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git config filter.dater.smudge expand_date
|
957
|
+
$ git config filter.dater.clean 'perl -pe "s/\\\$Date[^\\\$]*\\\$/\\\$Date\\\$/"'</code></pre>
|
958
|
+
</div>
|
959
|
+
</div>
|
960
|
+
<div class="paragraph">
|
961
|
+
<p>This Perl snippet strips out anything it sees in a <code>$Date$</code> string, to get back to where you started.
|
962
|
+
Now that your filter is ready, you can test it by setting up a Git attribute for that file that engages the new filter and creating a file with your <code>$Date$</code> keyword:</p>
|
963
|
+
</div>
|
964
|
+
<div class="listingblock">
|
965
|
+
<div class="content">
|
966
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">date*.txt filter=dater</code></pre>
|
967
|
+
</div>
|
968
|
+
</div>
|
969
|
+
<div class="listingblock">
|
970
|
+
<div class="content">
|
971
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ echo '# $Date$' > date_test.txt</code></pre>
|
972
|
+
</div>
|
973
|
+
</div>
|
974
|
+
<div class="paragraph">
|
975
|
+
<p>If you commit those changes and check out the file again, you see the keyword properly substituted:</p>
|
976
|
+
</div>
|
977
|
+
<div class="listingblock">
|
978
|
+
<div class="content">
|
979
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git add date_test.txt .gitattributes
|
980
|
+
$ git commit -m "Test date expansion in Git"
|
981
|
+
$ rm date_test.txt
|
982
|
+
$ git checkout date_test.txt
|
983
|
+
$ cat date_test.txt
|
984
|
+
# $Date: Tue Apr 21 07:26:52 2009 -0700$</code></pre>
|
985
|
+
</div>
|
986
|
+
</div>
|
987
|
+
<div class="paragraph">
|
988
|
+
<p>You can see how powerful this technique can be for customized applications.
|
989
|
+
You have to be careful, though, because the <code>.gitattributes</code> file is committed and passed around with the project, but the driver (in this case, <code>dater</code>) isn’t, so it won’t work everywhere.
|
990
|
+
When you design these filters, they should be able to fail gracefully and have the project still work properly.</p>
|
991
|
+
</div>
|
992
|
+
</div>
|
993
|
+
<div class="sect3">
|
994
|
+
<h3 id="_exporting_your_repository">Exporting Your Repository</h3>
|
995
|
+
<div class="paragraph">
|
996
|
+
<p>
|
997
|
+
Git attribute data also allows you to do some interesting things when exporting an archive of your project.</p>
|
998
|
+
</div>
|
999
|
+
<div class="sect4">
|
1000
|
+
<h4 id="_export_ignore"><code>export-ignore</code></h4>
|
1001
|
+
<div class="paragraph">
|
1002
|
+
<p>You can tell Git not to export certain files or directories when generating an archive.
|
1003
|
+
If there is a subdirectory or file that you don’t want to include in your archive file but that you do want checked into your project, you can determine those files via the <code>export-ignore</code> attribute.</p>
|
1004
|
+
</div>
|
1005
|
+
<div class="paragraph">
|
1006
|
+
<p>For example, say you have some test files in a <code>test/</code> subdirectory, and it doesn’t make sense to include them in the tarball export of your project.
|
1007
|
+
You can add the following line to your Git attributes file:</p>
|
1008
|
+
</div>
|
1009
|
+
<div class="listingblock">
|
1010
|
+
<div class="content">
|
1011
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">test/ export-ignore</code></pre>
|
1012
|
+
</div>
|
1013
|
+
</div>
|
1014
|
+
<div class="paragraph">
|
1015
|
+
<p>Now, when you run <code>git archive</code> to create a tarball of your project, that directory won’t be included in the archive.</p>
|
1016
|
+
</div>
|
1017
|
+
</div>
|
1018
|
+
<div class="sect4">
|
1019
|
+
<h4 id="_export_subst"><code>export-subst</code></h4>
|
1020
|
+
<div class="paragraph">
|
1021
|
+
<p>When exporting files for deployment you can apply <code>git log’s formatting and keyword-expansion processing to selected portions of files marked with the `export-subst</code> attribute.</p>
|
1022
|
+
</div>
|
1023
|
+
<div class="paragraph">
|
1024
|
+
<p>For instance, if you want to include a file named <code>LAST_COMMIT</code> in your project, and have metadata about the last commit automatically injected into it when <code>git archive</code> runs, you can for example set up your <code>.gitattributes</code> and <code>LAST_COMMIT</code> files like this:</p>
|
1025
|
+
</div>
|
1026
|
+
<div class="listingblock">
|
1027
|
+
<div class="content">
|
1028
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">LAST_COMMIT export-subst</code></pre>
|
1029
|
+
</div>
|
1030
|
+
</div>
|
1031
|
+
<div class="listingblock">
|
1032
|
+
<div class="content">
|
1033
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ echo 'Last commit date: $Format:%cd by %aN$' > LAST_COMMIT
|
1034
|
+
$ git add LAST_COMMIT .gitattributes
|
1035
|
+
$ git commit -am 'adding LAST_COMMIT file for archives'</code></pre>
|
1036
|
+
</div>
|
1037
|
+
</div>
|
1038
|
+
<div class="paragraph">
|
1039
|
+
<p>When you run <code>git archive</code>, the contents of the archived file will look like this:</p>
|
1040
|
+
</div>
|
1041
|
+
<div class="listingblock">
|
1042
|
+
<div class="content">
|
1043
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git archive HEAD | tar xCf ../deployment-testing -
|
1044
|
+
$ cat ../deployment-testing/LAST_COMMIT
|
1045
|
+
Last commit date: Tue Apr 21 08:38:48 2009 -0700 by Scott Chacon</code></pre>
|
1046
|
+
</div>
|
1047
|
+
</div>
|
1048
|
+
<div class="paragraph">
|
1049
|
+
<p>The substitutions can include for example the commit message and any <code>git notes</code>, and <code>git log</code> can do simple word wrapping:</p>
|
1050
|
+
</div>
|
1051
|
+
<div class="listingblock">
|
1052
|
+
<div class="content">
|
1053
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ echo '$Format:Last commit: %h by %aN at %cd%n%+w(76,6,9)%B$' > LAST_COMMIT
|
1054
|
+
$ git commit -am 'export-subst uses git log'\''s custom formatter
|
1055
|
+
|
1056
|
+
git archive uses git log'\''s `pretty=format:` processor
|
1057
|
+
directly, and strips the surrounding `$Format:` and `$`
|
1058
|
+
markup from the output.
|
1059
|
+
'
|
1060
|
+
$ git archive @ | tar xfO - LAST_COMMIT
|
1061
|
+
Last commit: 312ccc8 by Jim Hill at Fri May 8 09:14:04 2015 -0700
|
1062
|
+
export-subst uses git log's custom formatter
|
1063
|
+
|
1064
|
+
git archive uses git log's `pretty=format:` processor directly, and
|
1065
|
+
strips the surrounding `$Format:` and `$` markup from the output.</code></pre>
|
1066
|
+
</div>
|
1067
|
+
</div>
|
1068
|
+
<div class="paragraph">
|
1069
|
+
<p>The resulting archive is suitable for deployment work, but like any exported archive it isn’t suitable for further development work.</p>
|
1070
|
+
</div>
|
1071
|
+
</div>
|
1072
|
+
</div>
|
1073
|
+
<div class="sect3">
|
1074
|
+
<h3 id="_merge_strategies">Merge Strategies</h3>
|
1075
|
+
<div class="paragraph">
|
1076
|
+
<p>
|
1077
|
+
You can also use Git attributes to tell Git to use different merge strategies for specific files in your project.
|
1078
|
+
One very useful option is to tell Git to not try to merge specific files when they have conflicts, but rather to use your side of the merge over someone else’s.</p>
|
1079
|
+
</div>
|
1080
|
+
<div class="paragraph">
|
1081
|
+
<p>This is helpful if a branch in your project has diverged or is specialized, but you want to be able to merge changes back in from it, and you want to ignore certain files.
|
1082
|
+
Say you have a database settings file called <code>database.xml</code> that is different in two branches, and you want to merge in your other branch without messing up the database file.
|
1083
|
+
You can set up an attribute like this:</p>
|
1084
|
+
</div>
|
1085
|
+
<div class="listingblock">
|
1086
|
+
<div class="content">
|
1087
|
+
<pre class="highlight"><code class="language-ini" data-lang="ini">database.xml merge=ours</code></pre>
|
1088
|
+
</div>
|
1089
|
+
</div>
|
1090
|
+
<div class="paragraph">
|
1091
|
+
<p>And then define a dummy <code>ours</code> merge strategy with:</p>
|
1092
|
+
</div>
|
1093
|
+
<div class="listingblock">
|
1094
|
+
<div class="content">
|
1095
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git config --global merge.ours.driver true</code></pre>
|
1096
|
+
</div>
|
1097
|
+
</div>
|
1098
|
+
<div class="paragraph">
|
1099
|
+
<p>If you merge in the other branch, instead of having merge conflicts with the <code>database.xml</code> file, you see something like this:</p>
|
1100
|
+
</div>
|
1101
|
+
<div class="listingblock">
|
1102
|
+
<div class="content">
|
1103
|
+
<pre class="highlight"><code class="language-console" data-lang="console">$ git merge topic
|
1104
|
+
Auto-merging database.xml
|
1105
|
+
Merge made by recursive.</code></pre>
|
1106
|
+
</div>
|
1107
|
+
</div>
|
1108
|
+
<div class="paragraph">
|
1109
|
+
<p>In this case, <code>database.xml</code> stays at whatever version you originally had.</p>
|
1110
|
+
</div>
|
1111
|
+
</div>
|
1112
|
+
<div id="nav"><a href="_external_merge_tools.html">prev</a> | <a href="_email_hooks.html">next</a></div></div>
|
1113
|
+
</div>
|
1114
|
+
|
1115
|
+
</div>
|
1116
|
+
</div>
|
1117
|
+
<footer>
|
1118
|
+
<div class="site-source">
|
1119
|
+
<a href="https://git-scm.com/site">About this site</a><br>
|
1120
|
+
Patches, suggestions, and comments are welcome.
|
1121
|
+
</div>
|
1122
|
+
<div class="sfc-member">
|
1123
|
+
Git is a member of <a href="https://git-scm.com/sfc">Software Freedom Conservancy</a>
|
1124
|
+
</div>
|
1125
|
+
</footer>
|
1126
|
+
<a href="_keyword_expansion.html#top" class="no-js scrollToTop" id="scrollToTop" data-label="Scroll to top">
|
1127
|
+
<img src="../../../../images/icons/chevron-up@2x.png" width="20" height="20" alt="scroll-to-top"/>
|
1128
|
+
</a>
|
1129
|
+
<script src="../../../../assets/application-38b0d42ff05ffea45841edebbd14b75b89585646153808e82907c2c5c11f324b.js"></script>
|
1130
|
+
|
1131
|
+
</div>
|
1132
|
+
|
1133
|
+
</body>
|
1134
|
+
</html>
|