summaryrefslogtreecommitdiffstats
path: root/doc/en/merging.html
diff options
context:
space:
mode:
Diffstat (limited to 'doc/en/merging.html')
-rw-r--r--doc/en/merging.html195
1 files changed, 195 insertions, 0 deletions
diff --git a/doc/en/merging.html b/doc/en/merging.html
new file mode 100644
index 0000000..7331292
--- /dev/null
+++ b/doc/en/merging.html
@@ -0,0 +1,195 @@
+<html><head><title>Merging And The Merge Output Editor Window</title><link rel="stylesheet" href="help:/common/kde-default.css" type="text/css"><meta name="generator" content="DocBook XSL Stylesheets V1.67.2"><meta name="keywords" content="KDE, kdeextragear, kdiff3, diff, merge, CVS, triplediff, compare, files, directories, version control, three-way-merge, in-line-differences, synchronise, kpart, kio, networktransparent, editor, white space, comments"><link rel="start" href="index.html" title="The KDiff3 Handbook"><link rel="up" href="documentation.html" title="Chapter 2. File Comparison And Merge"><link rel="prev" href="interpretinginformation.html" title="Comparing Files And Interpreting The Information In The Input Windows"><link rel="next" href="navigation.html" title="Navigation And Editing"><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><meta name="GENERATOR" content="KDE XSL Stylesheet V1.13 using libxslt"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div style="background-image: url(help:/common/top-middle.png); width: 100%; height: 131px;"><div style="position: absolute; right: 0px;"><img src="help:/common/top-right-konqueror.png" style="margin: 0px" alt=""></div><div style="position: absolute; top: 25px; right: 100px; text-align: right; font-size: xx-large; font-weight: bold; text-shadow: #fff 0px 0px 5px; color: #444">Merging And The Merge Output Editor Window</div></div><div style="margin-top: 20px; background-color: #white; color: black; margin-left: 20px; margin-right: 20px;"><div style="position: absolute; left: 20px;"><a accesskey="p" href="interpretinginformation.html">Prev</a></div><div style="position: absolute; right: 20px;"><a accesskey="n" href="navigation.html">Next</a></div><div class="navCenter">File Comparison And Merge</div></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="merging"></a>Merging And The Merge Output Editor Window</h2></div></div></div><div class="screenshot"><div xmlns:doc="http://nwalsh.com/xsl/documentation/1.0" class="mediaobject"><hr><img src="screenshot_merge.png"><hr></div></div><p>
+ The merge output editor window (below the diff input windows) also has an info line at the top showing "Output:", the
+ filename and "[Modified]" if you edited something. Usually it will contain
+ some text through the automatic merge facilities, but often it will also
+ contain conflicts.
+</p><p>
+ !!! Saving is disabled until all conflicts are resolved !!! (Use the "Go
+ to prev/next unsolved conflicts"-buttons to find the remaining conflicts.)
+</p><p>
+ With only two input files every difference is also a conflict that must
+ be solved manually.
+</p><p>
+ With three input files the first file is treated as base, while the
+ second and third input files contain modifications. When at any line only
+ either input B or input C have changed but not both then the changed source
+ will automatically be selected. Only when B and C have changed on the same
+ lines, then the tool detects a conflict that must be solved manually.
+ When B and C are the same, but not the same as A, then C is selected.
+</p><div class="sect2" lang="en"><div class="titlepage"><div><div><h3 class="title"><a name="id2564630"></a>The Summary Column</h3></div></div></div><p>
+ The merge output editor window also has a summary column on the left. It shows the
+ letter of the input from which a line was selected or nothing if all three
+ sources where equal on a line. For conflicts it shows a questionmark "?"
+ and the line shows "&lt;Merge Conflict&gt;", all in red. Because solving
+ conflicts line by line would take very long, the lines are grouped into
+ groups that have the same difference and conflict characteristics.
+ But only-white-space-conflicts are separated from non-white-space-conflicts
+ in order to ease the merging of files were the indentation changed for many
+ lines.
+</p></div><div class="sect2" lang="en"><div class="titlepage"><div><div><h3 class="title"><a name="synchronise_views"></a>Setting The Current Group And Synchronising Merge And Diff View Position</h3></div></div></div><p>
+ When clicking into the summary column with the left mouse button in either
+ window then the beginning of the group belonging to that line will shown in all windows.
+ This group then becomes the "current group". It is highlighted with the
+ "Current range (diff) background color" and
+ a black bar appears on the left side of the text.
+</p></div><div class="sect2" lang="en"><div class="titlepage"><div><div><h3 class="title"><a name="id2564684"></a>Choosing Inputs A, B or C For Current Conflict And Editing</h3></div></div></div><p>
+ The button bar below the menubar contains three input selector buttons
+ containing the letters "A", "B" and "C". Click the input selector
+ button to insert (or remove if already inserted) the lines from the respective source.
+ To choose the lines from several inputs click the respective buttons in the
+ needed order. For example if you want that the lines from "B" appear before
+ the lines from "A" in the output, first click "B", then "A".
+</p><p>
+ If you use the auto-advance option
+ (<a href="navigation.html#autoadvance" title="Auto-Advance">"Automatically go to next unsolved conflict after source selection"</a>),
+ you should disable this before choosing lines from several inputs or if you want to
+ edit the lines after your choice. Otherwise <span class="application">KDiff3</span> will jump to the next
+ conflict after choosing the first input.
+</p><p>
+ It is often helpful directly edit the merge output.
+ The summary column will show "m" for every line that was manually modified.
+ When for instance the differences are aligned in a way that simply choosing
+ the inputs won't be satisfactory, then you can mark the needed text and use
+ normal <a href="selections.html" title="Select, Copy And Paste">copy and paste</a> to put it into the merge output.
+</p><p>
+ Sometimes, when a line is removed either by automatic merge or by editing
+ and no other lines remain in that group, then the text &lt;No src line&gt;
+ will appear in that line. This is just a placeholder for the group for
+ when you might change your mind and select some source again. This text won't
+ appear in the saved file or in any selections you want to copy and paste.
+</p><p>
+ The text "&lt;Merge Conflict&gt;" will appear in the clipboard if you
+ copy and paste some text containing such a line. But still be careful to
+ do so.
+</p></div><div class="sect2" lang="en"><div class="titlepage"><div><div><h3 class="title"><a name="id2564761"></a>Choosing Input A, B, or C for All Conflicts</h3></div></div></div><p>
+ The normal merge will start by solving simple conflicts automatically.
+ But the "Merge"-menu provides some actions for other common needs.
+ If you have to select the same source for most conflicts, then you can
+ choose "A", "B" or "C" everywhere, or only for the remaining unsolved
+ conflicts, or for unsolved white space conflicts. If you want to decide every
+ single delta yourself, you can "Set deltas to conflicts". Or if you want to
+ return to the automatic choices of <span class="application">KDiff3</span> then select
+ "Automatically solve simple conflicts". <span class="application">KDiff3</span> then restarts the merge.
+ For actions that change your previous modifications <span class="application">KDiff3</span> will ask for your
+ confirmation before proceeding.
+</p><p>
+ Note: When choosing either source for unsolved white space conflicts and
+ the options "Ignore Numbers" or "Ignore C/C++ Comments" are used then changes in
+ numbers or comments will be treated like white space too.
+
+</p></div><div class="sect2" lang="en"><div class="titlepage"><div><div><h3 class="title"><a name="vcskeywordsmergesupport"></a>Automatic Merge of Version Control Keywords and History (Log)</h3></div></div></div><p>
+Many version control systems support special keywords in the file. (e.g. "$Date$",
+"$Header$", "$Author$", "$Log$" etc.) During the
+check-in the version control system (VCS) changes these lines. For instance
+"$Date$" will turn into "$Date: 2005/03/22 18:45:01 $". Since this line will
+be different in every version of the file, it would require manual interaction
+during the merge.
+</p><p>
+<span class="application">KDiff3</span> offers automatic merge for these items. For simple lines that match the
+"Auto merge regular expression"-option in all input-files <span class="application">KDiff3</span> will choose
+the line from B or - if available - from C. (Additionally it is necessary that the lines
+in question line up in the comparison and the previous line contains no conflict.)
+This auto merge can either be run immediately after a merge starts (activate the option
+"Run regular expression auto merge on merge start") or later via the merge
+menu "Run Regular Expression Auto Merge".
+</p><p>
+Automatic merge for version control history (also called "log") is also supported.
+The history automerge can either run immediately when the merge starts by activating the
+option "Merge version control history on merge start" or later via the merge menu
+"Automatically Solve History Conflicts".
+</p><p>
+Usually the version control history begins with a line containing the keyword "$Log$".
+This must be matched by the "History start regular expression"-option.
+<span class="application">KDiff3</span> detects which subsequent lines are in the history by analysing the leading characters
+that came before the "$Log$"-keyword. If the same "leading comment"-characters also appears in the following
+lines, then they are also included in the history.
+</p><p>
+During each check-in the VCS writes a unique line specifying version-, date- and time-information
+followed by lines with user comments.
+These lines form one history-entry. This history section grows with every check-in and the
+most recent entries appear at the top (after the history start line).
+</p><p>
+When for parallel development two or more developers check-in a branch of the file then
+the merge history will contain several entries that appear as conflicts during the merge
+of the branches. Since merging these can become very tedious, <span class="application">KDiff3</span> offers support with two
+possible strategies: Just insert the history information from both contributors at the top
+or sort the history information by a user defined key.
+</p><p>
+The just-insert-all-entries-method is easier to configure. <span class="application">KDiff3</span> just needs a method to
+detect, which lines belong to one history entry. Most VCS insert an empty line after each
+history entry. If there are no other empty lines, this is a sufficient criterion for <span class="application">KDiff3</span>.
+Just set an empty "History entry start regular expression". If the empty line criterion
+isn't sufficient, you can specify a regular expression to detect the history entry start.
+</p><p>
+Note that <span class="application">KDiff3</span> will remove duplicate history entrys. If a history entry appeared several times
+in the history of a input file, only one entry will remain in the output.
+</p><p>
+If you want to sort the history, then you have to specify how the sort key should be built.
+Use parentheses in the "History entry start regular expression" to group parts of the regular
+expression that should later be used for the sort key.
+Then specify the "History entry start sort key order" specifying a comma "," separated list of
+numbers referring to the position of the group in the regular expression.
+</p><p>
+Because this is not so easy to get right immediately, you are able to test and improve
+the regular expressions and key-generation in a dedicated dialog by pressing the
+"Test your regular expressions"-button.
+</p><p>Example: Assume a history that looks like this:
+<pre class="screen">
+/**************************************************************************
+** HISTORY: $Log: \toms_merge_main_view\MyApplication\src\complexalgorithm.cpp $
+**
+** \main\integration_branch_12 2 Apr 2001 10:45:41 tom
+** Merged branch simon_branch_15.
+**
+** \main\henry_bugfix_branch_7\1 30 Mar 2001 19:22:05 henry
+** Improved the speed for subroutine convertToMesh().
+** Fixed crash.
+**************************************************************************/
+</pre>
+The history start line matches the regular expression ".*\$Log.*\$.*". Then follow
+the history entries.
+</p><p>
+The line with the "$Log$"-keyword begins with two "*" after which follows a space.
+<span class="application">KDiff3</span> uses the first non-white-space string as "leading comment" and assumes that
+the history ends in the first line without this leading comment. In this example the
+last line ends with a string that also starts with two "*", but instead of a space
+character more "*" follow. Hence this line ends the history.
+</p><p>
+If history sorting isn't required then the history entry start line regular expression
+could look like this. (This line is split in two because it wouldn't fit otherwise.)
+<pre class="screen">
+\s*\\main\\\S+\s+[0-9]+ (Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)
+ [0-9][0-9][0-9][0-9] [0-9][0-9]:[0-9][0-9]:[0-9][0-9]\s+.*
+</pre>
+For details about regular expressions please see the
+<a href="http://doc.trolltech.com/3.3/qregexp.html#details" target="_top">regular expression documentation by Trolltech</a>.
+Note that "\s" (with lowercase "s") matches any white space and "\S" (with uppercase "S") matches any non-white-space.
+In our example the history entry start contains first the version info with reg. exp. "\\main\\\S+", the date consisting of day "[0-9]+", month "(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)" and year "[0-9][0-9][0-9][0-9]", the time "[0-9][0-9]:[0-9][0-9]:[0-9][0-9]" and finally the developers login name ".*".
+</p><p>
+Note that the "leading comment"-characters (in the example "**") will already be removed by <span class="application">KDiff3</span>
+before trying to match, hence the regular expression begins with a match for none or more white-space characters "\s*".
+Because comment characters can differ in each file (e.g. C/C++ uses other comment characters than a Perl script)
+<span class="application">KDiff3</span> takes care of the leading comment characters and you should not specify them in the regular expression.
+</p><p>
+If you require a sorted history. Then the sortkey must be calculated. For this the
+relevant parts in the regular expression must be grouped by parentheses.
+(The extra parentheses can also stay in if history sorting is disabled.)
+<pre class="screen">
+\s*\\main\\(\S+)\s+([0-9]+) (Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)
+ ([0-9][0-9][0-9][0-9]) ([0-9][0-9]:[0-9][0-9]:[0-9][0-9])\s+(.*)
+</pre>
+The parentheses now contain 1. version info, 2. day, 3. month, 4. year, 5. time, 6. name.
+But if we want to sort by date and time, we need to construct a key with the elements in a different order of appearance:
+First the year, followed by month, day, time, version info and name. Hence the sortkey order to specify is "4,3,2,5,1,6".
+</p><p>
+Because month names aren't good for sorting ("Apr" would be first) <span class="application">KDiff3</span> detects in which order
+the month names were given and uses that number instead ("Apr"-&gt;"04").
+And if a pure number is found it will be transformed to a 4-digit value with leading zeros for sorting.
+Finally the resulting sort key for the first history entry start line will be:
+<pre class="screen">
+2001 04 0002 10:45:41 integration_branch_12 tom
+</pre>
+</p><p>
+For more information also see <a href="options.html#mergeoptions" title="Merge Settings">Merge Settings</a>.
+</p></div></div><div style="background-color: #white; color: black; margin-top: 20px; margin-left: 20px; margin-right: 20px;"><div style="position: absolute; left: 20px;"><a accesskey="p" href="interpretinginformation.html">Prev</a></div><div style="position: absolute; right: 20px;"><a accesskey="n" href="navigation.html">Next</a></div><div align="center"><a accesskey="h" href="index.html">Home</a></div></div><div style="background-color: #white; color: black; margin-left: 20px; margin-right: 20px;"><div class="navLeft">Comparing Files And Interpreting The Information In The Input Windows </div><div class="navRight"> Navigation And Editing</div><div class="navCenter"><a accesskey="u" href="documentation.html">Up</a></div></div><br><br><div class="bannerBottom" style="background-image: url(help:/common/bottom-middle.png); background-repeat: x-repeat; width: 100%; height: 100px; bottom:0px;"><div class="BannerBottomRight"><img src="help:/common/bottom-right.png" style="margin: 0px" alt=""></div><div class="bannerBottomLeft"><img src="help:/common/bottom-left.png" style="margin: 0px;" alt=""></div><div id="comments" style="position:relative; top: 5px; left: 1em; height:85px; width: 50%; color: #cfe1f6"><p>Would you like to make a comment or contribute an update to this page?<br>
+ Send feedback to the <a href="mailto:kde-docs@kdemail.net" style="background:transparent; color:#cfe1f6; text-decoration: underline;">KDE Docs Team</a></p></div></div></body></html> \ No newline at end of file