reklama - zainteresowany?

Mercurial: The Definitive Guide. The Definitive Guide - Helion

Mercurial: The Definitive Guide. The Definitive Guide
ebook
Autor: Bryan O'Sullivan
ISBN: 978-05-965-5547-4
stron: 284, Format: ebook
Data wydania: 2009-06-16
Księgarnia: Helion

Cena książki: 126,65 zł (poprzednio: 147,27 zł)
Oszczędzasz: 14% (-20,62 zł)

Dodaj do koszyka Mercurial: The Definitive Guide. The Definitive Guide

This instructive book takes you step by step through ways to track, merge, and manage both open source and commercial software projects with Mercurial, using Windows, Mac OS X, Linux, Solaris, and other systems. Mercurial is the easiest system to learn when it comes to distributed revision control. And it's a very flexible tool that's ideal whether you're a lone programmer working on a small project, or part of a huge team dealing with thousands of files.

Mercurial permits a countless variety of development and collaboration methods, and this book offers several concrete suggestions to get you started. This guide will help you:

  • Learn the basics of working with a repository, changesets, and revisions
  • Merge changes from separate repositories
  • Set up Mercurial to work with files on a daily basis, including which ones to track
  • Get examples and tools for setting up various workflow models
  • Manage a project that's making progress on multiple fronts at once
  • Find and fix mistakes by isolating problem sources
  • Use hooks to perform actions automatically in response to repository events
  • Customize the output of Mercurial


Mercurial: The Definitive Guide maintains a strong focus on simplicity to help you learn Mercurial quickly and thoroughly.

Dodaj do koszyka Mercurial: The Definitive Guide. The Definitive Guide

 

Osoby które kupowały "Mercurial: The Definitive Guide. The Definitive Guide", wybierały także:

  • Windows Media Center. Domowe centrum rozrywki
  • Ruby on Rails. Ćwiczenia
  • Przywództwo w Å›wiecie VUCA. Jak być skutecznym liderem w niepewnym Å›rodowisku
  • Scrum. O zwinnym zarzÄ…dzaniu projektami. Wydanie II rozszerzone
  • Od hierarchii do turkusu, czyli jak zarzÄ…dzać w XXI wieku

Dodaj do koszyka Mercurial: The Definitive Guide. The Definitive Guide

Spis treści

Mercurial: The Definitive Guide. The Definitive Guide eBook -- spis treści

  • Mercurial: The Definitive Guide
    • SPECIAL OFFER: Upgrade this ebook with OReilly
    • 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
          • The forking non-problem
        • 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
        • Whats 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
          • Creating a Mercurial configuration file
          • Choosing 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
      • Mercurials 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
          • Network recompression
        • Read/Write Ordering and Atomicity
        • Concurrent Access
          • Safe dirstate 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
      • Mercurials 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
          • What could possibly go wrong?
          • Configuring lighttpd
        • Sharing Multiple Repositories with One CGI Script
          • Explicitly specifying which repositories to publish
        • Downloading Source Archives
        • Web Configuration Options
          • Options specific to an individual repository
          • Options specific to the hg serve command
          • Choosing the right ~/.hgrc file to add web items to
      • System-Wide Configuration
        • Making Mercurial More Trusting
    • 7. Filenames and Pattern Matching
      • Simple File Naming
      • Running Commands Without Any Filenames
      • Telling You Whats Going On
      • Using Patterns to Identify Files
        • Shell-Style Glob Patterns
          • Watch out!
        • 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
      • Dont 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 Youve 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
          • Always use the --merge option
        • 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
        • aclAccess Control for Parts of a Repository
          • Configuring the acl hook
          • Testing and troubleshooting
        • bugzillaIntegration with Bugzilla
          • Configuring the bugzilla hook
          • Mapping committer names to Bugzilla usernames
          • Configuring the text that gets added to a bug
          • Testing and troubleshooting
        • notifySend Email Notifications
          • Configuring the notify hook
          • Testing and troubleshooting
      • Information for Writers of Hooks
        • In-Process Hook Execution
        • External Hook Execution
        • Finding Out Where Changesets Come From
          • Sources of changesets
          • Where changes are goingremote repository URLs
      • Hook Reference
        • changegroupAfter Remote Changesets Added
        • commitAfter a New Changeset Is Created
        • incomingAfter One Remote Changeset Is Added
        • outgoingAfter Changesets Are Propagated
        • prechangegroupBefore Starting to Add Remote Changesets
        • precommitBefore Starting to Commit a Changeset
        • preoutgoingBefore Starting to Propagate Changesets
        • pretagBefore Tagging a Changeset
        • pretxnchangegroupBefore Completing Addition of Remote Changesets
        • pretxncommitBefore Completing Commit of New Changeset
        • preupdateBefore Updating or Merging Working Directory
        • tagAfter Tagging a Changeset
        • updateAfter 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 Subversions 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 Dont Work Well
      • Conditionally Applying Patches with Guards
      • Controlling the Guards on a Patch
      • Selecting the Guards to Use
      • MQs 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
          • Scope of commands
          • Multi-user operation and safety
          • Published versus local changes
        • Quick Reference
      • Useful Tips for Newcomers
    • B. Mercurial Queues Reference
      • MQ Command Reference
        • qappliedPrint Applied Patches
        • qcommitCommit Changes in the Queue Repository
        • qdeleteDelete a Patch from the Series File
        • qdiffPrint a Diff of the Topmost Applied Patch
        • qfoldMove Applied Patches into Repository History
        • qfoldMerge (fold) Several Patches into One
        • qheaderDisplay the Header/Description of a Patch
        • qimportImport a Third-Party Patch into the Queue
        • qinitPrepare a Repository to Work with MQ
        • qnewCreate a New Patch
        • qnextPrint the Name of the Next Patch
        • qpopPop Patches Off the Stack
        • qprevPrint the Name of the Previous Patch
        • qpushPush Patches onto the Stack
        • qrefreshUpdate the Topmost Applied Patch
        • qrenameRename a Patch
        • qseriesPrint the Entire Patch Series
        • qtopPrint the Name of the Current Patch
        • qunappliedPrint Patches Not yet Applied
        • hg stripRemove 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
    • About the Author
    • Colophon
    • SPECIAL OFFER: Upgrade this ebook with OReilly

Dodaj do koszyka Mercurial: The Definitive Guide. The Definitive Guide

Code, Publish & WebDesing by CATALIST.com.pl



(c) 2005-2025 CATALIST agencja interaktywna, znaki firmowe należą do wydawnictwa Helion S.A.