diff options
Diffstat (limited to 'doc/en/merging.html')
-rw-r--r-- | doc/en/merging.html | 195 |
1 files changed, 0 insertions, 195 deletions
diff --git a/doc/en/merging.html b/doc/en/merging.html deleted file mode 100644 index fab4a3b..0000000 --- a/doc/en/merging.html +++ /dev/null @@ -1,195 +0,0 @@ -<html><head><title>Merging And The Merge Output Editor Window</title><link rel="stylesheet" href="help:/common/tde-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, tdeio, 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 "<Merge Conflict>", 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 <No src line> - 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 "<Merge Conflict>" 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"->"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 |