思维导图备注

Mercurial_ The Definitive Guide - Bryan O'Sullivan
首页 收藏书籍 阅读记录
  • 书签 我的书签
  • 添加书签 添加书签 移除书签 移除书签

Beware Interference Between Bugs

浏览 16 扫码
  • 小字体
  • 中字体
  • 大字体
2022-02-24 01:38:16
请 登录 再阅读
上一篇:
下一篇:
  • 书签
  • 添加书签 移除书签
  • Preface
    • Technical Storytelling
    • Thank You for Supporting Mercurial
    • Conventions Used in This Book
    • Using Code Examples
    • Safari® Books Online
    • How to Contact Us
    • This Book Is Free
    • Acknowledgments
  • 1. A Brief History of Revision Control
    • Why Revision Control? Why Mercurial?
      • Why Use Revision Control?
      • The Many Names of Revision Control
    • This Book Is a Work in Progress
    • About the Examples in This Book
    • Trends in the Field
    • A Few Advantages of Distributed Revision Control
      • Advantages for Open Source Projects
      • Advantages for Commercial Projects
    • Why Choose Mercurial?
    • Mercurial Compared with Other Tools
      • Subversion
      • Git
      • CVS
      • Commercial Tools
      • Choosing a Revision Control Tool
    • Switching from Another Tool to Mercurial
    • A Short History of Revision Control
  • 2. A Tour of Mercurial: The Basics
    • Installing Mercurial on Your System
      • Windows
      • Mac OS X
      • Linux
      • Solaris
    • Getting Started
      • Built-In Help
    • Working with a Repository
      • Making a Local Copy of a Repository
      • What’s in a Repository?
    • A Tour Through History
      • Changesets, Revisions, and Talking to Other People
      • Viewing Specific Revisions
      • More Detailed Information
    • All About Command Options
    • Making and Reviewing Changes
    • Recording Changes in a New Changeset
      • Setting Up a Username
      • Writing a Commit Message
      • Writing a Good Commit Message
      • Aborting a Commit
      • Admiring Our New Handiwork
    • Sharing Changes
      • Pulling Changes from Another Repository
      • Updating the Working Directory
      • Pushing Changes to Another Repository
      • Default Locations
      • Sharing Changes over a Network
    • Starting a New Project
  • 3. A Tour of Mercurial: Merging Work
    • Merging Streams of Work
      • Head Changesets
      • Performing the Merge
      • Committing the Results of the Merge
    • Merging Conflicting Changes
      • Using a Graphical Merge Tool
      • A Worked Example
    • Simplifying the Pull-Merge-Commit Sequence
    • Renaming, Copying, and Merging
  • 4. Behind the Scenes
    • Mercurial’s Historical Record
      • Tracking the History of a Single File
      • Managing Tracked Files
      • Recording Changeset Information
      • Relationships Between Revisions
    • Safe, Efficient Storage
      • Efficient Storage
      • Safe Operation
      • Fast Retrieval
      • Identification and Strong Integrity
    • Revision History, Branching, and Merging
    • The Working Directory
      • What Happens When You Commit
      • Creating a New Head
      • Merging Changes
      • Merging and Renames
    • Other Interesting Design Features
      • Clever Compression
      • Read/Write Ordering and Atomicity
      • Concurrent Access
      • Avoiding Seeks
      • Other Contents of the Dirstate
  • 5. Mercurial in Daily Use
    • Telling Mercurial Which Files to Track
      • Explicit Versus Implicit File Naming
      • Mercurial Tracks Files, Not Directories
    • How to Stop Tracking a File
      • Removing a File Does Not Affect Its History
      • Missing Files
      • Useful Shorthand: Adding and Removing Files in One Step
    • Copying Files
      • The Results of Copying During a Merge
      • Why Should Changes Follow Copies?
      • How to Make Changes Not Follow a Copy
      • Behavior of the hg copy Command
    • Renaming Files
      • Renaming Files and Merging Changes
      • Divergent Renames and Merging
      • Convergent Renames and Merging
      • Other Name-Related Corner Cases
    • Recovering from Mistakes
    • Dealing with Tricky Merges
      • File Resolution States
      • Resolving a File Merge
    • More Useful Diffs
    • Which Files to Manage, and Which to Avoid
    • Backups and Mirroring
  • 6. Collaborating with Other People
    • Mercurial’s Web Interface
    • Collaboration Models
      • Factors to Keep in Mind
      • Informal Anarchy
      • A Single Central Repository
      • A Hosted Central Repository
      • Working with Multiple Branches
      • Feature Branches
      • The Release Train
      • The Linux Kernel Model
      • Pull-Only Versus Shared-Push Collaboration
      • Where Collaboration Meets Branch Management
    • The Technical Side of Sharing
    • Informal Sharing with hg serve
      • A Few Things to Keep in Mind
    • Using the Secure Shell Protocol
      • How to Read and Write ssh URLs
      • Finding an ssh Client for Your System
      • Generating a Key Pair
      • Using an Authentication Agent
      • Configuring the Server Side Properly
      • Using Compression with ssh
    • Serving Over HTTP Using CGI
      • Web Server Configuration Checklist
      • Basic CGI Configuration
      • Sharing Multiple Repositories with One CGI Script
      • Downloading Source Archives
      • Web Configuration Options
    • System-Wide Configuration
      • Making Mercurial More Trusting
  • 7. Filenames and Pattern Matching
    • Simple File Naming
    • Running Commands Without Any Filenames
    • Telling You What’s Going On
    • Using Patterns to Identify Files
      • Shell-Style Glob Patterns
      • Regular Expression Matching with Re Patterns
    • Filtering Files
    • Permanently Ignoring Unwanted Files and Directories
    • Case Sensitivity
      • Safe, Portable Repository Storage
      • Detecting Case Conflicts
      • Fixing a Case Conflict
  • 8. Managing Releases and Branchy Development
    • Giving a Persistent Name to a Revision
      • Handling Tag Conflicts During a Merge
      • Tags and Cloning
      • When Permanent Tags Are Too Much
    • The Flow of Changes: Big Picture Versus Little Picture
    • Managing Big-Picture Branches in Repositories
    • Don’t Repeat Yourself: Merging Across Branches
    • Naming Branches Within One Repository
    • Dealing with Multiple Named Branches in a Repository
    • Branch Names and Merging
    • Branch Naming Is Generally Useful
  • 9. Finding and Fixing Mistakes
    • Erasing Local History
      • The Accidental Commit
      • Rolling Back a Transaction
      • The Erroneous Pull
      • Rolling Back Is Useless Once You’ve Pushed
      • You Can Only Roll Back Once
    • Reverting the Mistaken Change
      • File Management Errors
    • Dealing with Committed Changes
      • Backing Out a Changeset
      • Backing Out the Tip Changeset
      • Backing Out a Non-Tip Change
      • Gaining More Control of the Backout Process
      • Why hg backout Works As It Does
    • Changes That Should Never Have Been
      • Backing Out a Merge
      • Protect Yourself from Escaped Changes
      • What to Do About Sensitive Changes That Escape
    • Finding the Source of a Bug
      • Using the hg bisect Command
      • Cleaning Up After Your Search
    • Tips for Finding Bugs Effectively
      • Give Consistent Input
      • Automate As Much As Possible
      • Check Your Results
      • Beware Interference Between Bugs
      • Bracket Your Search Lazily
  • 10. Handling Repository Events with Hooks
    • An Overview of Hooks in Mercurial
    • Hooks and Security
      • Hooks Are Run with Your Privileges
      • Hooks Do Not Propagate
      • Hooks Can Be Overridden
      • Ensuring That Critical Hooks Are Run
    • A Short Tutorial on Using Hooks
      • Performing Multiple Actions Per Event
      • Controlling Whether an Activity Can Proceed
    • Writing Your Own Hooks
      • Choosing How Your Hook Should Run
      • Hook Parameters
      • Hook Return Values and Activity Control
      • Writing an External Hook
      • Telling Mercurial to Use an In-Process Hook
      • Writing an In-Process Hook
    • Some Hook Examples
      • Writing Meaningful Commit Messages
      • Checking for Trailing Whitespace
    • Bundled Hooks
      • acl—Access Control for Parts of a Repository
      • bugzilla—Integration with Bugzilla
      • notify—Send Email Notifications
    • Information for Writers of Hooks
      • In-Process Hook Execution
      • External Hook Execution
      • Finding Out Where Changesets Come From
    • Hook Reference
      • changegroup—After Remote Changesets Added
      • commit—After a New Changeset Is Created
      • incoming—After One Remote Changeset Is Added
      • outgoing—After Changesets Are Propagated
      • prechangegroup—Before Starting to Add Remote Changesets
      • precommit—Before Starting to Commit a Changeset
      • preoutgoing—Before Starting to Propagate Changesets
      • pretag—Before Tagging a Changeset
      • pretxnchangegroup—Before Completing Addition of Remote Changesets
      • pretxncommit—Before Completing Commit of New Changeset
      • preupdate—Before Updating or Merging Working Directory
      • tag—After Tagging a Changeset
      • update—After Updating or Merging Working Directory
  • 11. Customizing the Output of Mercurial
    • Using Precanned Output Styles
      • Setting a Default Style
    • Commands That Support Styles and Templates
    • The Basics of Templating
    • Common Template Keywords
    • Escape Sequences
    • Filtering Keywords to Change Their Results
      • Combining Filters
    • From Templates to Styles
      • The Simplest of Style Files
      • Style File Syntax
    • Style Files by Example
      • Identifying Mistakes in Style Files
      • Uniquely Identifying a Repository
      • Listing Files on Multiple Lines
      • Mimicking Subversion’s Output
  • 12. Managing Changes with Mercurial Queues
    • The Patch Management Problem
    • The Prehistory of Mercurial Queues
      • A Patchwork Quilt
      • From Patchwork Quilt to Mercurial Queues
    • The Huge Advantage of MQ
    • Understanding Patches
    • Getting Started with Mercurial Queues
      • Creating a New Patch
      • Refreshing a Patch
      • Stacking and Tracking Patches
      • Manipulating the Patch Stack
      • Pushing and Popping Many Patches
      • Safety Checks, and Overriding Them
      • Working on Several Patches at Once
    • More About Patches
      • The Strip Count
      • Strategies for Applying a Patch
      • Some Quirks of Patch Representation
      • Beware the Fuzz
      • Handling Rejection
    • More on Patch Management
      • Deleting Unwanted Patches
      • Converting to and from Permanent Revisions
    • Getting the Best Performance Out of MQ
    • Updating Your Patches When the Underlying Code Changes
    • Identifying Patches
    • Useful Things to Know About
    • Managing Patches in a Repository
      • MQ Support for Patch Repositories
      • A Few Things to Watch Out For
    • Third-Party Tools for Working with Patches
    • Good Ways to Work with Patches
    • MQ Cookbook
      • Managing Trivial Patches
      • Combining Entire Patches
      • Merging Part of One Patch into Another
    • Differences Between Quilt and MQ
  • 13. Advanced Uses of Mercurial Queues
    • The Problem of Many Targets
      • Tempting Approaches That Don’t Work Well
    • Conditionally Applying Patches with Guards
    • Controlling the Guards on a Patch
    • Selecting the Guards to Use
    • MQ’s Rules for Applying Patches
    • Trimming the Work Environment
    • Dividing Up the Series File
    • Maintaining the Patch Series
      • The Art of Writing Backport Patches
    • Useful Tips for Developing with MQ
      • Organizing Patches in Directories
      • Viewing the History of a Patch
  • 14. Adding Functionality with Extensions
    • Improve Performance with the inotify Extension
    • Flexible Diff Support with the extdiff Extension
      • Defining Command Aliases
    • Cherry-Picking Changes with the transplant Extension
    • Sending Changes via Email with the patchbomb Extension
      • Changing the Behavior of Patchbombs
  • A. Migrating to Mercurial
    • Importing History from Another System
      • Converting Multiple Branches
      • Mapping Usernames
      • Tidying Up the Tree
      • Improving Subversion Conversion Performance
    • Migrating from Subversion
      • Philosophical Differences
      • Quick Reference
    • Useful Tips for Newcomers
  • B. Mercurial Queues Reference
    • MQ Command Reference
      • qapplied—Print Applied Patches
      • qcommit—Commit Changes in the Queue Repository
      • qdelete—Delete a Patch from the Series File
      • qdiff—Print a Diff of the Topmost Applied Patch
      • qfold—Move Applied Patches into Repository History
      • qfold—Merge (fold) Several Patches into One
      • qheader—Display the Header/Description of a Patch
      • qimport—Import a Third-Party Patch into the Queue
      • qinit—Prepare a Repository to Work with MQ
      • qnew—Create a New Patch
      • qnext—Print the Name of the Next Patch
      • qpop—Pop Patches Off the Stack
      • qprev—Print the Name of the Previous Patch
      • qpush—Push Patches onto the Stack
      • qrefresh—Update the Topmost Applied Patch
      • qrename—Rename a Patch
      • qseries—Print the Entire Patch Series
      • qtop—Print the Name of the Current Patch
      • qunapplied—Print Patches Not yet Applied
      • hg strip—Remove a Revision and Descendants
    • MQ File Reference
      • The Series File
      • The Status File
  • C. Installing Mercurial from Source
    • On a Unix-Like System
    • On Windows
  • D. Open Publication License
    • Requirements on Both Unmodified and Modified Versions
    • Copyright
    • Scope of License
    • Requirements on Modified Works
    • Good-Practice Recommendations
    • License Options
  • Index
暂无相关搜索结果!
    展开/收起文章目录

    二维码

    手机扫一扫,轻松掌上学

    《Mercurial_ The Definitive Guide - Bryan O'Sullivan》电子书下载

    请下载您需要的格式的电子书,随时随地,享受学习的乐趣!
    EPUB 电子书

    书签列表

      阅读记录

      阅读进度: 0.00% ( 0/0 ) 重置阅读进度