blob: b8d0694de77073a66c5845aaacd477307a61d54b [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!--
Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved.
-->
<html>
<head>
<title>在 NetBeans IDE 中使用 Mercurial 支持</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<meta name="author" content="psunb@netbeans.org">
<meta name="description" content="Overview of Mercurial Features in NetBeans IDE">
<meta name="keywords" content="NetBeans, IDE, integrated development environment, Mercurial,
versioning software, open source, developers, collaborate">
<link rel="stylesheet" type="text/css" href="../../../netbeans.css">
<link rel="stylesheet" type="text/css" href="../../../lytebox.css" media="screen">
<script type="text/javascript" src="../../../images_www/js/lytebox-compressed.js"></script>
</head>
<body>
<h1>在 NetBeans IDE 中使用 Mercurial 支持 </h1>
<p>NetBeans IDE 支持 Mercurial 版本控制客户端 1.0.x 及更高版本。通过利用 IDE 的 Mercurial 支持,您可以在 IDE 内从项目中直接执行版本控制任务。本文档通过指导您完成使用版本控制软件的标准工作流,介绍了如何在 IDE 中执行基本的版本控制任务。</p>
<p><a href="http://www.selenic.com/mercurial/wiki/" target="_blank">Mercurial</a> 是一个快速的小型轻量级源代码控制管理系统,旨在高效地处理大型分布式项目。与 CVS 和 Subversion 不同的是,Mercurial 使用的是许多开源项目中常用的分布式资源库,并支持分布式开发,而无需任何集中控制。您可以对文件和目录使用 Mercurial 命令。IDE 提供了图形化比较查看器,用于比较文件修订版本,同时支持在编辑器中直接进行内联比较。</p>
<p>IDE 的 Mercurial 支持类似于 IDE 的 Subversion 支持。主要区别在于,Mercurial 是一个分布式修订版本控制系统。通常,用户首先<em>克隆</em>要使用的外部资源库。此克隆内容是资源库(包含修订历史记录)的完整副本。您可以根据需要反复克隆此本地副本,并且在准备好时将本地所做的更改推回原始资源库(如果您具有权限),或者<em>导出</em>所做的更改,然后将其发送给资源库所有者(如果您没有权限)。
</p>
<h3>目录</h3>
<img alt="此页上的内容适用于 NetBeans IDE 7.4" class="stamp" src="../../../images_www/articles/74/netbeans-stamp.png" title="此页上的内容适用于 NetBeans IDE 7.4">
<ul class="toc">
<li><a href="#settingUp">设置 Mercurial</a></li>
<li><a href="#synchronizing">将本地文件与资源库保持同步</a></li>
<li><a href="#editing">编辑源</a>
<ul>
<li><a href="#viewingChanges">在源代码编辑器中查看更改</a></li>
<li><a href="#viewingFileStatus">查看文件状态信息</a></li>
<li><a href="#comparing">比较文件版本</a></li>
</ul></li>
<li><a href="#committing">将源文件提交到资源库</a>
<ul>
<li><a href="#updating">更新本地副本</a></li>
<li><a href="#committing">执行提交</a></li>
<li><a href="#issues">更新问题</a></li>
<li><a href="#pushing">将本地更改推入共享资源库</a></li>
</ul>
</li>
<li><a href="#summary">小结</a></li>
<li><a href="#seeAlso">另请参见</a></li>
</ul>
<h2><a name="reqs"></a>要求</h2>
<p><strong>要学完本教程,您需要具备以下软件和资源。</strong></p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">软件或资源</th>
<th class="tblheader" scope="col">要求的版本</th>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.netbeans.org/downloads/index.html" target="_blank">NetBeans IDE</a></td>
<td class="tbltd1">版本 7.4</td>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html" target="_blank">Java 开发工具包</a> (JDK)</td>
<td class="tbltd1">版本 6 或 7</td>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.selenic.com/mercurial/" target="_blank">Mercurial 客户端软件</a></td>
<td class="tbltd1">1.04 或更高版本</td>
</tr>
</tbody>
</table>
<a name="settingUp"></a>
<h2>设置 Mercurial</h2>
<p> 在系统中安装 Mercurial 客户端软件后,才能使用 IDE 的 Mercurial 支持。IDE 支持 Mercurial 客户端版本 1.04 和更高版本。IDE 的 Mercurial 支持是通过使用与 Mercurial 命令行界面相同的命令实现的。</p>
<p>通过 <a href="http://www.selenic.com/mercurial/" target="_blank">Mercurial 网站</a>,可以下载 Mercurial 源文件或二进制软件包。</p>
<p>在 IDE 中设置 Mercurial 可执行文件的路径:</p>
<ol>
<li>从主菜单中选择 <tt>Tools</tt>(工具)> <tt>Options</tt>(选项);在 OS X 上为 <tt>NetBeans</tt> > <tt>Preferences</tt>(首选项)。"Options"(选项)对话框打开。</li>
<li>选择对话框顶部的 "Miscellaneous"(其他)图标,然后单击 "Versioning"(版本控制)标签。在 "Versioning Systems"(版本控制系统)下方的左窗格中,选择 "Mercurial"。对话框的主窗口中将显示 Mercurial 的用户定义选项:
<p class="align-center">
<a href="../../../images_www/articles/73/ide/mercurial/options-dialog.png" rel="lytebox" title="&quot;Mercurial Options&quot;(Mercurial 选项)对话框"> <img alt="&quot;Mercurial Options&quot;(Mercurial 选项)对话框" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/options-dialog-small.png"></a></p></li>
<li>在 "Mercurial Executable Path"(Mercurial 可执行文件路径)文本字段中,输入可执行文件的路径,或者单击 "Browse"(浏览)在系统中找到它。请注意,您不需要将 Mercurial 可执行文件<em>包含</em>在路径中。</li>
<li>单击 "OK"(确定)。</li>
</ol>
<p>设置 Mercurial 客户端之后,您可以通过 IDE 的 <tt>Team</tt>(团队开发)> <tt>Mercurial</tt> 菜单运行 Mercurial 命令。要克隆外部 Mercurial 资源库,请选择 <tt>Team</tt>(团队开发)> <tt>Mercurial</tt> > <tt>Clone Other</tt>(克隆其他)。在克隆过程中,IDE 将自动导入克隆文件的所有历史记录和状态信息。</p>
<p>如果您目前拥有 Mercurial 资源库,则 IDE 会自动将在 IDE 项目中打开的文件或在 "Favorites"(收藏夹)窗口中添加的文件标识为版本控制文件。可以通过 Mercurial 菜单对这些文件使用 Mercurial 命令,也可以采用右键单击文件或文件夹,然后从 Mercurial 上下文菜单中进行选择的方法。</p>
<p>要使用命令行在计算机上创建 Mercurial 资源库,请键入以下内容:</p>
<pre class="examplecode">hg clone /path/to/your/repository</pre>
<p class="notes"><b>注:</b>NetBeans Mercurial 资源库 (<a href="http://hg.netbeans.org/">http://hg.netbeans.org/</a>) 在本教程中用于演示目的。 </p>
<a name="synchronizing"></a>
<h2>将本地文件与资源库保持同步</h2>
<p>使用版本控制系统时,可以这样操作:将本地文件与资源库保持同步,再对本地副本进行更改,然后将其提交到该资源库。下表介绍了在 NetBeans IDE 中同步项目所能使用的各种方法,这取决于您的具体情况:</p>
<ul>
<li><a href="#opening">在 IDE 中打开 Mercurial 项目</a> </li>
<li><a href="#checking">从资源库中检出文件</a></li>
<li><a href="#importing">将文件导入资源库中</a></li>
</ul>
<div class="indent">
<a name="opening"></a>
<h3>在 IDE 中打开 Mercurial 项目</h3>
<p>如果您已拥有 Mercurial 版本控制项目,并且已在 IDE 之外使用该项目,则可在 IDE 中将其打开,版本控制功能将自动变为可用。IDE 将扫描打开的项目和文件状态,并为 Mercurial 版本控制项目自动激活上下文相关支持。</p>
<a name="checking"></a>
<h3>从资源库中检出文件</h3>
<p>如果要通过 IDE 与远程资源库相连,请检出并立即开始使用文件,具体操作如下:</p>
<ol>
<li>在 NetBeans IDE 中,从主菜单中选择 <tt>Team</tt>(团队开发)> <tt>Mercurial</tt> > <tt>Clone other</tt>(克隆其他)。此时将打开克隆向导。
<p class="align-center">
<a href="../../../images_www/articles/73/ide/mercurial/clone-repository.png" rel="lytebox" title="Mercurial 克隆向导"> <img alt="Mercurial 克隆向导" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/clone-repository-small.png"></a></p>
<p class="notes"><b>注:</b>IDE 的下拉菜单是与上下文相关的,即可用选项取决于当前选定的项。因此,如果已在使用 Mercurial 项目,则可以从主菜单中选择 <tt>Team</tt>(团队开发)> <tt>Remote</tt>(远程)> <tt>Clone Other</tt>(克隆其他)。</p></li>
<li>在 "Repository URL"(资源库 URL)中,输入资源库的路径(例如 <tt>http://hg.netbeans.org/main</tt>)。</li>
<li>在克隆向导显示的 "User"(用户)和 "Password"(口令)字段中,输入 netbeans.org 用户名和口令。
<p class="align-center"> <a href="../../../images_www/articles/73/ide/mercurial/clone-username.png" rel="lytebox" title="Mercurial 克隆向导"> <img alt="Mercurial 克隆向导" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/clone-username-small.png"></a></p></li>
<li>如果要使用代理,请务必单击 "Proxy Configuration"(代理配置)按钮,然后在 "Options"(选项)对话框中输入所有必要的信息。如果确定资源库的连接设置正确无误,请单击 "Next"(下一步)。</li>
<li>在第二步中,单击 "Default Push Path"(默认推入路径)字段右侧的 "Change"(更改)。"Change Push Path"(更改推入路径)对话框打开。
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/clone-push.png" rel="lytebox" title="&quot;Change Push Path&quot;(更改推入路径)对话框"> <img alt="&quot;Change Push Path&quot;(更改推入路径)对话框" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/clone-push-small.png"></a></p></li>
<li> 添加 NetBeans 用户名和口令,并将协议更改为 <tt>https</tt>,以修改默认推入项。 </li>
<li>单击 "Set Path"(设置路径)。此时将关闭 "Change Push Path"(更改推入路径)对话框。</li>
<li>单击 "Next"(下一步)以转到该向导的第三步。 </li>
<li>在 "Parent Directory"(父目录)字段中,输入计算机上要将资源库文件检出到的位置(此外,也可以使用 "Browse"(浏览)按钮)。
<p class="align-center"> <a href="../../../images_www/articles/73/ide/mercurial/clone-destination.png" rel="lytebox" title="Mercurial 克隆向导"> <img alt="Mercurial 克隆向导" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/clone-destination-small.png"></a></p>
<p class="note"><b>注:</b>如果运行的是 Windows,请留意指定的路径长度;即 <tt>C:\Documents and Settings\myName\My Documents\NetBeans\etc\etc</tt>,克隆可能会因文件路径过长而失败。请试着改用 <tt>C:\</tt></p></li>
<li>将 "Scan for NetBeans Projects after Checkout"(在检出后扫描 Netbeans 项目)选项保持选中状态,然后单击 "Finish"(完成),以启动检出操作。<br>IDE 将检出选定的源,并且 IDE 的状态栏会显示将文件从资源库下载到本地工作目录的进度。您还可以在 "Output"(输出)窗口(在 Windows 上按 Ctrl-4 组合键;在 OS X 上按 Command-4 组合键)中查看正要检出的文件。
<p class="notes"><b>注:</b>如果检出的源中包含 NetBeans 项目,则将显示一个对话框,提示您在 IDE 中将其打开。如果源中不包含项目,也将显示该对话框,提示您创建基于这些源的新项目,然后在 IDE 中将其打开。如果为这类源创建新项目,请选择相应的项目类别(位于新建项目向导中),然后使用该类别中的 "With Existing Sources"(基于现有源)选项。</p></li>
</ol>
<a name="importing"></a>
<h3>将文件导入资源库中</h3>
<p>此外,也可以将已在 IDE 中处理的项目导入远程资源库中,然后对该项目执行同步操作,再在 IDE 中继续进行处理。</p>
<p><strong class="notes">注:</strong>事实上,从系统中<em>导出</em>文件时,可在版本控制系统中使用术语 "import" 表明文件正<em>导入</em>资源库中。</p>
<p>将项目导入资源库中:</p>
<ol>
<li>在 "Projects"(项目)窗口(在 Windows 上按 Ctrl-1 组合键;在 OS X 上按 Command-1 组合键)中,选择未进行版本控制的项目,然后从节点的右键单击菜单中选择 <tt>Team</tt>(团队开发)> <tt>Mercurial</tt> > <tt>Initialize Repository</tt>(初始化资源库)。此时将打开 "Repository root path"(资源库根路径)对话框。
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/repositoryrootpath.png" rel="lytebox" title="&quot;Repository root path&quot;(资源库根路径)对话框"> <img alt="&quot;Repository root path&quot;(资源库根路径)对话框" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/repositoryrootpath.png"></a></p></li>
<li>在资源库中指定用来放置项目的资源库文件夹。默认情况下,建议您在 "Root Path"(根路径)文本字段中,键入包含项目名称的文件夹。 </li>
<li>单击 "OK"(确定)以启动 Mercurial 初始化操作。<br> 在单击 "OK"(确定)后,IDE 会将项目文件上载到资源库中,并打开 "Output"(输出)窗口以显示进度。
<p class="align-center">
<a href="../../../images_www/articles/73/ide/mercurial/output.png" rel="lytebox" title="输出"> <img alt="输出" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/output-small.png"></a></p>
<p class="notes"><b>注:</b>对项目文件进行 Mercurial 版本控制后,这些文件在资源库中将注册为 <tt>Locally New</tt>(本地新建)。要查看这些新文件及其状态,可以对其右键单击,然后从弹出式菜单中选择 <tt>Mercurial</tt> > <tt>Show changes</tt>(显示更改)。</p>
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/status.png" rel="lytebox" title="状态"> <img alt="状态" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/status-small.png"></a></p></li>
<li>右键单击项目,然后从弹出式菜单中选择 <tt>Mercurial</tt> > <tt>Commit</tt>(提交),以便将这些项目文件提交到 Mercurial 资源库中。此时将打开 "Commit - [ProjectName]"(提交 - [项目名称])对话框。
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/commit-dialog.png" rel="lytebox" title="&quot;Commit&quot;(提交)对话框"> <img alt="&quot;Commit&quot;(提交)对话框" class="margin-around" src="../../../images_www/articles/73/ide/mercurial/commit-dialog-small.png"></a></p></li>
<li>在 "Commit Message"(提交消息)文本区域中键入消息,然后单击 "Commit"(提交)。
<p class="notes"><b>注:</b>提交的文件连同 <tt>.hg</tt> 目录一起放在 Mercurial 资源库目录中。IDE 的 "Output"(输出)窗口(在 Windows 上按 Ctrl-4 组合键;在 OS X 上按 Command-4 组合键)中提供了详细提交信息。</p></li>
</ol>
</div>
<a name="editing"></a>
<h2>编辑源</h2>
<p>在 IDE 中打开 Mercurial 版本控制项目之后,即可开始对源进行更改。与 NetBeans IDE 中打开的任何项目一样,在 IDE 窗口(例如“项目”(在 Windows 上按 Ctrl-1 组合键;在 OS X 上按 Command-1 组合键)、“文件”(在 Windows 上按 Ctrl-2 组合键;在 OS X 上按 Command-2 组合键)或“收藏夹”(在 Windows 上按 Ctrl-3 组合键;在 OS X 上按 Command-3 组合键)窗口)中显示文件时,您可以双击文件节点,在源代码编辑器中打开文件。</p>
<p>在 IDE 中的处理源时,您需要处理各种 UI 组件,这有助于查看和操作版本控制命令:</p>
<ul>
<li><a href="#viewingChanges">在源代码编辑器中查看更改</a></li>
<li><a href="#viewingFileStatus">查看文件状态信息</a></li>
<li><a href="#comparing">比较文件版本</a></li>
<li><a href="#merging">合并文件修订版本</a></li>
</ul>
<div class="indent">
<a name="viewingChanges"></a>
<h3>在源代码编辑器中查看更改</h3>
<p>如果在 IDE 的源代码编辑器中打开版本控制文件,则对照资源库中以前检出的基本版本对文件进行修改时,可以查看对该文件进行的实时更改。您在操作时,IDE 通过源代码编辑器旁注中的颜色编码传递了以下信息:</p>
<table class="cell">
<tr>
<td class="align-right cell"><strong>蓝色</strong> (<span style="background-color:#b8cfe5">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>)</td>
<td>表示自早期修订版本以来更改的行。</td>
</tr>
<tr>
<td class="align-right cell"><strong>绿色</strong> (<span style="background-color:#b4ffb4">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>)</td>
<td>表示自早期修订版本以来添加的行。</td>
</tr>
<tr>
<td class="align-right cell"><strong>红色</strong> (<span style="background-color:#ffa0b4">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>)</td>
<td>表示自早期修订版本以来删除的行。</td>
</tr>
</table>
<p>源代码编辑器左旁注逐行显示发生的更改。当修改给定行时,所做更改会立即在左旁注中显示出来。</p>
<p>您可以单击旁注中的颜色组以调用版本控制命令。例如,单击红色图标(指明从本地副本中删除了行)时,左下方的屏幕快照会显示可用的窗口部件。</p>
<p>源代码编辑器右旁注提供了对文件所做的更改的整体视图,从上到下显示。更改文件之后,将会立即生成颜色编码。</p>
<p>注:单击旁注的特定点可以让内联光标立即转到文件中的该位置。想要查看受影响行的行号,可以将鼠标放在右旁注中的彩色图标上:</p>
<table class="cell" style="width:500px">
<tr>
<td><a href="../../../images_www/articles/73/ide/mercurial/left-ui.png" rel="lytebox" title="显示在编辑器左旁注中的版本控制颜色编码"> <img alt="显示在编辑器左旁注中的版本控制颜色编码" class="b-all" src="../../../images_www/articles/73/ide/mercurial/left-ui-small.png"></a><br> <strong>左旁注</strong></td>
<td><a href="../../../images_www/articles/73/ide/mercurial/right-ui.png" rel="lytebox" title="显示在编辑器右旁注中的版本控制颜色编码"> <img alt="显示在编辑器右旁注中的版本控制颜色编码" class="b-all" src="../../../images_www/articles/73/ide/mercurial/right-ui-small.png"></a> <br><strong>右旁注</strong></td>
</tr>
</table>
<a name="viewingFileStatus"></a>
<h3>查看文件状态信息</h3>
<p>在使用 "Projects"(项目)(在 Windows 上按 Ctrl-1 组合键;在 OS X 上按 Command-1 组合键)、"Files"(文件)(在 Windows 上按 Ctrl-2 组合键;在 OS X 上按 Command-2 组合键)或 "Favorites"(收藏夹)(在 Windows 上按 Ctrl-3 组合键;在 OS X 上按 Command-3 组合键)或 "Versioning"(版本控制)窗口时,IDE 将提供一些可视化功能以帮助查看文件状态信息。在下面的示例中,请注意标记(例如,<img alt="蓝色标记" src="../../../images_www/articles/73/ide/mercurial/blue-badge.png">)、文件名颜色和相邻状态标签如何全都彼此一致,以向您提供一种简单而有效的方法来跟踪文件的版本控制信息:
</p>
<p class="align-center"><img alt="&quot;Favorites&quot;(收藏夹)窗口中显示的蓝色标记" class="b-all" src="../../../images_www/articles/73/ide/mercurial/badge-example.png"></p>
<p class="notes"><b>注:</b>状态标签以文本的形式指示 "Versioning"(版本控制)、"Projects"(项目)和 "Files"(文件)窗口中的文件状态。要显示状态标签,请从主工具栏中选择 "View"(视图)> "Show Versioning Labels"(显示版本控制标签)。</p>
<p>标记、颜色编码、文件状态标签和最重要的 "Versioning"(版本控制)窗口都有助于在 IDE 中有效地查看和管理版本控制信息。</p>
<ul>
<li><a href="#badges">标记和颜色编码</a></li>
<li><a href="#fileStatus">文件状态标签</a></li>
<li><a href="#versioning">"Versioning"(版本控制)窗口</a></li>
</ul>
<div class="indent">
<a name="badges"></a>
<h4>标记和颜色编码</h4>
<p>标记应用于项目、文件夹、包节点,通知您包含在该节点中的文件状态:</p>
<p>下表显示了用于标记的颜色方案:</p>
<table >
<tr>
<th class="tblheader" scope="col" style="width:110px">UI 组件</th>
<th class="tblheader" scope="col" style="width:490px">描述</th>
</tr>
<tr>
<td class="tbltd0 align-center"><strong>蓝色标记</strong> (<img alt="蓝色标记" src="../../../images_www/articles/73/ide/mercurial/blue-badge.png">)</td>
<td class="tbltd0">指示存在已在本地修改、添加或删除的文件。对于包,此标记仅应用于包本身,而不应用于它的子包。对于项目或文件夹,此标记指示其中的更改,或指示其所包含子文件夹中的任何更改。</td>
</tr>
<tr>
<td class="tbltd1 align-center"><strong>红色标记</strong> (<img alt="红色标记" src="../../../images_www/articles/73/ide/mercurial/red-badge.png">)</td>
<td class="tbltd1">标记包含<em>冲突</em>文件(即与资源库中保留的版本冲突的本地版本)的项目、文件夹或包。对于包,此标记仅应用于包本身,而不应用于它的子包。对于项目或文件夹,此标记指示其中的冲突,或指示其所包含子文件夹中的任何冲突。</td>
</tr>
</table>
<a name="color-coding-table"></a>
<p>颜色编码应用于文件名,以指示它们相对于资源库的当前状态:</p>
<table >
<tr>
<th class="tblheader" scope="col" style="width:40px">颜色</th>
<th class="tblheader" scope="col">示例</th>
<th class="tblheader" scope="col">描述</th>
</tr>
<tr>
<td class="tbltd0 align-center"><strong>蓝色</strong></td>
<td class="tbltd0"><img alt="蓝色文本" src="../../../images_www/articles/73/ide/mercurial/blue-text.png"></td>
<td class="tbltd0">表示在本地修改了文件。</td>
</tr>
<tr>
<td class="tbltd1 align-center"><strong>绿色</strong></td>
<td class="tbltd1"><img alt="绿色文本" src="../../../images_www/articles/73/ide/mercurial/green-text.png"></td>
<td class="tbltd1">表示在本地添加了文件。</td>
</tr>
<tr>
<td class="tbltd0 align-center"><strong>红色</strong></td>
<td class="tbltd0"><img alt="红色文本" src="../../../images_www/articles/73/ide/mercurial/red-text.png"></td>
<td class="tbltd0">表示文件中包含本地工作副本与资源库中版本之间的冲突。</td>
</tr>
<tr>
<td class="tbltd1 align-center"><strong>灰色</strong></td>
<td class="tbltd1"><img alt="灰色文本" src="../../../images_www/articles/73/ide/mercurial/gray-text.png"></td>
<td class="tbltd1">表示文件被 Mercurial 忽略,并且不包含在版本控制命令(如 "Update"(更新)和 "Commit"(提交))中。如果文件没有进行版本化,那么它们只能被忽略。</td>
</tr>
<tr>
<td class="tbltd0 align-center" style="width:120px"><strong>删除线</strong></td>
<td class="tbltd0 align-center"><img alt="删除文本" src="../../../images_www/articles/73/ide/mercurial/strike-through-text.png"></td>
<td class="tbltd0">表示从提交操作中排除了文件。只有选择从提交操作中排除个别文件时,删除线文本才出现在特定位置,例如 "Versioning"(版本控制)窗口或 "Commit"(提交)对话框。其他 Mercurial 命令(如 "Update"(更新)命令)仍然会影响到此类文件。</td>
</tr>
</table>
<a name="fileStatus"></a>
<h4>文件状态标签</h4>
<p>文件状态标签以文本的形式指示 IDE 窗口中的版本控制文件的状态。默认情况下,IDE 在窗口中列出的文件右侧以灰色文本显示状态(新的、已修改或已忽略等)和文件夹信息。然而,您可以根据需要修改此格式。例如,如果要将修订版本号添加到状态标签中,请执行以下操作:</p>
<ol>
<li>从主菜单中选择 <tt>Tools</tt>(工具)> <tt>Options</tt>(选项);在 OS X 上为 <tt>NetBeans</tt> > <tt>Preferences</tt>(首选项)。此时将打开 "Options"(选项)窗口。</li>
<li>选择窗口顶部的 "Miscellaneous"(其他)图标,然后单击下面的 "Versioning"(版本控制)标签。确保在左面板中的版本控制系统下选择了 "Mercurial"。 </li>
<li>要重新设置状态标签的格式,以便在文件右侧仅显示状态和文件夹,可以按照下列顺序重新排列 "Status Label Format"(状态标签格式)文本字段的内容:
<pre class="examplecode">[{status}; {folder}]</pre>
单击 "OK"(确定)。状态标签现在列出文件状态和文件夹(如果适用): </li></ol>
<p class="align-center"><img alt="显示在文件名旁边的文件标签" class="b-all margin-around" src="../../../images_www/articles/73/ide/mercurial/file-labels.png"></p>
<p class="tips">从主菜单中选择 <tt>View</tt>(视图)> <tt>Show Versioning Labels</tt>(显示版本控制标签),可打开和关闭文件状态标签。</p>
<a name="versioning"></a>
<h4>"Versioning"(版本控制)窗口</h4>
<p>Mercurial 的 "Versioning"(版本控制)窗口为您提供了一个实时列表,其中包括对本地工作副本的选定文件夹中的文件做出的所有更改。默认情况下,它将在 IDE 的底部面板中打开,其中列出了已添加、删除或修改的文件。</p>
<p>要打开 "Versioning"(版本控制)窗口,请选择一个版本控制文件或文件夹(例如,从 "Projects"(项目)、"Files"(文件)或 "Favorites"(收藏夹)窗口中选择),然后从右键单击菜单中选择 <tt>Mercurial</tt> > <tt>Show Changes</tt>(显示更改),或者从主菜单中选择 <tt>Team</tt>(团队开发)> <tt>Mercurial</tt> > <tt>Show Changes</tt>(显示更改)。下面的窗口出现在 IDE 底部:
</p>
<p class="align-center"><img alt="显示本地修改的文件的版本控制窗口" class="b-none margin-around" src="../../../images_www/articles/73/ide/mercurial/versioning-window.png"></p>
<p>默认情况下,"Versioning"(版本控制)窗口会显示选定包或文件夹中所有已修改文件的列表。使用工具栏中的按钮,可以选择显示所有更改,也可以将显示的文件列表限定为本地或远程修改的文件。此外,也可以单击列出的文件上面的列标题,按名称、状态或位置对这些文件进行排序。</p>
<p>"Versioning"(版本控制)窗口工具栏还包含一些按钮,可用来对列表中显示的所有文件调用最常见的 Mercurial 任务。下表列出了 "Versioning"(版本控制)窗口工具栏中的可用 Mercurial 命令:</p>
<table >
<tr>
<th class="tblheader" scope="col">图标</th>
<th class="tblheader" scope="col" style="width:110px">名称</th>
<th class="tblheader" scope="col">功能</th>
</tr>
<tr>
<td class="tbltd0 align-center"><img alt="&quot;refresh status&quot;(刷新状态)图标" src="../../../images_www/articles/73/ide/mercurial/refresh.png"></td>
<td class="tbltd0 align-center"><strong>刷新状态</strong></td>
<td class="tbltd0">刷新选定文件和文件夹的状态。可以刷新 "Versioning"(版本控制)窗口中显示的文件,以反映可能已在外部执行的任何更改。</td>
</tr>
<tr>
<td class="tbltd1 align-center"><img alt="&quot;Diff all&quot;(全部比较)图标" src="../../../images_www/articles/73/ide/mercurial/diff.png"></td>
<td class="tbltd1 align-center"><strong>全部比较</strong></td>
<td class="tbltd1">打开比较查看器,您可以用它对本地副本和资源库中保留的版本进行并排比较。</td>
</tr>
<tr>
<td class="tbltd0 align-center"><img alt="&quot;update all&quot;(全部更新)图标" src="../../../images_www/articles/73/ide/mercurial/update.png"></td>
<td class="tbltd0 align-center"><strong>全部更新</strong></td>
<td class="tbltd0">更新资源库中的所有选定文件。</td>
</tr>
<tr>
<td class="tbltd1 align-center"><img alt="&quot;Commit all&quot;(全部提交)图标" src="../../../images_www/articles/73/ide/mercurial/commit.png"></td>
<td class="tbltd1 align-center"><strong>全部提交</strong></td>
<td class="tbltd1">用于将本地更改提交到资源库。</td>
</tr>
</table>
<p>您可以在 "Versioning"(版本控制)窗口中访问其他 Mercurial 命令,方法是:选择与修改的文件相对应的表行,然后从右键单击菜单中选择一个命令:</p>
<p class="align-center"><img alt="显示在 &quot;Versioning&quot;(版本控制)窗口中的所选文件上的右键单击菜单" class="b-none margin-around" src="../../../images_www/articles/73/ide/mercurial/versioning-right-click.png"></p>
<p>例如,您可以在文件上执行以下操作:</p>
<table >
<tr>
<td>
<ul>
<li><strong>显示标注</strong>:在源代码编辑器中打开的文件的左旁注中显示作者和修订版本号信息。</li>
</ul></td>
<td class="f-page-cell">
<img alt="显示在源代码编辑器左旁注中的标注" class="b-all" src="../../../images_www/articles/73/ide/mercurial/annotations.png"></td>
</tr>
<tr>
<td>
<ul>
<li><strong>还原修改</strong>:打开 "Revert Modifications"(还原修改)对话框,您可以使用它指定参数,以便将所有本地更改还原到资源库中保留的修订版本。</li>
</ul></td>
<td class="f-page-cell">
<a href="../../../images_www/articles/73/ide/mercurial/search-rev.png" rel="lytebox" title="&quot;Search Revisions&quot;(搜索修订)对话框按照日期列出文件修订版本"> <img alt="&quot;Revert Modifications&quot;(还原修改)对话框" class="b-right b-bottom" src="../../../images_www/articles/73/ide/mercurial/search-rev-small.png"></a></td>
</tr>
</table>
</div>
<a name="comparing"></a>
<h3>比较文件版本</h3>
<p>使用版本控制项目时,比较文件修订版本是一项常见任务。IDE 允许您使用 "Diff"(比较)命令比较修订版本,该命令可以从选定项的右键单击菜单(<tt>Mercurial</tt> > <tt>Diff</tt>(比较)> <tt>Diff To Base</tt>(与 Base 进行比较)或 <tt>Mercurial</tt> > <tt>Diff</tt>(比较)> <tt>Diff To Revision</tt>(与修订版本进行比较))获得,也可以从 "Versioning"(版本控制)窗口获得。在 "Versioning"(版本控制)窗口中,可通过双击列出的文件来执行比较;否则,可单击顶部工具栏中的 "Diff All"(全部比较)图标 (<img alt="&quot;Diff all&quot;(全部比较)图标" src="../../../images_www/articles/73/ide/mercurial/diff.png">)。</p>
<p>进行比较时,将在 IDE 的主窗口中打开选定文件和修订版本的图形化比较查看器。比较查看器在两个并行面板中显示两个副本。较新的副本显示在右侧,因此,如果要将资源库修订版本与工作副本进行比较,则在右面板中显示工作副本:</p>
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/diff-viewer.png" rel="lytebox" title="Mercurial 比较查看器"> <img alt="Mercurial 比较查看器" class="b-all margin-around" src="../../../images_www/articles/73/ide/mercurial/diff-viewer-small.png"></a></p>
<p>比较查看器使用<a href="#viewingChanges">颜色编码</a>来显示版本控制更改,该颜色编码与其他地方使用的颜色编码相同。在上面显示的屏幕快照中,绿色块指示已添加到较新修订版本中的内容。红色块指示从较新修订版本中删除了以前的修订内容。蓝色指示在突出显示的行中发的更改。</p>
<p>此外,当对一组文件(例如,项目、包或文件夹)执行比较时,或者当单击 "Diff All"(全部比较)(<img alt="&quot;Diff all&quot;(全部比较)图标" src="../../../images_www/articles/73/ide/mercurial/diff.png">) 时,可在各比较之间进行切换,只需单击比较查看器上方区域中列出的文件即可。</p>
<p>比较查看器还为您提供了以下功能:</p>
<ul>
<li><a href="#makeChanges">对本地工作副本进行更改</a></li>
<li><a href="#navigateDifferences">在差异之间导航</a></li>
</ul>
<div class="indent">
<a name="makeChanges"></a>
<h4>对本地工作副本进行更改</h4>
<p>如果要对本地工作副本进行比较,IDE 允许您从比较查看器中直接进行更改。为此,可以将光标放在比较查看器的右侧窗格中,并且相应地修改文件,也可以每个突出显示的更改旁边的内联图标:</p>
<table>
<tr>
<td class="align-right cell" style="width:120px"><strong>Replace</strong>(替换)(<img alt="&quot;replace&quot;(替换)图标" src="../../../images_www/articles/73/ide/mercurial/insert.png">):</td>
<td>将突出显示的文本从上一修订版本插入当前修订版本中</td>
</tr>
<tr>
<td class="align-right cell" style="width:120px"><strong>Move All</strong>(全部移动)(<img alt="&quot;move all&quot;(全部移动)图标" src="../../../images_www/articles/73/ide/mercurial/arrow.png">):</td>
<td>将文件的当前修订版本还原到上一个选定修订版本的状态</td>
</tr>
<tr>
<td class="align-right cell" style="width:120px"><strong>Remove</strong>(删除)(<img alt="&quot;Remove&quot;(删除)图标" src="../../../images_www/articles/73/ide/mercurial/remove.png">):</td>
<td>从当前版本中删除突出显示的文本,使之与先前版本完全匹配。</td>
</tr>
</table>
<a name="navigateDifferences"></a>
<h4>在比较文件之间的差异中导航</h4>
<p>如果您的比较中包含多个差异,则可以使用工具栏中的箭头图标在它们之间导航。箭头图标可用于查看从上到下列出的差异:</p>
<table>
<tr>
<td class="align-right cell" style="width:120px"><strong>Previous</strong>(上一个)(<img alt="&quot;Previous difference&quot;(上一个差异)按钮" src="../../../images_www/articles/73/ide/mercurial/diff-prev.png">):</td>
<td>转至比较中显示的上一个差异</td>
</tr>
<tr>
<td class="align-right cell" style="width:120px"><strong>Next</strong>(下一个)(<img alt="&quot;Next difference&quot;(下一个差异)按钮" src="../../../images_www/articles/73/ide/mercurial/diff-next.png">):</td>
<td>转至比较中显示的下一个差异</td>
</tr>
</table>
</div>
<a name="merging"></a>
<h3>合并文件修订版本</h3>
<p>通过 NetBeans IDE,可将资源库修订版本之间的更改与本地工作副本合并。具体而言,这样可将资源库中的两个单独的更改集合并成一个描述其合并方式的新更改集。</p>
<ol>
<li>在 "Projects"(项目)、"Files"(文件)或 "Favorites"(收藏夹)窗口中,右键单击要执行合并操作的文件或文件夹,然后选择 <tt>Mercurial</tt> > <tt>Branch/Tag</tt>(分支/标记)> <tt>Merge Changes</tt>(合并更改)。此时将显示 "Merge with Revision"(合并修订)对话框。</li>
<li>在 "Choose From Revisions"(从修订版本中选择)下拉列表中,选择所需的修订版本。此时将移动自本地工作副本文件创建以来对其所做的全部更改。</li>
<li>确保说明、作者和日期数据正确。
<p class="align-center"> <a href="../../../images_www/articles/73/ide/mercurial/mercurial-merge.png" rel="lytebox" title="&quot;Mercurial Merge&quot;(Mercurial 合并)对话框"> <img alt="&quot;Mercurial Merge&quot;(Mercurial 合并)对话框" class="margin-around b-none" src="../../../images_www/articles/73/ide/mercurial/mercurial-merge-small.png"></a></p></li>
<li>单击 "Merge"(合并)。IDE 将在资源库修订版本之间发现的所有差异与本地文件副本进行合并。如果发生合并冲突,则文件的状态会更新为 <a href="#resolving">Merge Conflict</a>(合并冲突),以说明这一情况。</li>
</ol>
<p><strong class="notes">注:</strong>将修订版本合并到本地工作副本后,仍须使用 "Commit"(提交)命令提交更改,以便将它们添加到资源库中。</p>
</div>
<a name="committing"></a>
<h2>将源文件提交到资源库</h2>
<p>对源进行更改后,可以将其提交到资源库。通常,最好对照资源库更新现有的所有副本,然后再执行提交,以便确保不会出现冲突。然而,当多名开发者同时处理项目时,可能会发生冲突,这应该属于正常现象。IDE 提供了灵活的支持,让您可以执行所有这些功能。此外,还提供了冲突解决程序,用于安全地处理发生的任何冲突。</p>
<ul>
<li><a href="#updating">更新本地副本</a></li>
<li><a href="#performing">执行提交</a></li>
<li><a href="#issues">更新问题</a></li>
<li><a href="#pushing">将本地更改推入共享资源库</a></li>
</ul>
<div class="indent">
<a name="updating"></a>
<h3>更新本地副本</h3>
<p>您可以从主菜单中选择<tt>团队开发</tt> > <tt>更新</tt>,以执行更新。</p>
<p>要对已修改的源执行更新,可以单击“全部更新”图标 (<img alt="&quot;Update all&quot;(全部更新)图标" src="../../../images_www/articles/73/ide/mercurial/update.png">),该图标显示在位于<a href="#versioning">“版本控制”窗口</a><a href="#comparing">比较查看器</a>顶部的工具栏中。资源库中可能进行的任何更改显示在“版本控制输出”窗口中。</p>
<a name="comitting"></a>
<h3>执行提交</h3>
<p>编辑源文件、执行更新并解决所有冲突后,您可以将文件从本地工作副本提交到资源库。IDE 允许通过以下方式调用提交命令:</p>
<ul>
<li>在 "Projects"(项目)、"Files"(文件)或 "Favorites"(收藏夹)窗口中,右键单击新的或修改的项,然后选择 <tt>Mercurial</tt> > <tt>Commit</tt>(提交)。</li>
<li>从 "Versioning"(版本控制)窗口或比较查看器中,单击位于工具栏中的 "Commit All"(全部提交)(<img alt="&quot;Commit all&quot;(全部提交)图标" src="../../../images_www/articles/73/ide/mercurial/commit.png">) 按钮。</li>
</ul>
<p>此时将打开 "Commit"(提交)对话框,其中显示要提交到资源库的文件:</p>
<p class="align-center"><a href="../../../images_www/articles/73/ide/mercurial/mercurial-commit-dialog.png" rel="lytebox" title="显示将要提交的文件的 &quot;Commit&quot;(提交)对话框"> <img alt="显示将要提交的文件的 &quot;Commit&quot;(提交)对话框" class="b-none margin-around" src="../../../images_www/articles/73/ide/mercurial/mercurial-commit-dialog-small.png"></a></p>
<p>"Commit"(提交)对话框将列出以下内容:</p>
<ul>
<li>本地修改的所有文件</li>
<li>本地删除的所有文件</li>
<li>所有新文件(即,尚未包含在资源库中的文件)</li>
<li>已重命名的所有文件。Mercurial 可通过删除原始文件并使用新名称创建副本来处理重命名的文件。</li>
</ul>
<p>在 "Commit"(提交)对话框中,可以指定是否从提交中排除个别文件。为此,可以单击选定文件的 "Commit Action"(提交操作)列,并从下拉列表中选择 "Exclude from Commit"(从提交中排除)。</p>
<p>执行提交:</p>
<ol>
<li>在 "Commit Message"(提交消息)文本区域中键入提交消息。或者,单击右上角的 "Recent Messages"(近期的消息)(<img alt="&quot;Recent Messages&quot;(近期的消息)图标" src="../../../images_www/articles/73/ide/mercurial/recent-msgs.png">) 图标,以便在以前使用过的消息列表中进行查看和选择。</li>
<li>指定各个文件的操作后,单击 "Commit"(提交)。IDE 将执行提交操作,并将本地更改发送到资源库中。在执行提交操作时,将在界面右下方显示 IDE 的状态栏。成功提交后,版本控制标记会在 "Projects"(项目)、"Files"(文件)或 "Favorites"(收藏夹)窗口中消失,并且提交文件中的颜色编码会变回黑色。</li>
</ol>
<a name="issues"></a>
<h3>更新问题</h3>
<p>通过将提交操作与资源库的问题跟踪器中现有的问题相关联,可以更新问题。为此,请在“提交”对话框中单击“更新问题”标题将其展开,然后指定以下选项:</p>
<ul>
<li><strong>问题跟踪器:</strong>通过从下拉列表中选择问题跟踪器,可指定资源库使用的问题跟踪器。下拉列表为您提供了注册到 IDE 中的所有问题跟踪器。如果未注册资源库的问题跟踪器,请单击“新建”按钮对其进行注册。</li>
<li><strong>问题:</strong>指定问题 ID。为此,可以键入 ID 或描述的一部分。</li>
</ul>
<p>此外,还可以指定以下选项:</p>
<ul><li><strong>解析为 FIXED:</strong>选择此选项时,问题的状态将标记为“已解决”。</li>
<li><strong>从上方添加提交消息:</strong>选择此选项时,将向问题中添加提交消息。</li>
<li><strong>在问题中添加修订信息:</strong>选择此选项时,将更新问题,以包括修订版本信息,如作者和日期等。您可以单击“更改格式”,以修改添加到问题中的修订版本信息的格式。</li>
<li><strong>在提交消息中添加问题信息:</strong>选择此选项时,将向提交消息中添加问题 ID 和概要。您可以单击“更改格式”,以修改添加到消息中的问题信息的格式。</li>
<li><strong>提交后:</strong>选择此选项时,将在提交更改后更新问题。</li>
<li><strong>推入后</strong>:选择此选项时,只有将更改推入资源库后才更新问题。</li></ul>
<a name="pushing"></a>
<h3>将本地更改推入共享资源库</h3>
<p>推入在本地提交到共享资源库的更改之前,需要将本地资源库与共享资源库保持同步。要使用 Fetch 命令完成此操作,请从主菜单中选择<tt>团队开发</tt> > (<tt>Mercurial</tt> >) <tt>远程</tt> > <tt>获取</tt>。成功执行 Fetch 之后,本地资源库将会与共享资源库保持同步。</p>
<p>要推入更改,请从主菜单中选择<tt>团队开发</tt> > (<tt>Mercurial</tt> >) <tt>远程</tt> > <tt>推入当前分支</tt><tt>团队开发</tt> > (<tt>Mercurial</tt> >) <tt>远程</tt> > <tt>推入所有分支</tt><tt>团队开发</tt> > (<tt>Mercurial</tt> >) <tt>远程</tt> > <tt>推入</tt>。成功执行 Push 之后,输出将列出创建的所有更改集。</p>
<p class="notes"><b>注:</b>由于系统上保留着整个资源库的副本,因此,一般的做法是多次提交到本地资源库,并且只有在完成特定任务后,才推入至共享资源库。</p>
</div>
<a name="summary"></a>
<h2>小结</h2>
<p>本教程通过指导您完成使用 IDE 的 Mercurial 支持的标准工作流,介绍了如何在 IDE 中执行基本版本控制任务。它还介绍了如何设置版本控制项目以及如何对版本控制文件执行基本任务,同时简要说明了 IDE 中包含的一些特定于 Mercurial 的功能。</p>
<div class="feedback-box">
<a href="/about/contact_form.html?to=3&amp;subject=Feedback:%20Using%20Mercurial%20Support%20in%20NetBeans%20IDE">发送有关此教程的反馈意见</a></div>
<br style="clear:both;">
<a name="seeAlso"></a>
<h2>另请参见</h2>
<p>相关资料请参见以下文档:</p>
<ul>
<li><a href="http://wiki.netbeans.org/HgNetBeansSources">在 IDE 中使用 Mercurial 处理 NetBeans 源</a></li>
<li><a href="mercurial-queues.html">在 NetBeans IDE 中使用 Mercurial 队列支持</a></li>
<li>“使用 NetBeans IDE 开发应用程序”中的<a href="http://www.oracle.com/pls/topic/lookup?ctx=nb7400&id=NBDAG234">使用版本控制对应用程序进行版本控制</a></a></li>
</ul>
</body>
</html>