1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473
2474
2475
2476
2477
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627
2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
2929
2930
2931
2932
2933
2934
2935
2936
|
<?xml version="1.0" ?>
<!DOCTYPE book PUBLIC "-//KDE//DTD DocBook XML V4.2-Based Variant V1.1//EN" "dtd/kdex.dtd" [
<!ENTITY kdiff3 "<application
>KDiff3</application
>">
<!ENTITY kappname "&kdiff3;">
<!ENTITY package "extragear-utils">
<!ENTITY % addindex "IGNORE">
<!ENTITY % Spanish "INCLUDE">
]>
<book lang="&language;">
<!-- This header contains all of the meta-information for the document such
as Authors, publish date, the abstract, and Keywords -->
<bookinfo>
<title
>El manual de &kdiff3;</title>
<authorgroup>
<author
><firstname
>Joachim</firstname
> <surname
>Eibl</surname
> <affiliation
><address
> <email
>joachim.eibl at gmx.de</email>
</address
></affiliation>
</author>
<othercredit role="translator"
> <firstname
>Santiago</firstname
> <surname
>Fernández Sancho</surname
> <affiliation
><address
><email
>santi@kde-es.org</email
></address
></affiliation
> <contrib
>Traductor</contrib
> </othercredit
>
</authorgroup>
<copyright>
<year
>2002-2006</year>
<holder
>Joachim Eibl</holder>
</copyright>
<!-- Translators: put here the copyright notice of the translation -->
<!-- Put here the FDL notice. Read the explanation in fdl-notice.docbook
and in the FDL itself on how to use it. -->
<legalnotice
>&FDLNotice;</legalnotice>
<!-- Date and version information of the documentation
Don't forget to include this last date and this last revision number, we
need them for translation coordination !
Please respect the format of the date (YYYY-MM-DD) and of the version
(V.MM.LL), it could be used by automation scripts.
Do NOT change these in the translation. -->
<date
>2006-04-09</date>
<releaseinfo
>0.9.89</releaseinfo>
<abstract>
<para
>&kdiff3; es una herramienta para ver diferencias y fusionar archivos y directorios que: <itemizedlist>
<listitem
><para
>Compara y fusiona dos o tres archivos o directorios de texto.</para
></listitem>
<listitem
><para
>Muestra las diferencias línea a línea y caracter a caracter (!).</para
></listitem>
<listitem
><para
>Proporciona una utilidad de fusión automática.</para
></listitem>
<listitem
><para
>Tiene un editor para resolver de forma cómoda los conflictos de fusión.</para
></listitem>
<listitem
><para
>Proporciona transparencia de red a través de TDEIO.</para
></listitem>
<listitem
><para
>Tiene opciones para resaltar u ocultar los cambios en los espacios en blanco o en los comentarios.</para
></listitem>
<listitem
><para
>Soporta Unicode, UTF-8 y otras codificaciones de archivo.</para
></listitem>
<listitem
><para
>Imprime diferencias.</para
></listitem>
<listitem
><para
>Soporta claves de control de versiones e historial de fusionado.</para
></listitem>
</itemizedlist>
</para
><para
>Este documento describe la versión 0.9.89 de &kdiff3;. </para>
</abstract>
<!-- This is a set of Keywords for indexing by search engines.
Please at least include KDE, the KDE package it is in, the name
of your application, and a few relevant keywords. -->
<keywordset>
<keyword
>KDE</keyword>
<keyword
>kdeextragear</keyword>
<keyword
>kdiff3</keyword>
<keyword
>diferencia</keyword>
<keyword
>fusión</keyword>
<keyword
>CVS</keyword>
<keyword
>triple diferencia</keyword>
<keyword
>comparar</keyword>
<keyword
>archivos</keyword>
<keyword
>directorios</keyword>
<keyword
>control de versiones</keyword>
<keyword
>fusión del árbol</keyword>
<keyword
>diferencias en línea</keyword>
<keyword
>sincronización</keyword>
<keyword
>kpart</keyword>
<keyword
>tdeio</keyword>
<keyword
>transparencia de red</keyword>
<keyword
>editor</keyword>
<keyword
>espacio en blanco</keyword>
<keyword
>comentarios</keyword>
</keywordset>
</bookinfo>
<chapter id="introduction"
><title
>Introducción</title>
<sect1 id="why"
><title
>¿Otro interfaz para diff?</title>
<para
>Ya existen varias herramientas gráficas para diff. ¿Por qué elegir &kdiff3;? Déjeme decirle por qué lo escribí. </para
><para
>&kdiff3; se inició debido a la dificultad para hacer la fusión. La fusión es necesaria cuando varias personas trabajan sobre los mismos archivos en un proyecto. Una fusión puede ser algo automatizado, cuando la herramienta de fusionado no solo tiene nuevos archivos modificados (llamados «ramas»), sino también el archivo original (llamado «base»). La herramienta de fusionado seleccionará automáticamente cualquier modificación que se haga solo en una rama. Cuando varios colaboradores cambian la misma línea, la herramienta detecta un conflicto que deberá resolverse manualmente. </para
><para
>El fusionado se vuelve difícil porque, por ejemplo, un colaborador cambió muchas cosas y corrigió el sangrado en algunos lugares. Otro colaborador también cambió mucho texto en el mismo archivo, y todo esto dió como resultado varios conflictos durante la fusión. </para
><para
>La herramienta que utilizaba, solo mostraba las líneas cambiadas, pero no los cambios hechos en estas líneas. Y no había información sobre los cambios en el sangrado. La fusión era una pequeña pesadilla. </para
><para
>Por eso empecé. La primera versión podía mostrar las diferencias en un línea y las diferencias en los espacios en blanco. Después se añadieron otras características para incrementar la utilidad. </para
><para
>Por ejemplo, si desea comparar algún texto rápidamente, podrá copiarlo al portapapeles y pegarlo en otra ventana de diff. </para
><para
>Una característica que requería un enorme esfuerzo era la capacidad de comparar y fusionar directorios, que convirtió el programa en un navegador de archivos completo. </para
><para
>Espero que &kdiff3; le funcione también. ¡Diviértase! </para
><para
>Joachim Eibl (2003) </para>
</sect1>
<sect1 id="screenshots"
><title
>Capturas de pantalla y características</title>
<para
>Esta captura de pantalla muestra la diferencia entre dos archivos de texto.</para>
<para
>(Utilizando una versión temprana de &kdiff3;):</para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<para
>Existe 3 formas de fusión totalmente soportados. Es práctico si dos personas modifican código de forma independiente. El archivo original (la base) se utiliza para ayudar a &kdiff3; para seleccionar automáticamente los cambios correctos. El editor de fusión bajo la ventana de diferencias le permite resolver los conflictos, a la vez que le muestra la salida. También podrá editar la salida. Esta captura de pantalla muestra tres archivos de entrada que se pueden fusionar: </para
><para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_merge.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</para>
<para id="dirmergebigscreenshot"
>&kdiff3; también le ayuda a comparar y fusionar directorios completos. Esta captura muestra &kdiff3; durante la fusión de un directorio: </para
><para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="dirmergebig.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</para>
</sect1>
<sect1 id="features"
><title
>Más características</title>
<sect2
><title
>Visor de diferencias línea a línea y caracter a caracter</title>
<para
>Utilizando las posibilidades que permite una pantalla gráfica a color &kdiff3; muestra exactamente cuál es la diferencia. Cuando haga algunas revisiones de código, obtendrá algo como ésto. </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="letter_by_letter.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>
<sect2
><title
>Ver diferencias de espacios en blanco de un vistazo</title>
<para
>Los espacios y tabulaciones que difieren se muestran visiblemente. Cuando las líneas difieren solo en la cantidad de espacios en blanco puede verse de un vistazo en la columna resumen en la parte izquierda (no más preocupaciones cuando se hagan cambios en el sangrado). </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="white_space.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>
<sect2
><title
>Triple diferencia</title>
<para
>Analiza tres archivos y ve dónde está la diferencia. </para
><para
>Las ventanas izquierda/central/derecha se llamarán A/B/C y tendrán los colores azul/verde/gris respectivamente. </para
><para
>Si un archivo es igual y el otro es diferente en una línea, el color mostrado en el archivo será diferente. El color rojo significa que ambos archivos son diferentes. </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="triple_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>
<sect2
><title
>Fusión cómoda de dos o tres archivos de entrada</title>
<para
>&kdiff3; puede utilizarse para fusionar dos o tres archivos de entrada y hacer la fusión todo lo automática que sea posible. El resultado se presentará en una ventana editable donde se podrán resolver la mayor parte de los conflictos con una pulsación de ratón: Seleccione los botones A/B/C de la barra de botones para seleccionar la fuente que se utilizará. También podrá seleccionar más de una fuente. Como la ventana de salida es un editor aunque los conflictos puedan necesitar correcciones más profundas, éste hecho puede resolverse aquí sin ninguna herramienta adicional. </para>
</sect2>
<sect2
><title
>Y ...</title>
<itemizedlist>
<listitem
><para
>Navegación rápida a través de los botones.</para
></listitem>
<listitem
><para
>Una pulsación del ratón en la columna resumen sincronizará todas las ventanas para mostrar la misma posición.</para
></listitem>
<listitem
><para
>Seleccione una copia desde cualquier ventana y péguela en la ventana de fusión del resultado.</para
></listitem>
<listitem
><para
>Columna de vista general que muestra los cambios y conflictos.</para
></listitem>
<listitem
><para
>Los colores pueden ajustarse a sus preferencias.</para
></listitem>
<listitem
><para
>Tamaño de pestaña ajustable.</para
></listitem>
<listitem
><para
>Opción de insertar espacios en lugar de tabuladores.</para
></listitem>
<listitem
><para
>Abrir archivos cómodamente a través de un diálogo o especificando archivos en la línea de órdenes.</para
></listitem>
<listitem
><para
>Buscar cadenas en todas las ventanas de texto. Buscar (Ctrl-F) y Buscar siguiente (F3).</para
></listitem>
<listitem
><para
>Mostrar los números de línea. </para
></listitem>
<listitem
><para
>Pegar el portapapeles y arrastrar texto a una ventana de diferencias.</para
></listitem>
<listitem
><para
>Transferencia de red a través de TDEIO.</para
></listitem>
<listitem
><para
>Puede utilizarse como visor de diff en KDevelop 3.</para
></listitem>
<listitem
><para
>Ajuste de línea para las líneas largas.</para
></listitem>
<listitem
><para
>Soporte para Unicode, UTF-8 y otras codificaciones.</para
></listitem>
<listitem
><para
>Soporte para idiomas que van de derecha a izquierda.</para
></listitem>
<listitem
><para
>...</para
></listitem>
</itemizedlist>
</sect2>
</sect1>
</chapter>
<chapter id="documentation"
><title
>Comparación y fusión de archivos</title>
<sect1 id="commandline"
><title
>Opciones de la línea de órdenes</title>
<sect2
><title
>Comparar 2 archivos: </title>
<screen
><command
>kdiff3</command
> <replaceable
>archivo1 archivo2</replaceable
>
</screen>
</sect2>
<sect2
><title
>Fusionar 2 archivos: </title>
<screen
><command
>kdiff3</command
> <replaceable
>archivo1 archivo2</replaceable
> -m
<command
>kdiff3</command
> <replaceable
>archivo1 archivo2</replaceable
> -o <replaceable
>archivosalida</replaceable
>
</screen>
</sect2>
<sect2
><title
>Comparar 3 archivos: </title>
<screen
><command
>kdiff3</command
> <replaceable
>archivo1 archivo2 archivo3</replaceable
>
</screen>
</sect2>
<sect2
><title
>Fusionar 3 archivos: </title>
<screen
><command
>kdiff3</command
> <replaceable
>archivo1 archivo2 archivo3</replaceable
> -m
<command
>kdiff3</command
> <replaceable
>archivo1 archivo2 archivo3</replaceable
> -o <replaceable
>archivosalida</replaceable
>
</screen>
<para
>Tenga en cuenta que <replaceable
>archivo1</replaceable
> será tratado como base de <replaceable
>archivo2</replaceable
> y <replaceable
>archivo3</replaceable
>. </para>
</sect2>
<sect2
><title
>Caso especial: Archivos con el mismo nombre </title>
<para
>Si todos los archivos tienen el mismo nombre pero están en directorios diferentes, puede reducir el tipo de trabajo especificando el nombre del archivo sólo para el primer archivo. P.ej.: </para>
<screen
><command
>kdiff3</command
> <replaceable
>directorio1/nombrearchivo directorio2 directorio3</replaceable
>
</screen>
</sect2>
<sect2
><title
>Línea de órdenes para iniciar la comparación o fusión de un directorio: </title>
<para
>Es muy similar, pero ahora sobre directorios.</para>
<screen
><command
>kdiff3</command
> <replaceable
>directorio1 directorio2</replaceable>
<command
>kdiff3</command
> <replaceable
>directorio1 directorio2</replaceable
> -o <replaceable
>directoriodestino</replaceable>
<command
>kdiff3</command
> <replaceable
>directorio1 directorio2 directorio3</replaceable>
<command
>kdiff3</command
> <replaceable
>directorio1 directorio2 directorio3</replaceable
> -o <replaceable
>directoriodestino</replaceable
>
</screen>
<para
>Para la comparación y fusión de directorios puede continuar leyendo <link linkend="dirmerge"
>aquí</link
>.</para>
</sect2>
<sect2
><title
>Opciones de la línea de órdenes</title>
<para
>Para obtener más información sobre las opciones de la línea de órdenes utilice:</para>
<screen
><command
>kdiff3</command
> --help
</screen>
<para
>Ejemplo de salida:</para>
<screen
>Opciones:
-m, --merge Fusiona la entrada.
-b, --base archivo Archivo base explícito. Por compatibilidad con ciertas herramientas.
-o, --output archivo Archivo de salida. Supone -m. Ejem.: -o nuevoarchivo.txt
--out archivo Archivo de salida, de nuevo. (Por compatibilidad con ciertas herramientas.)
--auto Sin interfaz si todos los conflictos se resuelven de forma automática. (Necesita -o archivo)
--qall No resuelve los conflictos automáticamete. (Por compatibilidad...)
--L1 alias1 Reemplazo de nombre visible para la entrada del archivo 1 (base).
--L2 alias2 Reemplazo de nombre visible para la entrada del archivo 2.
--L3 alias3 Reemplazo de nombre visible para la entrada del archivo 3.
-L, --fname alias Reemplazo de nombre visible alternativo. Proporcione éste una vez para cada entrada.
--cs string Sobreescribe la configuración. Utilícelo una vez para cada opción. P.ej.: --cs "AutoAdvance=1"
--confighelp Muestra la lista de las opciones de configuración y sus valores actuales.
--config file Utiliza un archivo de configuración diferente.
</screen>
<para
>La opción <option
>--cs</option
> le permite ajustar un valor de configuración que de otra forma solo sería ajustable a través del diálogo de configuración. Pero asegúrese de que cuando &kdiff3; finalice se guarden los valores con las configuraciones nuevas. Con <option
>--confighelp</option
> puede encontrar los nombres de los elementos disponibles y los valores actuales.</para>
<para
>A través de <option
>--config</option
> puede especificar un archivo de configuración diferente. Cuando utilice con frecuencia diferentes configuraciones para &kdiff3; ésto le permitirá cambiar entre ellas.</para>
</sect2>
<sect2
><title
>Opciones de la línea de órdenes que se ignoran</title>
<para
>Mucha gente quiere utilizar &kdiff3; con algún sistema de control de versiones. Pero cuando el sistema de control de versiones llama a &kdiff3; utilizando los parámetros de la línea de órdenes &kdiff3; no los reconoce, y termina con un error. Las preferencias de integración le permiten especificar los parámetros de línea de órdenes que &kdiff3; debería ignorar. Aparecerán en la ayuda de uso, de forma similar a este ejemplo:</para>
<screen
>--<replaceable
>foo</replaceable
> Ignored. (Definida por el usuario.)
</screen>
<variablelist>
<varlistentry
><term
><emphasis
>Opciones de la línea de órdenes a ignorar:</emphasis
></term
><listitem
><para
>Una lista de opciones separadas por punto y coma «;». Cuando aparezca una de estas opciones en una línea de órdenes, &kdiff3; la ignorará y se ejecutará sin informar de ningún error (el valor predeterminado es «u;query;html;abort»).</para
></listitem
></varlistentry>
</variablelist>
<para
>Si ésto no es suficiente, se recomienda escribir un script para el intérprete de órdenes que traduzcan esta opción.</para>
</sect2>
</sect1>
<sect1 id="opendialog"
><title
>Diálogo abrir</title>
<para
>Como se pueden seleccionar varios archivos de entrada, el programa tiene un diálogo de apertura especial: </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="open_dialog.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<para
>El diálogo abrir le permite editar los nombres de los archivos manualmente, seleccionando un archivo a través del navegador de archivos («Archivo...») o permitir la elección de los archivos recientes a través de las listas desplegables. Si abre el diálogo nuevamente, el nombre actual continúa ahí. El tercer archivo de entrada no es necesario. si la entrada para «C» permanece vacía, solo se efectuará el análisis de diferencia de dos archivos. </para
><para
>Puede seleccionar un directorio a través de «Dir...». Si se especifica un directorio para A entonces comienza la comparación/fusión de directorios. Si en A especifica un archivo pero en B,C o en la salida se especifica un directorio, &kdiff3; utiliza el nombre del archivo de A en los directorios especificados. </para
><para
>Si está seleccionado «Fusionar», la línea de «Salida» será editable. Pero no se necesita especificar el nombre de archivo de salida de forma inmediata. Puede postponerlo hasta que lo guarde. </para
><para
>El botón «Configurar...» abre el diálogo de opciones, de forma que pueda seleccionar las opciones antes de realizar el análisis. </para>
</sect1>
<sect1 id="pasteinput"
><title
>Pegar y soltar la entrada</title>
<para
>Algunas veces deseará comparar partes de un texto que no sea propiamente un archivo. &kdiff3; también le permite pegar texto desde el portapapeles a la ventana de entrada de diff que tenga el foco. El análisis de las diferencias se producirá inmediatamente. En el diálogo abrir no necesitará especificar archivos entonces, ciérrelo con el botón «Cancelar». </para
><para
>También podrá utilizar arrastrar y soltar: Arrastre un archivo desde un administrador de archivos o seleccione texto en un editor y arrástrelo a la ventana de entrada. </para
><para
>¿Cuál es la idea? Algunas veces un archivo contiene dos funciones similares, pero comprobar las similitudes es un esfuerzo enorme si primero debe crear los archivos y luego cargarlos. Ahora bastará con copiar, pegar y comparar las secciones relevantes. </para
><para
>Nota: En estos momentos no podrá arrastrar nada desde &kdiff3;. Solo está soportado en la ventana de entrada diff. </para
><para
>Aviso: Algunos editores todavía interpretan arrastrar y soltar en otro programa como cortar (en lugar de copiar) y pegar. En este caso sus datos originales se perderían. </para>
</sect1>
<sect1 id="interpretinginformation"
><title
>Interpretar la información en las ventanas de entrada</title>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<sect2
><title
>Línea de información</title
><para
>En la parte superior de cada ventana de texto se encuentra la «línea de información». Las líneas de información de las ventanas de entrada contienen una letra «A», «B» y «C», el nombre del archivo, un botón para el navegador, y el número de línea de la primera línea visible en la ventana (recuerde que la ventana «C» es opcional). Cada línea de información aparecerá con un color diferente. </para
><para
>Cuando selecciona otro archivo a través del navegador o termina de editar el nombre del archivo pulsando entrar, el nuevo archivo se cargará y se comparará con el(los) archivo(s) que ya estaba(n) cargado(s). </para
></sect2
><sect2
><title
>Coloreado</title
><para
>Las tres ventanas de entrada tienen asignadas las letras «A», «B» y «C». «A» tiene color azul, «B» verde y «C» magenta (estos son los valores predeterminados, pero puede cambiarlos en el menú Preferencias). </para
><para
>Cuando se detecta una diferencia el color mostrado en el archivo de entrada cambia. Cuando los dos archivos presentan diferencias el color utilizado para expresar esto es rojo de manera predeterminada («Color de conflicto» en las preferencias). Este esquema de color es especialmente práctico en el caso de que tenga tres archivos de entrada, tal y como se verá en la próxima sección (<link linkend="merging"
>Fusionar</link
>). </para
></sect2
><sect2
><title
>Columna resumen</title
><para
>A la izquierda de cada texto se encuentra la «columna resumen». Si las diferencias se producen en una línea la columna resumen muestra el color correspondiente. Si la diferencia es sólo de espacios en blanco se marca el resumen. Para los lenguajes de programación en los que los espacios no son importantes es práctico para apreciar de un vistazo si se modificó algo importante. (En C/C++ los espacios en blanco sólo son interesantes en el interior de las cadenas, comentarios, para el preprocesador y en otra serie de extrañas situaciones). </para
><para
>La línea vertical que separa la columna resumen y el texto se interrumpe si el archivo de entrada no tiene líneas. Cuando se activa el ajuste de línea, esta línea vertical aparecerá punteada en las líneas ajustadas. </para
></sect2
><sect2
><title
>Columna de visión general</title
><para
>En el lado derecho podemos encontrar la columna «visión general», a la izquierda de la barra de desplazamiento. Muestra la columna de resumen comprimida de la entrada «A». todas las diferencias y conflictos se pueden apreciar de un vistazo. Cuando solo se utilizan dos ventanas de entrada, todas las diferencias aparecerán en rojo, ya que cada diferencia supondrá un conflicto. Un rectángulo negro marca la parte visible de las entradas. Para los archivos con entradas muy largas, cuando el número de líneas es más grande que la altura de la columna visión general en pixels, varias líneas de entrada compartirán una línea de visión general. Un conflicto tendrá más prioridad que las simples diferencias, que a su vez tendrán prioridad sobre lo no cambiado, de forma que no se pierdan las diferencias o los conflictos aquí. Pulsando sobre la columna de visión general se mostrará el correspondiente texto. </para
></sect2
><sect2 id="manualdiffhelp"
><title
>Líneas alineadas manualmente</title
><para
>Algunas veces el algoritmo sitúa líneas incorrectas unas al lado de otras. O desea comparar un trozo de texto con otro texto que está en una posición completamente diferente en el otro archivo. Para estas situaciones puede indicar a &kdiff3; manualmente que alinee algunas líneas. Marque el texto que quiera alinear con el ratón, como si estuviera copiando y pegando, en la primera vista de diferencia y seleccione «Añadir alineación manual de diferencias» en el menú «Diffview» (acceso rápido de teclado «Ctrl-Y»). Aparecerá una barra naranja en la columna resumen al lado del texto seleccionado. Repita esto para la segunda y (si está disponible) para la tercera vista. &kdiff3; recalculará inmediatamente las diferencias cada vez que haga esto, y alineará las líneas elegidas. Por supuesto, alguna de las líneas que antes coincidían puede que ya no coincidan. </para
><para
>En estos momentos el fusionado no soporta el uso de ayuda de diff manual. </para
></sect2>
</sect1>
<sect1 id="merging"
><title
>Fusionar y la ventana del editor de la salida fusionada</title>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_merge.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<para
>La ventana del editor de la salida fusionada (bajo las ventanas de la entrada de diferencias) también tiene una línea de información sobre ella que mostrará «Salida», el nombre del archivo y «[Modificado]» si edita algo. Normalmente contendrá texto que podrá fusionarse automáticamente con facilidad, pero algunas veces también contendrá conflictos. </para
><para
>El guardado está desactivado hasta que se hayan resuelto todos los conflictos (utilice los botones «Ir al conflicto anterior/siguiente sin resolver» para encontrar los conflictos que falten). </para
><para
>Con sólo dos archivos de entrada, cada diferencia es también un conflicto que debe resolverse manualmente. </para
><para
>Con tres archivos de entrada el primer archivo se utiliza como base, mientras que el segundo y tercer archivos de entrada contienen las modificaciones. Si en cualquier línea solo tienen cambios la entrada B o la C pero no ambas se seleccionará automáticamente la fuente cambiada. Solo cuando B y C tengan cambios en las mismas líneas, la herramienta detectará un conflicto que debe resolverse manualmente. Cuando B y C sean iguales, pero diferentes a A, se seleccionará C. </para
><sect2
><title
>La columna resumen</title
><para
>El editor de la salida de fusionado también tiene una columna resumen a su izquierda. Mostrará la letra de la entrada de la que se seleccionó la línea, o nada si las tres fuentes son iguales en esa línea. Para los conflictos mostrará un signo de interrogación «?» y la línea mostrará «<Conflicto de fusionado>», en rojo. Puesto que resolver los conflictos línea a línea es muy arduo, las líneas se agruparán en grupos que tengan las mismas diferencias y conflictos característicos. Pero los conflictos causados solo por espacios en blanco se separarán de los conflictos no causados por espacios en blanco para facilitar el fusionado de los archivos cuando el sangrado cambia en muchas líneas. </para
></sect2
><sect2 id="synchronise_views"
><title
>Configurar el grupo actual, sincronizado de fusión y posición de vista de diferencias</title
><para
>Cuando se pulsa en la columna resumen con el botón izquierdo del ratón en la ventana a la que pertenezca este grupo, se seleccionarán todas las ventanas y se mostrará el comienzo de este grupo (ésto implica un salto automático en la posición de la ventana si el principio del grupo no se encuentra visible). El grupo se convierte en el «grupo actual». Se resalta con la «gama (diff) de color del fondo actual» y aparecerá una barra negra en la parte izquierda del texto. </para
></sect2
><sect2
><title
>Seleccionar las entradas A, B o C para el conflicto actual y la edición</title
><para
>La barra de botones bajo el menú incluye tres botones para seleccionar las entradas que contienen las letras «A», «B» y «C». Pulse el botón selector de entrada para insertar (o eliminar si ya se ha insertado) las líneas de la fuente respectiva. Para seleccionar las líneas de varias entradas pulse los botones correspondientes en el orden que necesite. Por ejemplo, si desea que las líneas de «B» aparezcan antes de las líneas de «A» en la salida, pulse primero «B» y luego «A». </para
><para
>Si estaba utilizando la opción avance automático (<link linkend="autoadvance"
>«Automáticamente ir al conflicto siguiente sin resolver después de una selección de origen»</link
>), debería desactivarla antes de elegir líneas desde varias entradas o editar líneas después de su elección. Sino lo hace &kdiff3; saltará al siguiente conflicto después de elegir la primera entrada. </para
><para
>Suele ser práctico para editar directamente la salida resultante de la fusión. La columna resumen mostrará «m» para cada línea que se haya modificado manualmente. Cuando, por ejemplo, las diferencias estén alineadas de forma que la simple elección no sea satisfactoria, puede marcar el texto necesario y utilizar <link linkend="selections"
>copiar y pegar</link
> de forma normal para situarlo en la salida de fusionado. </para
><para
>Algunas veces, cuando una línea se elimina bien por el fusionado o por la edición manual y no hay más líneas en este grupo, aparecerá el texto <Sin línea fuente>. Se coloca en lugar del grupo de forma que pueda cambiar de idea y seleccionar de nuevo la fuente. Este texto no aparecerá en el archivo guardado o en cualquier selección que copie y pegue. </para
><para
>El texto «<Conflicto de fusionado>» aparecerá en el portapapeles si copia y pega texto que la contenga. Pero tenga cuidado al hacerlo. </para
></sect2
><sect2
><title
>Seleccionar las entradas A, B o C para todos los conflictos</title
><para
>El fusionado normal se inicia resolviendo los conflictos sencillos automáticamente. Pero el menú «Fusionar» proporciona algunas acciones para otras necesidades habituales. Si ha seleccionado la misma fuente para más conflictos, podrá seleccionar «A», «B» o «C» en cualquier sitio, o solo para los conflictos pendientes de resolver, o para los conflictos sin resolver que sean debidos a espacios. Si desea decidir cada delta por sí mismo, puede «Establecer deltas a conflictos». O si desea volver a las elecciones automáticas de &kdiff3; seleccione «Resolver automáticamente conflictos simples». &kdiff3; reiniciará el fusionado. Para las acciones que cambien sus modificaciones anteriores &kdiff3; le pedirá confirmación antes de realizarlo. </para
><para
>Nota: Cuando seleccione fuente para los conflictos de espacios en blanco sin resolver y las opciones «Ignorar números» o «Ignorar comentarios C/C++», los cambios en los números o en los comentarios se tratarán también como espacios en blanco. </para
></sect2
><sect2 id="vcskeywordsmergesupport"
><title
>Fusión automática de las claves de control de versión y del historial (registro)</title
><para
>Many version control systems support special keywords in the file. (e.g. "$Date: 2006-04-21 17:24:21 -0400 (Fri, 21 Apr 2006) $", "$Header$", "$Author: toma $", "$Log$" etc.) During the check-in the version control system (VCS) changes these lines. For instance "$Date: 2006-04-21 17:24:21 -0400 (Fri, 21 Apr 2006) $" will turn into "$Date: 2006-04-21 17:24:21 -0400 (Fri, 21 Apr 2006) $". Since this line will be different in every version of the file, it would require manual interaction during the merge. </para
><para
>&kdiff3; ofrece fusionado automático para estos elementos. Para las líneas que coincidan con la opción «Fusionar automáticamente expresión regular» en todos los archivos de entrada de &kdiff3; se elegirá la línea desde B o -si está disponible- desde C (adicionalmente es necesario que las líneas en cuestión si las comparamos con las líneas anteriores no han de tener conflictos). Esta fusión automática también se puede ejecutar de forma inmediata después de iniciar la fusión (active la opción «Ejecutar expresión regular de fusión automática al iniciar la fusión») o posteriormente a través del menú de fusión «Ejecutar expresión regular de fusión automática»). </para
><para
>También está soportada la fusión automática para el historial de control de versión (también llamado «registro»). El historial de fusión automática se puede ejecutar automáticamente cuando se inicie la fusión activando la opción «Resolver automáticamente los conflictos del historial». </para
><para
>Usually the version control history begins with a line containing the keyword "$Log$". This must be matched by the "History start regular expression"-option. &kdiff3; detects which subsequent lines are in the history by analysing the leading characters that came before the "$Log$"-keyword. If the same "leading comment" also appears in the following lines, then they are also included in the history. </para
><para
>Durante cada descarga el VCS escribe una única línea especificando la versión, fecha, e información horaria seguida de líneas con comentarios del usuario. Estas líneas forman una entrada de historial. Esta sección del historial crece cada vez que descarga de forma que las entrada más recientes aparecerán en la parte superior (después de la línea de inicio del historial). </para
><para
>Cuando dos o más desarrolladores que están realizando un desarrollo paralelo descargan una rama de un archivo la fusión del historial contendrá varias entradas que aparecerán como conflictos durante la fusión de las ramas. Como esta fusión puede ser muy aburrido, &kdiff3; ofrece soporte con dos posibles estrategias: Insertar la información del historial de ambos colaboradores en la parte superior u ordenar la información del historial por una clave definida por el usuario. </para
><para
>El método que simplemente inserta las entradas es fácil de configurar. &kdiff3; solo necesita un método para detectar qué líneas pertenecen a una entrada del historial. La mayor parte de los VCS insertan una línea vacía después de cada entrada del historial. Sino hay otras líneas vacías, éste criterio es suficiente para &kdiff3;. Seleccione «Entrada del historial que inicia una expresión regular». Si el criterio de la línea vacía no es suficiente, puede especificar una expresión regular para detectar el inicio de la entrada del historial. </para
><para
>Tenga en cuenta que &kdiff3; eliminará las entradas duplicadas del historial. Si una entrada aparece varias veces en el historial de un archivo de entrada, solo permanecerá una en la salida. </para
><para
>Si desea ordenar el historial, debe especificar cómo se debe construir la clave de ordenación. Utilice paréntesis en «Entrada del historial que inicia una expresión regular» para agrupar partes del a expresión regular que se deberían utilizar posteriormente para la tecla de ordenación. A continuación especifique «Orden de la clave de ordenación que inicia la entrada del historial» especificando una lista de números separados por una coma «,» para referirse a la posición del grupo en la expresión regular. </para
><para
>Debido a que no es sencillo de hacer al primer intento, podrá comprobar y mejorar la expresión regular y la generación de clave en un diálogo dedicado pulsando el botón «Comprobar sus expresiones regulares». </para
><para
>Example: Assume a history that looks like this: <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.
**************************************************************************/
</screen
> The history start line matches the regular expression ".*\$Log.*\$.*". Then follow the history entries. </para
><para
>The line with the "$Log$"-keyword begins with two "*" after which follows a space. &kdiff3; 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. </para
><para
>Sino es necesaria la ordenación del historial entonces la entrada del historial comenzará con una línea de expresión regular como esta (esta línea se divide en dos porque sino no se puede ajustar) <screen>
\s*\\main\\\S+\s+[0-9]+ (Ene|Feb|Mar|Abr|May|Jun|Jul|Ago|Sep|Oct|Nov|Dic)
[0-9][0-9][0-9][0-9] [0-9][0-9]:[0-9][0-9]:[0-9][0-9]\s+.*
</screen
> Para obtener detalles sobre las expresiones regulares por favor, consulte la <ulink url="http://doc.trolltech.com/3.3/qregexp.html#details"
>documentación de las expresiones regulares de Trolltech</ulink
>. Tenga en cuenta que "\s" (con la «s» minúscula) coincidirá con cualquier espacio y "\S" (con «S» mayúscula) coincidirá con lo que no sean espacios en blanco. En nuestro ejemplo la entrada del historial deberá contener primero la versión de información de la expresión regular "\\main\\\S+", la fecha formada por el día «[0-9]+», més «(Ene|Feb|Mar|Abr|May|Jun|Jul|Ago|Sep|Oct|Nov|Dic)» y año «[0-9][0-9][0-9][0-9]», la hora «[0-9][0-9]:[0-9][0-9]:[0-9][0-9]» y finalmente el nombre de registro del desarrollador «.*». Vea que el comentario importante (en el ejemplo «**») lo eliminará KDiff3 antes de buscar la coincidencia, de ahí que la expresión regular comience con con una expresión regular para ninguno o más espacios en blanco «\s*». </para
><para
>Si necesita un historial ordenado, se calculará la clave de ordenación. Para esta las partes relevantes en la expresión regular se deben agrupar entre paréntesis (los paréntesis adicionales puede mantenerse aunque desactive la ordenación del historial). <screen>
(Ene|Feb|Mar|Abr|May|Jun|Jul|Ago|Sep|Oct|Nov|Dic)
([0-9][0-9][0-9][0-9]) ([0-9][0-9]:[0-9][0-9]:[0-9][0-9])\s+(.*)
</screen
> Los paréntesis ahora contendrán: 1. versión de información, 2. día, 3. mes, 4. año, 5. hora, 6. nombre. Pero si deseamos ordenarlos por fecha y hora, necesitará construir una clave con los elementos en un orden de aparición diferente: Primero el año, seguido del mes, día, hora, información de versión y nombre. De ahí que el orden de la clave de ordenación que se deba especificar sea «4,3,2,5,1,6». </para
><para
>Ya que los nombres de los meses no son buenos para la ordenación («Abr» iría primero) &kdiff3; detectará que son nombres de meses y utilizará números en su lugar («Abr»->«04»). Si se encuentra un número puro se transformará en un valor de 4 dígitos con ceros significativos para la ordenación. Finalmente la clave de ordenación resultante que iniciará la primera entrada del historial será: <screen
>2001 04 0002 10:45:41 rama_integración_12 tom
</screen>
</para
><para
>Para obtener más detalles consulte también <link linkend="diffmergeoptions"
>Configuración de Diff y Merge</link
>. </para>
</sect2>
</sect1>
<sect1 id="navigation"
><title
>Navegación y edición</title>
<para
>La mayor parte de la navegación puede realizarse con las barras de desplazamiento y el ratón, pero también puede navegar con las teclas. Si pulsa en cualquier ventana puede utilizar los cursores izquierdo, derecho, arriba, abajo, página arriba, página abajo, inicio, fin, Ctrl-Inicio, Ctrl-Fin tal y como lo haría en otros programas. La columna vista general situada al lado de la barra vertical de desplazamiento en los archivos de entrada también puede utilizarse para navegar pulsando sobre ella. </para
><para
>También puede utilizar la rueda del ratón para desplazarse arriba y abajo. </para
><para
>En el editor de la salida de fusionado también puede utilizar las otras teclas para la edición. Puede cambiar entre los modos insertar y sobreescribir con la tecla Insertar (el modo predeterminado es insertar). </para
><para
>Una pulsación del botón izquierdo del ratón en la columna resumen sincronizará todas las ventanas para mostrar el inicio del mismo grupo de líneas (tal y como se explicaba en la sección <link linkend="synchronise_views"
>«Configurar el grupo actual, sincronizado de fusión y posición de vista de diferencias»</link
>). </para
><para
>La barra de botones también contiene siete botones de navegación con los que podrá saltar a la diferencia actual/primera/última, a la siguiente/anterior diferencia (Ctrl-Flecha abajo/Ctrl-Flecha arriba), al siguiente/anterior conflicto (Ctrl-Página abajo/Ctrl-Página arriba), o al siguiente/anterior conflicto sin resolver. Tenga en cuenta que para &kdiff3; un «conflicto» que no se pudo resolver automáticamente al comienzo del fusionado continúa siendo un «conflicto» aunque se haya resuelto. De aquí la necesidad de distinguir los «conflictos sin resolver» </para>
<sect2 id="autoadvance"
><title
>Avance automático</title>
<para
>También existe el botón «Automáticamente ir al conflicto siguiente sin resolver después de una selección origen» (avance automático). Si activa esto, cuando se seleccione una fuente &kdiff3; saltará automáticamente al siguiente conflicto sin resolver. Esto puede ayudarle cuando desee seleccionar una sola fuente. Cuando necesite ambas fuerte, o desee editar después de la selección, probablemente querrá desactivar esto. Antes de continuar con el siguiente conflicto sin resolver &kdiff3; muestra el resultado de su elección durante un momento. Este retardo es ajustable en las preferencias Diff y fusión: Puede especificar en «Retardo auto avanzado» en milisegundos un valor entre 0 y 2.000. Pista: ¿Cansado de tanta pulsación? Utilice un retardo de avance automático pequeño y los accesos rápidos Ctrl-1/2/3 para seleccionar A/B/C para muchos de los conflictos. </para>
</sect2>
</sect1>
<sect1 id="selections"
><title
>Seleccionar, copiar y pegar</title>
<para
>Las ventanas de entrada no muestran un cursor, por ello las selecciones se hacen pulsando el botón izquierdo del ratón al inicio, manteniendo pulsado el botón del ratón y moviéndose al final, momento en el que soltará el botón del ratón. También puede seleccionar una palabra con una doble pulsación. En la salida del editor de fusionado puede realizar la selección a través del teclado manteniendo pulsado el botón «mayúsculas» y navegando con las teclas de cursor. </para
><para
>Si la selección excede el rango visible puede desplazar el ratón sobre los bordes de la ventana que harán que &kdiff3; se desplace en esta dirección. </para
><para
>Para las selecciones muy largas puede utilizar las teclas de navegación mientras mantiene pulsado el ratón. P.ej. utilice RePág y AvPág para ir rápidamente a una posición determinada. Al final de la posición suelte el botón del ratón. </para
><para
>Para seleccionarlo todo en la ventana actual utilice el menú «Editar»->«Seleccionar todo» (Ctrl-A). </para
><para
>Para copiar al portapapeles debe pulsar el botón «Copiar» (Ctrl-C o Ctrl-Insertar). Pero también existe la opción «Auto copiar selección». Si está activado, todo lo que seleccione se copiará inmediatamente y no necesitará realizar la copia explícitamente. Ponga atención cuando lo utilice ya que el contenido del portapapeles puede destruirse accidentalmente. </para
><para
>«Cortar» (Ctrl-X o Mayúsculas-Borrar) copia el texto seleccionado al portapapeles y lo borra. </para
><para
>«Pegar» (Ctrl-V o Mayúsculas-Insertar) inserta el texto del portapapeles en la posición del cursor o sobre la selección actual. Si pega algo en cualquier ventana de entrada de diferencia se mostrará el contenido del portapapeles en esta ventana y la comparación se reiniciará inmediatamente. Es práctico si desea guardar rápidamente un trozo de texto de alguna parte y compararlo con algo sin crear los archivos en primer lugar. </para>
</sect1>
<sect1 id="saving"
><title
>Guardar</title>
<para
>Guardar solo estará permitido cuando se hayan resuelto todos los conflictos. Si el archivo ya existe y la opción «Archivos de copia de seguridad» está activada el archivo existente se renombrará con una extensión «.orig», pero si ya existe un archivo se borrará. Cuando salga o inicie otro análisis de diferencias y los datos no se hayan guardado, &kdiff3; le preguntará si desea guardar, cancelar o continuar sin guardar (&kdiff3; no captura ninguna señal. Por eso si ejecuta «kill» sobre &kdiff3; sus datos se perderán). </para
><para
>Los finales de línea se guardan de acuerdo con el método utilizado por el sistema operativo. Para Unix cada línea termina con un caracter de nueva línea «\n», mientras que para los sistemas basados en Win-32 cada línea termina con un retorno de carro + un nueva línea «\r\n». &kdiff3; no conserva los finales de línea de los archivos de entrada, lo que significa que no debería utilizar &kdiff3; con archivos binarios. </para>
</sect1>
<sect1 id="find"
><title
>Buscar cadenas</title>
<para
>Puede buscar una cadena en cualquier ventana de texto de &kdiff3;. La orden «Buscar...» («Ctrl-F) en el menú Editar abre un diálogo que le permite especificar la cadena a buscar. La búsqueda siempre comenzará en la parte superior. Utilice la orden «Buscar siguiente» («F3») para buscar la siguiente aparición. si selecciona la búsqueda en varias ventanas se comenzará a buscar en la primera ventana de arriba hacia abajo antes de iniciar la búsqueda en la parte superior de la siguiente ventana, etc. </para>
</sect1>
<sect1 id="printing"
><title
>Impresión</title>
<para
>&kdiff3; soporta impresión de las diferencias en los archivos de texto. La orden «Imprimir» (Ctrl-P) en el menú archivo abre un diálogo que permite seleccionar la impresora y ajustar otras opciones. </para
><para
>Existen varias posibilidades de ajustar el rango. Debido a las diferencias existentes en los diálogos de impresión de los diversos sistemas operativos, el método para realizar determinadas selecciones variará. </para>
<variablelist>
<varlistentry
><term
>Todo:</term
><listitem
><para
>Imprime todo.</para
></listitem
></varlistentry>
<varlistentry
><term
>Actual:</term
><listitem
><para
>Imprime un página comenzando en la primera línea visible de la ventana (en sistemas sin esta opción se puede suplir este inconveniente especificando la página número 10000 para imprimir).</para
></listitem
></varlistentry>
<varlistentry
><term
>Selección:</term
><listitem
><para
>Antes de realizar esta elección de impresión seleccione el texto con el ratón (como para copiar y pegar) en una de las ventanas de entrada de diferencias para definir las líneas inicial y final. Si no hay texto seleccionado en una de las ventanas de diferencia, no estará disponible esta opción (en sistemas sin esta opción se puede conseguir el mismo resultado especificando la página 9999).</para
></listitem
></varlistentry>
<varlistentry
><term
>Rango:</term
><listitem
><para
>Especifique la primera y última página. </para
></listitem
></varlistentry>
</variablelist>
<para
>Otras opciones importantes para la impresión son las habituales: </para
><itemizedlist>
<listitem
><para
>Letra, tamaño de letra</para
></listitem>
<listitem
><para
>Mostrar números de línea</para
></listitem>
<listitem
><para
>Ajuste de texto</para
></listitem>
<listitem
><para
>Colores</para
></listitem>
<listitem
><para
>etc.</para
></listitem>
</itemizedlist>
<para
>También se recomienda la impresión en formato apaisado. </para>
</sect1>
<sect1 id="options"
><title
>Opciones</title>
<para
>Las opciones y la lista de archivos recientes se guardarán cuando salga del programa, y se recargarán cuando lo inicie (Menú Preferencias->Configurar &kdiff3; ...). </para>
<sect2
><title
>Fuente</title>
<para
>Seleccione un tipo de letra de ancho fijo (en algunos sistemas este diálogo puede mostrar tipos de letra de ancho variable, pero no debería utilizarlas). </para>
<variablelist>
<varlistentry
><term
><emphasis
>Fuente cursiva para deltas:</emphasis
></term
><listitem
><para
>Si selecciona esto, las diferencias de texto se dibujarán con la versión cursiva del tipo de letra. Si el tipo de letra no soporta cursiva, no hará nada.</para>
</listitem
></varlistentry>
</variablelist>
</sect2>
<sect2
><title
>Colores</title>
<variablelist>
<varlistentry
><term
><emphasis
>Color del primer plano:</emphasis
></term
><listitem
><para
>Habitualmente negro. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color de fondo:</emphasis
></term
><listitem
><para
>Habitualmente blanco. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color del fondo de diff:</emphasis
></term
><listitem
><para
>Habitualmente gris claro. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color A:</emphasis
></term
><listitem
><para
>Habitualmente azul oscuro. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color B:</emphasis
></term
><listitem
><para
>Habitualmente verde oscuro. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color C:</emphasis
></term
><listitem
><para
>Habitualmente magenta oscuro. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color de conflicto:</emphasis
></term
><listitem
><para
>Habitualmente rojo.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Rango actual de color de fondo:</emphasis
></term
><listitem
><para
>Habitualmente amarillo claro.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Rango actual de color de fondo de diff:</emphasis
></term
><listitem
><para
>Habitualmente amarillo oscuro.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Colores para los rangos de diferencias seleccionados manualmente:</emphasis
></term
><listitem
><para
>Habitualmente naranja.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color del archivo más nuevo en la comparación de directorios:</emphasis
></term
><listitem
><para
>Habitualmente verde.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color del archivo más antiguo en la comparación de directorios:</emphasis
></term
><listitem
><para
>Habitualmente rojo.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color de los archivos de antigüedad media en la comparación de directorios:</emphasis
></term
><listitem
><para
>Habitualmente amarillo oscuro.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Color para los archivos que faltan en la comparación de directorios:</emphasis
></term
><listitem
><para
>Habitualmente negro.</para
></listitem
></varlistentry>
</variablelist>
<para
>Los cambios de color para la comparación de directorios no tendrán efecto hasta la siguiente vez que inicie la comparación de directorios. </para>
<para
>En sistemas que solo tengan 16 ó 256 colores algunos de ellos no estarán disponibles en su forma exacta. En aquellos sistema el botón «Predeterminados» seleccionará un color puro. </para>
</sect2>
<sect2
><title
>Preferencias del editor</title>
<variablelist>
<varlistentry
><term
><emphasis
>El tabulador inserta espacios:</emphasis
></term
><listitem
><para
>Si está desactivado y pulsa la tecla tabulador, se insertará un caracter de tabulación, sino se insertará la cantidad adecuada de caracteres.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Tamaño del tabulador:</emphasis
></term
><listitem
><para
>Se puede ajustar para sus necesidades. El valor predeterminado es 8. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Auto indentación:</emphasis
></term
><listitem
><para
>Cuando pulsa Entrar; o Return el sangrado de la línea anterior se utiliza para la nueva línea. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Auto-copiar selección:</emphasis
></term
><listitem
><para
>Cada selección se copia inmediatamente al portapapeles de forma que no necesitará copiarlo explícitamente. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Estilo línea final:</emphasis
></term
><listitem
><para
>Al guardar puede seleccionar qué estilo de línea prefiere. El valor predeterminado es la elección habitual para el sistema operativo utilizado. </para
></listitem
></varlistentry>
</variablelist>
</sect2>
<sect2 id="diffmergeoptions"
><title
>Preferencias de Diff y fusión</title>
<para
>Cuando se comparan archivos, &kdiff3; primero intenta hacer coincidir las líneas que sean iguales en todos los archivos de entrada. Solo durante este paso se ignorarán los espacios en blanco. El segundo paso compara cada línea. En este paso los espacios en blanco no se ignorarán. Los espacios en blanco tampoco se ignorarán durante la fusión. </para>
<variablelist>
<varlistentry
><term
><emphasis
>Conservar el retorno de carro</emphasis
></term
><listitem
><para
>Algunos editores (en algunos sistemas) guardan los caracteres de retorno de carro «\r» y de línea siguiente «\n» al final de la línea, mientras que otros solo guardan el de línea siguiente «\n». Normalmente &kdiff3; ignora el retorno de carro, pero a pesar de que debido a ello no tengan el mismo tamaño parecerán iguales si se comparan juntos. Cuando se activa esta opción, los caracteres de retorno de carro se harán visibles, pero se tratarán como espacios en blanco. Esta opción debería estar desactivada durante el mezclado. El valor predeterminado es apagado.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ignorar números:</emphasis
></term
><listitem
><para
>De forma predeterminada estará desactivado. Los caracteres numéricos («0-9», «.», «-») se ignorarán en la primera parte del análisis en la que se efectuará la coincidencia de líneas. Sin embargo en el resultado las diferencias sí se mostrarán, pero serán tratadas como espacios en blanco. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ignorar comentarios de C/C++:</emphasis
></term
><listitem
><para
>De forma predeterminada estará desactivado. Los cambios en los comentarios se tratarán como cambios de espacios en blanco. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ignorar mayúsculas:</emphasis
></term
><listitem
><para
>De forma predeterminada estará desactivado. Las diferencias de mayúsculas y minúsculas de los caracteres (como «A» y «a») se tratarán como cambios de espacios en blanco. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Comando del preprocesador:</emphasis
></term
><listitem
><para
>Vea la <link linkend="preprocessors"
>siguiente sección</link
>. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Comando de preprocesador de combinación de línea:</emphasis
></term
><listitem
><para
>Vea la <link linkend="preprocessors"
>siguiente sección</link
>. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Intentar más a fondo:</emphasis
></term
><listitem
><para
>Intenta encontrar más a fondo una delta más pequeña (de forma predeterminada estará activada). Debería ser efectivo para archivos grandes y complicados. Y lento para archivos muy grandes. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Retardo auto avanzado (ms):</emphasis
></term
><listitem
><para
>Cuando está activado el modo de «auto avanzado» aquí se especifica durante cuanto tiempo se mostrará el resultado de la selección antes de saltar al siguiente conflicto sin resolver. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Fusionar de forma predeterminada espacios en blanco de dos/tres archivos:</emphasis
></term
><listitem
><para
>Resuelve automáticamente todos los conflictos de los espacios en blanco seleccionando el archivo especificado (el modo predeterminado es el manual). Práctico si los espacios no son realmente importantes en los archivos. Si solo necesita ésto ocasionalmente mejor utilice «Seleccionar A/B/C para todos conflictos de los espacios en blanco sin resolver» en el menú Fusionar. Tenga en cuenta que si ha activado «Ignorar números» o «Ignorar comentarios de C/C++» esta autoelección también se aplica a los conflictos en los números y en los comentarios. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Expresión regular de fusión automática:</emphasis
></term
><listitem
><para
>Expresión regular para las líneas en las que &kdiff3; debería elegir automáticamente una fuente. Consulte también <link linkend="vcskeywordsmergesupport"
>Fusión automática</link
>. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ejecutar expresión regular de fusión automática al iniciar la fusión:</emphasis
></term
><listitem
><para
>Si está activado &kdiff3; ejecutará la fusión automática utilizando la «expresión regular de fusión automática» cuando se inicie una fusión. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Expresión regular de inicio de historial:</emphasis
></term
><listitem
><para
>Regular expression for the start of the merge history entry. Usually this line contains the "$Log$"-keyword. Default value: ".*\$Log.*\$.*" </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Expresión regular de inicio de entrada del historial:</emphasis
></term
><listitem
><para
>Una entrada del historial de fusión está formada por varias líneas. Especifique la expresión regular para detectar la primera línea (sin el comentario importante). Utilice paréntesis para agrupar las claves que desee utilizar para la ordenación. Si está vacío, KDiff3 asume que las líneas vacías separan entradas del historial. Consulte también <link linkend="vcskeywordsmergesupport"
>Fusión automática</link
>. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ordenación del historial de fusión:</emphasis
></term
><listitem
><para
>Activar ordenación del historial del control de versiones </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>orden de la clave de ordenación del inicio de la entrada del historial:</emphasis
></term
><listitem
><para
>Cada paréntesis utilizado en la expresión regular para la entrada del inicio del historial agrupa una clave que puede utilizarse para la ordenación. Especifique la lista de claves (están numeradas en orden de aparición comenzando con 1) y utilizando «,» como separador (p. ej. «4,5,6,1,2,3,7»). Si permanece vacío, no se realizará ordenación. Consulte también <link linkend="vcskeywordsmergesupport"
>fusión automática</link
>. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Historial del control de versión de fusión al iniciar la fusión</emphasis
></term
><listitem
><para
>Si está activado &kdiff3; ejecuta automáticamente el fusionado del historial utilizando las opciones antes mencionadas cuando se inicia una fusión. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Compruebe sus expresiones regulares</emphasis
></term
><listitem
><para
>Este botón muestra un diálogo que le permite mejorar y comprobar la expresión regular. Copie los datos de sus archivos en las líneas de ejemplo. Los «Resultados coincidentes» si la coincidencia se produjo o no. El «Resultado de la clave de ordenación» mostrará la clave utilizada para la ordenación del historial de fusión. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Orden de fusión irrelevante:</emphasis
></term
><listitem
><para
>Especifique una orden que debería ser llamada cuando &kdiff3; detecte que para el archivo B no contiene datos relevantes ya que están incluídos en C. La orden se llama con los tres nombres de archivo como parámetros. Las datos deberán coincidir con la «expresión regular de fusionado automático» o con el historial sino se considera relevante. </para
></listitem
></varlistentry>
</variablelist>
</sect2>
<sect2
><title
>Fusión de directorios</title>
<para
>Estas opciones están relacionadas con la exploración del directorio y el manejo del fusionado: Vea la <link linkend="dirmergeoptions"
>Comparación/fusión de directorios de documentos</link
> para obtener los detalles. </para
><para
>También existe una opción relevante para guardar archivos sencillos: </para>
<variablelist>
<varlistentry
><term
><emphasis
>Archivos de copia de seguridad:</emphasis
></term
><listitem
><para
>Cuando se guarde un archivo y ya exista una versión antigua, la versión original se renombrará con una extensión «.orig». Si ya existía un archivo de copia de seguridad antigua con la extensión «.orig» se borrará. </para
></listitem
></varlistentry>
</variablelist>
</sect2>
<sect2
><title
>Configuraciones regionales</title>
<variablelist>
<varlistentry
><term
><emphasis
>Idioma:</emphasis
></term
><listitem
><para
>Ajusta el idioma de la interfaz de usuario. Cambiar esta opción no afectará a la ejecución del programa. Tendrá que salir y reiniciar &kdiff3; para que el cambio tenga efecto (esta opción no está disponible en la versión de KDE; de &kdiff3; porque el idioma se ajusta de forma global en las preferencias de KDE). </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Usar la misma codificación para todo:</emphasis
></term
><listitem
><para
>Las siguientes opciones de codificación se pueden ajustar de forma separada para cada elemento, o si esta opción está activada, todos los valores tomarán el primer valor. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Codificación local:</emphasis
></term
><listitem
><para
>Sobre los selectores de código aparece una nota que le indica cuál es la codificación local (no es ajustable, ya que se utiliza para informarle de su codificación en caso de que no la conozca, y necesite seleccionarla). </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Codificación de archivo para A/B/C:</emphasis
></term
><listitem
><para
>Ajusta la codificación para los archivos de entrada. Esto tiene efecto en la interpretación de los caracteres especiales. Como puede ajustar cada codificación por separado puede comparar y fusionar archivos guardados con diferentes codificaciones. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Codificación de archivo para la salida de la fusión y guardar:</emphasis
></term
><listitem
><para
>Cuando haya editado un archivo, podrá ajustar qué codificación se utilizará al guardarse en el disco. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Codificación de archivo para los archivos del preprocesador:</emphasis
></term
><listitem
><para
>Cuando defina el preprocesador puede que no sea capaz de operar con su codificación (ejem: Sus archivos son de unicode de 16 bit y su preprocesador solo puede utilizar ascii de 8 bit). Con esta opción puede definir la codificación de la salida del preprocesador. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Idioma de derecha a izquierda:</emphasis
></term
><listitem
><para
>Algunos idiomas se escriben de derecha a izquierda. Cuando esta opción está activada, &kdiff3; dibuja el texto de derecha a izquierda en las ventanas de entrada de diff y en la ventana de la salida del fusionado. Tenga en cuenta que si inicia &kdiff3; con la opción de línea de órdenes «--reverse» toda la distribución se hará de derecha a izquierda también (ésta es una característica proporcionada por Qt). Este manual se escribió asumiendo que «Idioma de derecha a izquierda» o invertir distribución están desactivados. Por ello, algunas referencias a «izquierda» o «derecha» se reemplazarán por sus respectivas homólogas si utiliza estas opciones. </para
></listitem
></varlistentry>
</variablelist>
</sect2>
<sect2
><title
>Varios</title>
<para
>Estas opciones y acciones están disponibles en los menús o en la barra de botones.</para>
<variablelist>
<varlistentry
><term
><emphasis
>Mostrar números de líneas:</emphasis
></term
><listitem
><para
>Puede seleccionar si los números deberían mostrarse en los archivos de entrada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Mostrar caracteres espacio y tabulador por diferencias:</emphasis
></term
><listitem
><para
>Algunas veces los espacios visibles y los tabuladores molestan. Puede desactivarlos.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Mostrar espacio en blanco:</emphasis
></term
><listitem
><para
>Desactívelo para suprimir cualquier resaltado o cambio de «solo espacio en blanco» en el texto o en las columnas de vista general (tenga en cuenta que ésto también se aplicará a los cambios en los números y comentarios si están activadas las opciones «Ignorar números» o «Ignorar comentarios C/C++»).</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Opciones de la vista general:</emphasis
></term
><listitem
><para
>Estas elecciones están disponibles cuando compara tres archivos. En el modo normal todas las diferencias se muestra en un color codificado en la columna de vista general. Pero algunas veces puede estar interesado en las diferencias entre solo dos de los tres archivos. Seleccionando vista «A vs. B», «A vs. C» o «B vs. C» se mostrará una segunda columna de vista general con la información requerida situado al lado de la visión general normal. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Ajuste de palabras en las ventanas diff:</emphasis
></term
><listitem
><para
>Ajusta las líneas cuando su longitud excede del ancho de una ventana. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Mostrar ventana A/B/C:</emphasis
></term
><listitem
><para
>Algunas veces deseará utilizar mejor el espacio de la pantalla para las líneas largas. Oculte las ventanas que no sean importantes (en el menú Ventanas).</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Cambiar orientación de división:</emphasis
></term
><listitem
><para
>Cambia entre las ventanas diff mostrándolas una cerca de la otra (A a la izquierda de B, y a la izquierda de C) o una sobre otra (A sobre B y sobre C). También debería servir de ayuda para las líneas largas (en el menú Ventanas). </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Iniciar fusión rápida:</emphasis
></term
><listitem
><para
>Algunas veces puede estar viendo las deltas y decidir fusionarlas. <inlinemediaobject
><imageobject
><imagedata fileref="merge_current.png" format="PNG"/></imageobject
></inlinemediaobject
> «Fusionar el archivo actual» en el menú Directorio también funcionará si solo compara dos archivos. Una simple pulsación inicia la fusión y utiliza el nombre de archivo del último archivo de entrada como nombre de archivo predeterminado (cuando se utiliza esto para reiniciar una fusión, se conservará el nombre de archivo de la salida).</para
></listitem
></varlistentry>
</variablelist>
</sect2>
<sect2 id="shortcuts"
><title
>Configurar accesos rápidos de teclado</title>
<para
>En estos momentos solo la versión para KDE soporta accesos rápidos de teclado configurables por el usuario (Menú Preferencias->Configurar accesos rápidos). </para>
</sect2>
</sect1>
<sect1 id="preprocessors"
><title
>Órdenes del preprocesador</title>
<para
>&kdiff3; soporta dos opciones para el preprocesador. </para
><para>
<variablelist>
<varlistentry
><term
><emphasis
>Comando del preprocesador:</emphasis
></term
><listitem
><para
>Cuando se lee cualquier archivo, se redirigirá a través de esta orden externa. Se podrá ver la salida de esta orden en lugar del archivo original. Puede escribir su propio preprocesador que cubra sus necesidades específicas. Utilice esto para cortar determinadas partes del archivo, o para corregir de forma automática el sangrado, etc. </para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Comando de preprocesador de combinación de línea:</emphasis
></term
><listitem
><para
>Cuando se lee cualquier archivo, se redirigirá a través de esta orden externa. Si se especifica una orden de preprocesado (ver a continuación), la salida del preprocesador será la entrada de la coincidencia de líneas del preprocesador. La salida solo se utilizará durante la fase de coincidencia de líneas durante el análisis. Puede escribir su propio preprocesador que cubra sus necesidades específicas. Cada línea de entrada tendrá la correspondiente línea de salida. </para
></listitem
></varlistentry>
</variablelist>
</para>
<para
>La idea es permitir al usuario gran flexibilidad durante la configuración del resultado de diff. Pero necesita un programa externo, y muchos usuarios no quieren escribirlo ellos. La buena noticia es que muchas veces <command
>sed</command
> o <command
>perl</command
> harán este trabajo. </para>
<para
>Ejemplo: Prueba de mayúsculas sencilla: considerar el archivo a.txt (6 líneas): <screen>
aa
ba
ca
da
ea
fa
</screen
> y el archivo b.txt (3 líneas): <screen>
cg
dg
eg
</screen
>Sin un preprocesador las siguientes líneas se situarán unas al lado de otras: <screen>
aa - cg
ba - dg
ca - eg
da
ea
fa
</screen
> Esto no es lo que probablemente lo que se desea ya qu ela primera letra contiene actualmetne la información interesante. Para ayudar al algoritmo de coincidencias a ignorar la segunda letra podemos utilizar una orden de preprocesador, que reemplace «g» con «a»: <screen>
<command
>sed</command
> 's/g/a/'
</screen
> Con esta orden el resultado del a comparación será:<screen>
aa
ba
ca - cg
da - dg
ea - eg
fa
</screen
>Internamente el algoritmo de coincidencia ve los archivos después de la ejecución de la línea del preprocesador de coincidencia, pero en la pantalla el archivo continúa sin cambios (el preprocesador normal cambiará también los datos en la pantalla). </para>
<sect2 id="sedbasics"
><title
>Lo básico de <command
>sed</command
></title>
<para
>Esta sección solo introduce algunas características muy básicas de <command
>sed</command
>. Para obtener más información consulte <ulink url="info:/sed"
>info:/sed</ulink
> o <ulink url="http://www.gnu.org/software/sed/manual/html_mono/sed.html"
>http://www.gnu.org/software/sed/manual/html_mono/sed.html</ulink
>. Una versión precompilada para Windows puede encontrarse en <ulink url="http://unxutils.sourceforge.net"
>http://unxutils.sourceforge.net</ulink
>. Tenga en cuenta que los siguientes ejemplos asumen que la orden <command
>sed</command
> se encuentra en algún directorio definido en la variable de entorno PATH. Si este no es el caso, deberá especificar la ruta completa absoluta de lo orden. </para>
<note
><para
>También debe tener en cuenta que los siguientes ejemplos utilizan una marca de comilla simple (') que no funcionará para Windows. En Windows debería utilizar las marcas de comillas dobles (") en su lugar.</para
></note>
<para
>En este contexto solo se utiliza la orden de sustitución <command
>sed</command
>: <screen>
<command
>sed</command
> 's/<replaceable
>REGEXP</replaceable
>/<replaceable
>REEMPLAZO</replaceable
>/<replaceable
>MODIFICADORES</replaceable
>'
</screen
> Antes de utilizar una orden nueva con &kdiff3;, debería comprobarla en una consola. Aquí será práctica la orden <command
>echo</command
>. Ejemplo: <screen>
<command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/'
-> obrakadabra
</screen
> Este ejemplo muestra una orden sed muy simple que reemplaza la primera aparición de «a» con «o». Si desea reemplazar todas las apariciones necesitará el modificador «g»: <screen>
<command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/g'
-> obrokodobro
</screen
> El símbolo «|» es la orden de tubería que transfiere la salida de la orden anterior a la entrada de la siguiente orden. Si desea comprobar el uso con un archivo largo puede utiilzar <command
>cat</command
> en los sistemas tipo Unix o <command
>type</command
> en los sistemas tipo Windows. <command
>sed</command
> hará la sustitución para cada línea. <screen
><command
>cat</command
> <replaceable
>nombrearchivo</replaceable
> | <command
>sed</command
> <replaceable
>opciones</replaceable
>
</screen>
</para>
</sect2>
<sect2 id="sedforkdiff3"
><title
>Ejemplos para <command
>sed</command
> usados en &kdiff3;</title>
<sect3
><title
>Ignorar otros tipos de comentarios</title>
<para
>En estos momentos &kdiff3; solo entiende los comentarios C/C++. Utilizando la orden del preprocesado de línea coincidente también puede ignorar otros tipos de comentarios, convirtiéndoles en comentarios C/C++. Ejemplo: Para ignorar los comentarios que comiencen con «#», debería convertirlos a «//». Tenga en cuenta que debe tener activada la opción «Ignorar comentarios C/C++» para que tenga efecto. Una línea de preprocesado de línea coincidente podría ser: <screen>
<command
>sed</command
> 's/#/\/\//'
</screen
>Al igual que para <command
>sed</command
> el caracter «/» tienen un significado especial, y es necesarío reemplazar el caracter «\» antes de cada «/» en la cadena de reemplazo. Algunas veces el «\» es necesario para añadir o eliminar un significado especial de ciertos caracteres. Las comillas simples (') antes y después de la orden de sustitución son importantes, ya que sino el intérprete de órdenes intentará interpretar algunos caracteres especiales como «#», «$» o «\» antes de pasarlos a <command
>sed</command
>. <emphasis
>Tenga en cuenta que en Windows aquí necesitará utilizar las comillas dobles ("). Windows sustituye otros caracteres como «%», por ello debería experimentar un poquito</emphasis
>. </para>
</sect3>
<sect3
><title
>Sensibilidad de diff a mayúsculas y minúsculas</title>
<para
>Utilice la siguiente orden de preprocesado de coincidencia de línea para convertir todas las entradas a mayúsculas: <screen>
<command
>sed</command
> 's/\(.*\)/\U\1/'
</screen
>Aquí el «.*» es una expresión regular que incluye a todos los caracteres en la línea. El «\1» en la cadena de reemplazo hace referencia al texto que coincide con el primer par de «\(» y «\)». La «\U» convierte el texto insertado a mayúsculas. </para>
</sect3>
<sect3
><title
>Ignorar las claves de control de versión</title>
<para
><acronym
>CVS</acronym
> y otros sistemas de control de versión utilizan algunas claves para insertar cadenas automáticamente generadas (<ulink url="info:/cvs/Keyword substitution"
>info:/cvs/Keyword sustitución</ulink
>). Todos ellos siguen el modelo «$CLAVE generada texto$». Ahora necesitaremos una orden de preprocesado que elimine solo el texto generado: <screen>
<command
>sed</command
> 's/\$\(Revision\|Author\|Log\|Header\|Date\).*\$/\$\1\$/'
</screen
> Las «\|» separan las posibles claves. Podría querer modificar esta lista para acomodarla a sus necesidades. La «\» before the «$» es necesaria porque de otra forma «$» coincidirá con el final de la línea. </para>
<para
>Mientras experimenta con <command
>sed</command
> puede llegar a entender y a gustarle las expresiones regulares. Son prácticas porque hay muchos programas que soportan cosas similares. </para>
</sect3>
<sect3
><title
>Ignorar números</title>
<para
>Ignorar los números en realidad es una opción de construcción. Pero como en otros ejemplos, indica el aspecto que podría tener la orden de preprocesado. <screen>
<command
>sed</command
> 's/[0123456789.-]//g'
</screen
> Cualquier caracter entre «[» y «]» será una coincidencia y no se reemplazará con nada. </para>
</sect3>
<sect3
><title
>Ignorar ciertas columnas</title>
<para
>Algunas veces una texto tiene un formato muy estricto y contiene columnas que desearía ignorar, mientras que otras columnas deseará conservarlas para el análisis. En el siguiente ejemplo las primeras cinco columnas (caracteres) se ignorarán, las siguientes diez se conservarán, otras cinco se ignorarán y el resto de la línea se conservará. <screen>
<command
>sed</command
> 's/.....\(..........\).....\(.*\)/\1\2/'
</screen
> Cada punto «.» coincidirá con cualquier caracter simple. El «\1» y el «\2» en la cadena de reemplazo hacen referencia al texto coincidente dentro del primer y segundo par de «\(» y «\)» indicando el texto que se conservará. </para>
</sect3>
<sect3
><title
>Combinar varias sustituciones</title>
<para
>Algunas veces deseará aplicar varias sustituciones a la vez. Puede utilizar el punto y coma «;» para separarlas unas de otras. Ejemplo: <screen
><command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/g;s/\(.*\)/\U\1/'
-> OBROKODOBRO
</screen>
</para>
</sect3>
<sect3
><title
>Utilizar <command
>perl</command
> en lugar de <command
>sed</command
></title>
<para
>En lugar de <command
>sed</command
> podría utilizar algo como <command
>perl</command
>. <screen>
<command
>perl</command
> -p -e 's/<replaceable
>EXPREG</replaceable
>/<replaceable
>REEMPLAZO</replaceable
>/<replaceable
>MODIFICADORES</replaceable
>'
</screen
> Pero algunos detalles son diferentes en <command
>perl</command
>. Tenga en cuenta que <command
>sed</command
> necesita «\(» y «\)» <command
>perl</command
> necesita solo «(» y «)» sin estar precedido de «\». Ejemplo: <screen
><command
>sed</command
> 's/\(.*\)/\U\1/'
<command
>perl</command
> -p -e 's/(.*)/\U\1/'
</screen>
</para>
</sect3>
</sect2>
<sect2
><title
>Orden de la ejecución de preprocesado</title>
<para
>Los datos van pasando por todos los preprocesadores internos y externos en el siguiente orden: </para>
<itemizedlist>
<listitem
><para
>Preprocesador normal.</para
></listitem>
<listitem
><para
>Preprocesador de coincidencia de líneas.</para
></listitem>
<listitem
><para
>Ignorar mayúsculas (conversión a mayúsculas).</para
></listitem>
<listitem
><para
>Detección de comentarios C/C++.</para
></listitem>
<listitem
><para
>Ignorar números.</para
></listitem>
<listitem
><para
>Ignorar espacios en blanco.</para
></listitem>
</itemizedlist>
<para
>Los datos después del preprocesador normal se conservarán para mostrarse y fusionarse. El resto de operaciones solo modificarán los datos para que los vea el algoritmo de coincidencia de líneas de diff. </para
><para
>En alguna ocasión cuando use el preprocesador normal se dará cuenta de que el preprocesador de coincidencia de líneas verá la salida del preprocesador normal como entrada. </para>
</sect2>
<sect2
><title
>Aviso</title>
<para
>La orden de preprocesado suele ser muy práctica, pero como con cualquier opción que modifique su texto u oculte ciertas diferencias automáticamente, puede saltarse accidentalmente ciertas diferencias y en el peor de los casos destruir datos importantes. </para
><para
>Por esta razón durante un fusionado si &kdiff3; utiliza una orden de preprocesado normal le preguntará si desea desactivarla o no. Pero no se producirá ningún aviso si está activada la orden de preprocesado de líneas coincidentes. La fusión no se completará hasta que se resuelvan los conflictos. Si desactiva «Mostrar espacios en blanco» las diferencias eliminadas con la orden de preprocesado de líneas coincidentes también estarán visibles. Si el botón guardar continúa desactivado durante una fusión (porque aún existen conflictos), asegúrese de activar «Mostrar espacios en blanco». Si no desea fusionar estas diferencias sin importancia de forma manual puede elegir «Seleccionar [A|B|C] para todos los conflictos de espacios en blanco sin resolver» en el menú Fusionar. </para>
</sect2>
</sect1>
</chapter>
<chapter id="dirmerge"
><title
>Comparación y fusionado de directorios con &kdiff3;</title>
<sect1 id="dirmergeintro"
><title
>Iniciar la comparación y fusión del directorio</title>
<para
>Frecuentemente los programadores modifican varios archivos en un directorio para conseguir su propósito. Para esto &kdiff3; también le permite comparar y fusionar directorios completos recursivamente. </para
><para
>Aunque la comparación y fusionado de directorios parezca bastante obvio, existen varios detalles que debería conocer. Lo más importante es el hecho de que la operación podría afectar a muchos archivos. Si no tiene copias de seguridad de los datos originales, podría ser complicado e incluso imposible devolverlos a su estado original. Por lo tanto, antes de realizar un fusionado, asegúrese de guardar sus datos en un lugar seguro, de forma que sea posible volver atrás. Si crea un archivo o utiliza algún sistema de control de versiones es cosa suya, pero los programadores experimentados y los integradores pueden necesitan las antiguas fuentes. Y tenga en cuenta que a pesar de que yo (el autor de &kdiff3;) intento hacerlo lo mejor posible, no garantizo que no existan fallos. De acuerdo con la licencia GNU GPL NO EXISTE NINGUNA GARANTÍA para este programa. Por lo tanto, sea humilde y tenga siempre lo siguiente en mente: </para>
<blockquote
><para>
<emphasis
>Errar es humano, pero para echar las cosas a perder necesita un ordenador.</emphasis>
</para
></blockquote>
<para
>Ésto es lo que este programa puede hacer por usted: &kdiff3; ... </para>
<itemizedlist>
<listitem
><para
>... lee y compara dos o tres directorios recursivamente.</para
></listitem>
<listitem
><para
>... tiene un especial cuidado con los enlaces simbólicos.</para
></listitem>
<listitem
><para
>... le permitirá navegar por los directorios con una doble pulsación del ratón.</para
></listitem>
<listitem
><para
>... para cada elemento propone una operación de fusión, que puede cambiar antes de iniciar la fusión del directorio.</para
></listitem>
<listitem
><para
>... le permite simular la fusión y lista las acciones que se realizarían si se llegasen a llevar a cabo.</para
></listitem>
<listitem
><para
>... le permite realizar la fusión, y le permite interactuar cuando sea necesaria la interacción manual.</para
></listitem>
<listitem
><para
>... le permite ejecutar las operaciones seleccionadas para todos los elementos (tecla F7) o para el elemento seleccionado (tecla F6).</para
></listitem>
<listitem
><para
>... le permite continuar la fusión después de la interacción manual con la tecla F7.</para
></listitem>
<listitem
><para
>... crea copias de seguridad opcionales, con la extensión «.orig».</para
></listitem>
<listitem
><para
>...</para
></listitem>
</itemizedlist>
</sect1>
<sect1 id="startingdirmerge"
><title
>Iniciar la comparación o fusión del directorio</title>
<para
>Es similar a la fusión y comparación de archivos. Solo debe especificar los directorios en la línea de órdenes o en el diálogo abrir archivo. </para>
<sect2
><title
>Comparar/fusionar dos directorios: </title>
<screen
><command
>kdiff3</command
> <replaceable
>directorio1 directorio2</replaceable>
<command
>kdiff3</command
> <replaceable
>directorio1 directorio2</replaceable
> -o <replaceable
>directorio-destino</replaceable
>
</screen>
<para
>Sino se especifica directorio de destino, &kdiff3; utilizará <replaceable
>directorio2</replaceable
>. </para>
</sect2>
<sect2
><title
>Comparar/fusionar tres directorios: </title>
<screen
><command
>kdiff3</command
> <replaceable
>directorio1 directorio2 directorio3</replaceable>
<command
>kdiff3</command
> <replaceable
>directorio1 directorio2 directorio3</replaceable
> -o <replaceable
>directorio-destino</replaceable
>
</screen>
<para
>Cuando se fusionen tres directorios <replaceable
>directorio1</replaceable
> se utiliza como base para la fusión. Sino se especifica directorio destino, &kdiff3; utilizará <replaceable
>directorio3</replaceable
> como directorio destino para la fusión. </para>
<para
>Tenga en cuenta que solo la comparación se inicia automáticamente, no la fusión. Para esto debería seleccionar la entrada de menú o la tecla F7 (más detalles a continuación). </para>
</sect2>
</sect1>
<sect1 id="dirmergevisible"
><title
>Información visible del directorio de fusión</title>
<para
>Mientras lee estos directorios se mostrará un cuadro de diálogo en el que se informará del progreso. Si cancela la exploración del directorio, solo se compararán los archivos listados. </para
><para
>Cuando se termine la exploración del directorio &kdiff3; mostrará una lista con el resultado... </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="dirbrowser.png" format="PNG"/></imageobject
> <!--alt="Image of the directory browser."-->
</mediaobject
></screenshot>
<para
>... y detalles sobre el elemento seleccionado actualmente a la derecha: </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="iteminfo.png" format="PNG"/></imageobject>
<!--alt="Image with information about the selected item."-->
</mediaobject
></screenshot>
<sect2 id="name"
><title
>La columna nombre</title>
<para
>Cada archivo y directorio que se encuentre durante la exploración se mostrará aquí en un árbol. Puede seleccionar un elemento pulsando una vez con el ratón. </para
><para
>De forma predeterminada los directorios están contraídos. Puede expandirlos y contraerlos pulsando en «+»/«-», con una doble pulsación, o utilizando las teclas Flecha izquierda o Flecha derecha. El menú «Directorio» también contiene dos acciones «Plegar todos los subdirectorios» y «Desplegar todos los subdirectorios» con los que podrá contraer y expandir todos los directorios de una vez. </para
><para
>Si hace una doble pulsación sobre un elemento de fichero comenzará la comparación y aparecerá la ventana de diferencias de archivos. </para>
<para
>La imagen de la columna nombre reflejará el tipo de archivo en el primer directorio («A»). Puede ser uno de estos: </para>
<itemizedlist>
<listitem
><para
>Archivo normal.</para
></listitem>
<listitem
><para
>Directorio normal (imagen de directorio).</para
></listitem>
<listitem
><para
>Enlace a un archivo (imagen de archivo con una flecha de enlace).</para
></listitem>
<listitem
><para
>Enlace a un directorio (imagen de directorio con una flecha de enlace).</para
></listitem>
</itemizedlist>
<para
>Si el tipo de archivo es diferente en el resto de directorios, ésto podrá verse en las columnas A/B/C y en la ventana que muestra los detalles sobre el elemento seleccionado. Tenga en cuenta que en este caso la fusión no podrá seleccionarse automáticamente. Cuando inicie la fusión, el usuario será informado de problemas de este tipo. </para>
</sect2>
<sect2 id="coloring"
><title
>Las columnas A/B/C y el esquema de coloreado</title>
<para
>Como puede verse en la imagen superior los colores rojo, verde, amarillo y negro son los que se utilizan en las columnas A/B/C. </para>
<itemizedlist>
<listitem
><para
>Negro: Este elemento no existe en este directorio.</para
></listitem>
<listitem
><para
>Verde: El elemento más nuevo.</para
></listitem>
<listitem
><para
>Amarillo: Más antiguo que verde, más nuevo que rojo.</para
></listitem>
<listitem
><para
>Rojo: El elemento más antiguo.</para
></listitem>
</itemizedlist>
<para
>Pero para los elementos que son idénticos en la comparación sus colores son idénticos aunque no coincida la antigüedad. </para
><para
>Los directorios se consideran iguales si todos los elementos que contienen son idénticos. Entonces tendrán el mismo color. Pero la antigüedad de un directorio no se considerará para su color. </para
><para
>La idea de este esquema de color se basa en <ulink url="http://samba.org/cgi-bin/cvsweb/dirdiff"
>dirdiff</ulink
>.Los colores son semejantes a las hojas, que son verdes cuando nacen, se vuelven amarillas más tarde y cuando envejecen se vuelven rojos. </para>
</sect2
><sect2 id="operation"
><title
>La columna Operación</title>
<para
>Después de comparar los directorios &kdiff3; también evalúa una propuesta para una operación de fusión. Esto se muestra en la columna «Operación». Puede modificar la operación pulsando en la operación que desee cambiar. Aparecerá un pequeño menú y le permitirá seleccionar una operación para este elemento (también puede seleccionar las operaciones a través del teclado. Ctrl+1/2/3/4/Supr seleccionarán A/B/C/Fusionar/Borrar respectivamente si están disponibles). Esta operación se ejecutará durante la fusión. La disponibilidad de estas operaciones dependerá del elemento y del modo de fusión. El modo de fusión será uno de los siguientes: </para>
<itemizedlist>
<listitem
><para
>Fusión del árbol de directorios («A» será tratada como la base más antigua de ambas).</para
></listitem>
<listitem
><para
>Fusionar dos directorios.</para
></listitem>
<listitem
><para
>Sincronizar dos directorios (activado a través de la opción «Sincronizar directorios»).</para
></listitem>
</itemizedlist>
<para
>En la fusión de tres directorios la operación propuesta será: Si para un elemento... </para>
<itemizedlist>
<listitem
><para
>... todos los árboles de directorios son iguales: Copiar desde C.</para
></listitem>
<listitem
><para
>... A y C son iguales pero B no: Copiar desde B (o si B no existe, borra el destino, si existe).</para
></listitem>
<listitem
><para
>... A y B son iguales pero C no: Copiar desde C (o si C no existe, borra el destino, si existe).</para
></listitem>
<listitem
><para
>... B y C son iguales pero A no: Copiar desde C (o si C no existe, borra el destino, si existe).</para
></listitem>
<listitem
><para
>... solo existe A: Borrar el destino (si existe).</para
></listitem>
<listitem
><para
>... solo existe B: Copiar desde B.</para
></listitem>
<listitem
><para
>... solo existe C: Copiar desde C.</para
></listitem>
<listitem
><para
>... A, B y C no son iguales: Fusionar.</para
></listitem>
<listitem
><para
>... A, B y C no tienen el mismo tipo de archivo (p.ej. A es un directorio, B es un archivo): «Error: Conflicto en los tipos de archivo». Mientras existan elementos como éstos la fusión de directorio no comenzará.</para
></listitem>
</itemizedlist>
<para
>En la fusión de dos directorios la operación propuesta será: Si para un elemento... </para>
<itemizedlist>
<listitem
><para
>... ambos directorios son iguales: Copiar desde B.</para
></listitem>
<listitem
><para
>... A existe, pero B no: Copiar desde A.</para
></listitem>
<listitem
><para
>... B existe, pero no A: Copiar desde B.</para
></listitem>
<listitem
><para
>... A y B existe pero no son iguales: Fusionar.</para
></listitem>
<listitem
><para
>... A y B no tienen el mismo tipo de archivo (p.ej. A es un directorio, B es un archivo): «Error: Conflicto en los tipos de archivo». Mientras existan de elementos como éstos la fusión de directorio no comenzará.</para
></listitem>
</itemizedlist>
<para
>El modo de sincronización estará activo si solo existen dos directorios, no se ha especificado destino y está activa la opción «Sincronizar directorios». &kdiff3; seleccionará una operación predeterminada de forma que ambos directorios sean idénticos después. Si para un elemento ... </para>
<itemizedlist>
<listitem
><para
>... ambos directorios son iguales: No se hará nada.</para
></listitem>
<listitem
><para
>... A existe, pero B no: copiar A a B.</para
></listitem>
<listitem
><para
>... B existe, pero A no: Copiar B a A.</para
></listitem>
<listitem
><para
>... A y B existen, pero no son iguales: Fusionar y guardar el resultado en ambos directorios (para los usuarios el nombre de archivo guardado es B, pero entonces &kdiff3; copiará B a A).</para
></listitem>
<listitem
><para
>... A y B no tienen el mismo tipo de archivo (p.ej. A es un directorio, B es un archivo): «Error: Conflicto en los tipos de archivo». Mientras existan de elementos como éstos la fusión de directorio no comenzará.</para
></listitem>
</itemizedlist>
<para
>Cuando se fusionen dos directorios y esté seleccionada la opción «Copiar nuevo en lugar de fusionar», &kdiff3; buscará en las fechas y propondrá como elección el nuevo archivo. Si los archivos no son iguales pero tienen las mismas fechas, la operación contendrá «Error: Las fechas son iguales pero los archivos no». Mientras éstos elementos existan no se iniciará la fusión de directorios. </para>
</sect2>
<sect2 id="status"
><title
>La columna estado</title>
<para
>Durante la fusión se procesará un archivo tras otro. La columna estado mostrará «Hecho» para los elementos donde se haya producido la operación de fusionado, y otro texto si sucede algo inesperado. Cuando se completa una fusión, debería hacer una última comprobación para ver si el estado de todos los elementos es el adecuado. </para>
</sect2>
<sect2 id="statisticscolulmns"
><title
>Columnas estadísticas</title>
<para
>Cuando está activado en las opciones el modo de comparación de archivos «Análisis completo», &kdiff3; mostrará columnas que contienen el número de conflictos sin resolver, resueltos, no en blanco o de espacios en blanco (la columna resueltos solo se mostrará cuando se comparen o fusionen directorios). </para>
</sect2>
<sect2 id="selectingvisiblefiles"
><title
>Seleccionar archivos listados</title>
<para
>Varias opciones influyen en los archivos que se listarán aquí. Algunas son accesibles a través del <link linkend="dirmergeoptions"
>diálogo preferencias</link
>. El menú Directorio contiene las entradas: </para
><para
><itemizedlist>
<listitem
><para
>«Mostrar archivos idénticos». Archivos que se han detectado como iguales en todos los directorios.</para
></listitem>
<listitem
><para
>«Mostrar archivos diferentes». Archivos que existen en dos o más directorios pero que no son iguales.</para
></listitem>
<listitem
><para
>«Mostrar archivos solo en A». Archivos que existen solo en A, pero no en B o C.</para
></listitem>
<listitem
><para
>«Mostrar archivos solo en B». Archivos que existen solo en B, pero no en A o B.</para
></listitem>
<listitem
><para
>«Mostrar archivos solo en C». Archivos que existen solo en C, pero no en A o B.</para
></listitem>
</itemizedlist
></para>
<para
>Active las opciones «Mostrar» para los elementos que desee listar. Si por ejemplo solo desea listar todos los elementos que existan en A o en B pero no en ambos, deberá activar «Mostrar archivos solo en A» y «Mostrar archivos solo en B» y desactivar todas las demás («Mostrar archivos idénticos», «Mostrar archivos diferentes», «Mostrar archivos solo en C»). La lista se actualizará inmediatamente para reflejar los cambios. </para
><para
>Estas opciones también se aplican para los directorio con una excepción: Desactivar «Mostrar archivos diferentes» no ocultará ningún directorio. Solo funcionará para los archivos que contenga. </para
><para
>Tenga en cuenta que de estas opciones solo es persistente la opción «Mostrar archivos idénticos». Los otros se activarán cuando se inicie &kdiff3;. </para>
</sect2>
</sect1>
<sect1 id="dothemerge"
><title
>Hacer una fusión de directorios</title>
<para
>Puede fusionar el elemento seleccionado (archivo o directorio) o todos los elementos. Cuando haya hecho todas sus operaciones de elección (en todos los subdirectorios también) podrá iniciar la fusión. </para
><para
>Sea consciente de que sino especifica un directorio de destino explícitamente, el destino será «C» en el modo de tres directorios, «B» en el modo de fusión de dos directorios, y en el modo de sincronización será «A» y/o «B». </para
><para
>Si ha especificado un directorio de destino marque todos los elementos del árbol que debieran estar en la salida. Existen algunas opciones que hará que se omitan ciertos elementos del directorio de comparación y del de fusión. Marque estas opciones para evitar sorpresas desagradables: </para>
<itemizedlist>
<listitem
><para
>«Directorios recursivos»: Si está desactivado, no se buscarán los elementos de los directorios.</para
></listitem>
<listitem
><para
>«Patrón»/«Anti-patrón»: Incluir/excluir elementos que coincidan.</para
></listitem>
<listitem
><para
>«Excluir archivos ocultos»</para
></listitem>
<listitem
><para
><link linkend="selectingvisiblefiles"
>«Mostrar» opciones</link
> (Mostrar archivos idénticos/diferentes, archivos solo en A/B/C)</para
></listitem>
</itemizedlist>
<para
>Si cambia las preferencias para listar más archivos, debería volver a buscar a través del menú «Directorio»->«Volver a buscar» (el motivo es que para realizar una comparación rápida &kdiff3; omite la comparación para los archivos suprimidos por este criterio). Si cambia sus patrones de archivo y directorio de exclusión de archivos, la lista de archivos se actualizará inmediatamente al cerrar el diálogo de las opciones. </para
><para
>Tenga en cuenta que cuando escribe un nuevo directorio completo también deseará copiar los archivos idénticos. En este caso active la opción «Mostrar archivos idénticos». Si su directorio de destino es una de las entradas, ésto no será necesario ya que el archivo ya estará aquí. </para
><para
>Si está satisfecho con ésto, el resto es sencillo. </para
><para
>Para fusionar todos los elementos: Seleccione «Comenzar/continuar fusión de directorio» en el menú «Directorio» o pulse F7 (que es el acceso rápido). Para fusionar solo el elemento actual: Seleccione «Realizar operación para el elemento actual» o pulse F6. </para
><para
>Si debido a tipos de archivos conflictivos todavía continúan existiendo operaciones no válidas, aparecerá un mensaje señalándolo, de forma que pueda seleccionar una operación válida para este elemento. </para
><para
>Si fusiona todos los elementos aparecerá un diálogo proporcionándole las opciones «Hacer», «Simular» y «Cancelar». </para>
<itemizedlist>
<listitem
><para
>Seleccione «Simular» si desea ver el resultado sin hacer la fusión. Se mostrará un lista de todas las operaciones.</para
></listitem>
<listitem
><para
>Sino seleccione «Hacer» para realizar el fusionado.</para
></listitem>
</itemizedlist>
<para
>Entonces &kdiff3; realizará las operaciones especificadas para todos los elementos. Si se precisa interacción manual (fusión de un solo archivo), aparecerá una ventana de fusión (<link linkend="dirmergebigscreenshot"
>vea la gran captura de pantalla</link
>). </para
><para
>Cuando haya terminado con un archivo, seleccione de nuevo «Comenzar/continuar fusión de directorio» o la tecla F7. Si todavía no la había guardado, un diálogo le preguntará para hacerlo. Entonces &kdiff3; continuará con el siguiente elemento. </para
><para
>Cuando &kdiff3; encuentre un error, éste se lo indicará con información literal del estado. En la parte inferior de la lista, aparecerán algunos mensajes de error que deberían ayudarle a entender la causa del problema. Cuando continúe con la fusión (tecla F7) &kdiff3; le permitirá reintentar o saltarse el elemento que provocó el problema. Esto significa que antes de continuar puede seleccionar otra operación o resolver el problema por otros medios. </para
><para
>Cuando la fusión se haya completado, &kdiff3; le informará a través de un cuadro de diálogo. </para
><para
>Si algunos elementos se fusionaron de forma individual &kdiff3; lo recordará (mientras esté en esta sesión de fusionado), y no les fusionará nuevamente cuando haga la fusión para todos los elementos. Incluso cuando se salte la fusión o no se guarde nada estos elementos se contarán como completos. Solo cuando cambie la operación de fusionado se eliminará el estado «hecho» del elemento y se podrá fusionar de nuevo. </para>
</sect1>
<sect1 id="dirmergeoptions"
><title
>Opciones para comparación y fusión de directorios</title>
<para
>Las preferencias de &kdiff3; (menú «Preferencias»->«Configurar &kdiff3;») ahora tienen una sección llamada «Fusión de directorio» con estas opciones: </para>
<variablelist>
<varlistentry
><term
><emphasis
>Directorios recursivos:</emphasis
></term
><listitem
><para
>Indica si se realizará la búsqueda en los directorios de forma recursiva.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Patrón(es) de archivo(s):</emphasis
></term
><listitem
><para
>Solo los archivos que coincidan con el patrón se colocarán en el árbol. Puede especificarse más de un patrón utilizando el punto y coma «;» como separador. Comodines válidos: «*» y «?» (p. ej. «*.cpp;*.h»). El valor predeterminado es «*». Este patrón no se utiliza en directorios.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Anti-patrón(es) de archivo:</emphasis
></term
><listitem
><para
>Los archivos y directorios que coincidan con este patrón se excluirán del árbol. Se puede especificar más de un patrón utilizando el «;» como separador. Comodines válidos: «*» y «?». El valor predeterminado es «*.orig;*.o;*.obj».</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Anti-patrón(es) de direcctorio:</emphasis
></term
><listitem
><para
>Los archivos y directorios que coincidan con este patrón se excluirán del árbol. Se puede especificar más de un patrón utilizando el «;» como separador. Comodines válidos: «*» y «?». El valor predeterminado es «CVS;deps;.svn».</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Usar .cvsignore:</emphasis
></term
><listitem
><para
>Ignora los archivos y directorios que también se vayan a ignorar por el CVS. Muchos archivos generados automáticamente se ingorarán por el CVS. La gran ventaja es que puede ser un directorio especificado a través del archivo local «.cvsignore» (vea <ulink url="info:/cvs/cvsignore"
>info:/cvs/cvsignore</ulink
>).</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Buscar archivos y directorios ocultos:</emphasis
></term
><listitem
><para
>En algunos sistemas de archivos tienen un atributo «Oculto». En otros sistemas el nombre de archivo comienza con un punto («.»), lo que hace que esté oculto. Esta opción le permite decidir si incluir o no estos archivos en el árbol. De forma predeterminada está activado.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Seguir enlaces de archivos:</emphasis
></term
><listitem
><para
>Para los enlaces de los archivos: Cuando esté desactivado, se compararán los enlaces simbólicos. Cuando esté activado, se compararán los archivos que estén detrás de los enlaces. De forma predeterminada está desactivada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Seguir enlaces de directorios:</emphasis
></term
><listitem
><para
>Para los enlaces de los directorios: Cuando esté desactivado se compararán los enlaces simbólicos. Cuando esté activado, el enlace será tratado como un directorio y se explorará recursivamente (tenga en cuenta que el programa no comprueba si el enlace es «recursivo»). Así por ejemplo, un directorio que contenga un enlace al directorio puede provocar un bucle infinito, y después de cierto tiempo podrá sobrecargar la pila o utilizar toda la memoria, colgando el programa). De forma predeterminada está desactivada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Comparación de nombres de archivo sensible a mayúsculas y minúsculas:</emphasis
></term
><listitem
><para
>El valor predeterminado es false (falso) para Windows, true (verdadero) para otros sistemas operativos.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Modo de comparación de archivos:</emphasis
></term
><listitem
><para>
<variablelist
>
<varlistentry
><term
><emphasis
>Comparación binaria:</emphasis
></term
><listitem
><para
>Éste es el modo de comparación de archivos predeterminado. </para
></listitem
></varlistentry
>
<varlistentry
><term
><emphasis
>Análisis completo:</emphasis
></term
><listitem
><para
>Hace un análisis completo de cada archivo y muestra las columnas de información estadística (número de conflictos resueltos, sin resolver, no blancos y blancos). El análisis completo es más lento que un simple análisis binario, y mucho más lento cuando se utiliza con archivos que no contienen texto (especifique el anti-patrón archivo). </para
></listitem
></varlistentry
>
<varlistentry
><term
><emphasis
>Validar la fecha de modificación:</emphasis
></term
><listitem
><para
>Si compara directorios grandes sobre una red lenta, es más rápido comparar solo las fechas de modificación y el tamaño del archivo. Pero esta mejora del rendimiento paga el precio de una pequeña inseguridad. Utilice esta opción con cuidado. De forma predeterminada estará desactivada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Validar el tamaño:</emphasis
></term
><listitem
><para
>Similar a la validación de la fecha. No hace comparaciones reales. Dos archivos se consideran iguales si sus tamaños son iguales. Esto es práctico cuando la operación de copiado no conserva la fecha de modificación. Utilice esta opción con cuidado. De forma predeterminada estará desactivada.</para
></listitem
></varlistentry>
</variablelist
></para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Sincronizar directorios:</emphasis
></term
><listitem
><para
>Activa el «Modo sincronizado» cuando se comparan dos directorios y no se especificó el directorio de destino. En este modo las operaciones propuestas se seleccionarán de forma que tras realizar la operación ambos directorios queden iguales. Por ello el resultado del fusionado se escribirá en ambos directorios. De forma predeterminada estará desactivada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Copiar el más nuevo en vez de fusionar:</emphasis
></term
><listitem
><para
>En lugar de fusionar la operación propuesta será copiar la fuente nueva si hubo algún cambio (considerado inseguro, ya que implica que el otro directorio no ha sido editado. Deberá hacer una comprobación para cada caso). De forma predeterminada estará desactivada.</para
></listitem
></varlistentry>
<varlistentry
><term
><emphasis
>Archivos de copia de seguridad:</emphasis
></term
><listitem
><para
>Si se reemplaza un archivo o directorio por otro o se borra, la versión original se renombrará con una extensión «.orig». Si ya existía un archivo con la extensión «.orig» se borrará sin hacer copia de seguridad. También afecta al fusionado normal de archivos simples, no solo al modo de fusionado de directorio. De forma predeterminada estará activada.</para
></listitem
></varlistentry>
</variablelist>
</sect1>
<sect1 id="other"
><title
>Otras funciones en la ventana del directorio de fusión</title>
<sect2
><title
>Modo de pantalla dividida/completa</title>
<para
>Normalmente la vista de la lista de fusionado de directorios permanece visible cuando se compara o fusiona un solo archivo. Con el ratón puede mover la barra divisoria que separa la lista de archivos de las ventanas de texto diff. Sino desea ésto, puede desactivar la «Vista de pantalla dividida» en el menú «Directorio». A continuación utilice «Cambiar vista» en el menú «Directorio» para conmutar entre la lista de archivos y la ventana de texto diff que ocupará la pantalla completa. </para>
</sect2>
<sect2
><title
>Comparar o fusionar un solo archivo</title>
<para
>Probablemente preferirá una doble pulsación del ratón sobre un archivo para compararlos. Sin embargo existe una entrada en el menú «Directorio». También puede fusionar directamente un solo archivo, sin iniciar el fusionado del directorio a través de la opción «Fusionar un solo archivo» en el menú «Directorio». Al guardar el resultado, el estado cambiará a «hecho», y el archivo no se fusionará si se inicia un fusionado de directorio. </para
><para
>Pero tenga en cuenta que la información del estado se perderá cuando vuelva a explorar un directorio: Menú «Directorio»->«Volver a buscar». </para>
</sect2>
<sect2
><title
>Comparar o fusionar archivos con nombres diferentes</title>
<para
>Algunas veces necesitará comparar o fusionar archivos con nombres diferentes (p. ej. el archivo actual y la copia de seguridad en la misma carpeta). </para
><para
>Seleccione el archivo exacto pulsando en el icono en la columna A, B o C. El primer archivo seleccionado se marcará con una «A», el segundo y tercero con «B» y «C» con independencia de la columna en la que esté. Solo se podrá seleccionar en la parte superior de los árboles de archivos. </para
><para
>Seleccione «Comparar explícitamente archivos seleccionados» o «Fusionar explícitamente archivos seleccionados» desde el menú «Directorio». Estas entradas también aparecerán como menú contextual cuando pulse el botón derecho cuando pulse el último archivo seleccionado. </para
><para
>La comparación o fusión de un archivo se realizará en la misma ventana. Si este método se utiliza para directorios se abrirá una ventana nueva. </para
></sect2>
</sect1>
</chapter>
<chapter id="misc">
<title
>Temas variados</title>
<sect1 id="networktransparency">
<title
>Transferencia de red a través de TDEIO</title>
<sect2
><title
>TDEIO-Slaves</title>
<para
>KDE soporta transparencia de red a través de los TDEIO-slaves. &kdiff3; lo utiliza para leer los archivos de entrada y para explorar directorios. Esto significa que puede especificar archivos y directorios locales y en recursos remotos a través de URLs. </para
><para
>Ejemplo: </para
><para>
<screen
><command
>kdiff3</command
> prueba.cpp ftp://ftp.muylejos.org/prueba.cpp
<command
>kdiff3</command
> tar:/home/hacker/archivo.tar.gz/dir ./dir
</screen>
</para>
<para
>La primera línea compara un archivo local con un archivo en un servidor FTP. La segunda línea compara un directorio con un archivo comprimido con un directorio local. </para
><para
>Otros TDEIO-slaves interesantes son: </para>
<itemizedlist>
<listitem
><para
>Archivos de la web (http:).</para
></listitem>
<listitem
><para
>Archivos desde el FTP (ftp:).</para
></listitem>
<listitem
><para
>Transferencia de archivos encriptados (fish:, sftp:).</para
></listitem>
<listitem
><para
>Recursos Windows (smb:).</para
></listitem>
<listitem
><para
>Archivos locales (file:).</para
></listitem>
</itemizedlist>
<para
>Otras cosas posibles, aunque probablemente poco prácticas son: </para>
<itemizedlist>
<listitem
><para
>Páginas de manual (man:).</para
></listitem>
<listitem
><para
>Páginas de información (info:).</para
></listitem>
</itemizedlist>
</sect2>
<sect2
><title
>Cómo escribir URLs</title>
<para
>Una URL tiene una sintaxis diferente comparada con las rutas de los archivos y directorios locales. Algunas cosas a considerar son: </para>
<itemizedlist>
<listitem
><para
>Una ruta puede ser relativa y puede contener «.» o «..» Ésto no es posible para URLs que son siempre absolutas. </para
></listitem
><listitem
><para
>Los caracteres especiales deben escribirse «escapados» («#» se convertirá en «%23», los espacios se convertirán en «%20» y así sucesivamente). P.ej. Un archivo con el nombre «/#foo#» tendrá el URL «file:///%23foo%23». </para
></listitem
><listitem
><para
>Cuando un URL no funcione tal y como esperaba, intente abrirla primero en Konqueror. </para
></listitem>
</itemizedlist>
</sect2>
<sect2
><title
>Capacidades de los TDEIO-Slaves.</title>
<para
>La transparencia de red tiene un inconveniente: No todos los recursos tienen las mismas capacidades. </para
><para
>Algunas veces esto es debido al sistema de archivos del servidor, otras al protocolo. Aquí tenemos una pequeña lista de restricciones: </para>
<itemizedlist>
<listitem
><para
>Algunas veces no soporta enlaces. </para
></listitem
><listitem
><para
>O no hay forma de distinguir si un enlace apunta a un archivo o a un directorio. Siempre se asume un archivo (ftp:, sftp:). </para
></listitem
><listitem
><para
>No siempre se puede determinar el tamaño del archivo. </para
></listitem
><listitem
><para
>Soporte limitado para los permisos. </para
></listitem
><listitem
><para
>No hay posibilidad de modificar los permisos o la hora, por ello los permisos o la hora de la copia puede diferir del original (vea la opción «Verificar tamaño»). La modificación de permisos o de la hora solo es posible en los archivos locales. </para
></listitem>
</itemizedlist>
</sect2>
</sect1>
<sect1 id="kpart">
<title
>Utilizar &kdiff3; como un KPart</title>
<para
>KDiff3 es un KPart. Actualmente implementa la interfaz KParts::ReadOnlyPart-interface. </para
><para
>Su principal utilización es la de visor de diferencias en KDevelop. KDevelop siempre inicia primero el visor interno de diferencias. Para llamar a &kdiff3; pulse el botón derecho del ratón en la ventana de diferencias y seleccione «Mostrar en KDiff3Part» en el menú contextual. </para
><para
>&kdiff3; normalmente requiere dos archivos completos como entrada. Cuando se utiliza como una parte &kdiff3; asume que el archivo de entrada es un archivo de parches en formato unificado. &kdiff3; recupera el nombre del archivo original del archivo del parche. Al menos uno de los dos archivos debe estar disponible. &kdiff3; llamará a <command
>patch</command
> para volver a crear el segundo archivo. </para
><para
>En Konqueror puede seleccionar un archivo de parche y seleccionar «Previsualizar en» - «KDiff3Part» desde el menú contextual. Sea consciente de que esto no funcionará si no está disponible ninguno de los archivos originales, y no será fiable si hubo modificaciones en el(los) archivo(s) original(es) desde que se generó el parche. </para
><para
>Cuando se ejecute como una parte, &kdiff3; solo proporcionará la diferencia de dos archivos, una pequeñísima barra de herramientas y un menú. La fusión y comparación de directorios no está soportada. </para>
</sect1>
</chapter>
<chapter id="faq">
<title
>Preguntas y respuestas</title>
&reporting.bugs; &updating.documentation; <qandaset id="faqlist">
<qandaentry
><question
><para
>¿Por qué se llama «&kdiff3;»? </para
></question
><answer
><para
>Las herramientas llamadas «KDiff» y «KDiff2» (ahora llamada «Kompare») ya existen. Por tanto «KDiff3» debería sugerir que incluye la fusión de forma similar a la herramienta «diff3» de la colección de herramientas Diff. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Por qué la he liberado bajo la GPL? </para
></question
><answer
><para
>He utilizado programas GPL durante mucho tiempo y aprendí mucho echando un vistazo a muchas fuentes. Ésta es mi forma de dar las «gracias» a todos programadores que han hecho lo mismo. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Faltan algunos botones y funciones. ¿Que está pasando? </para
></question
><answer
><para
>Compiló las fuentes, pero probablemente no especificó de forma correcta el parámetro «prefix» de KDE en configure. De forma predeterminada configure intentará instalarlo en /usr/local pero KDE no encuentra el archivo de recursos de la interfaz de usuario (p.ej. kdiff3ui.rc). El archivo README contiene más información sobre el parámetro «prefix» correcto. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Algunas líneas que son similares, pero no idénticas aparecen unas al lado de las otras, pero no siempre. ¿Por qué? </para
></question
><answer
><para
>Las líneas que solo contienen una cantidad diferente de espacios se tratan «igual» al principio, de forma que solo una diferencia en un caracter que no sea un espacio en blanco hará que las líneas sean «diferentes». Si aparecen líneas similares unas al lado de las otras, en realidad es una coincidencia, y sucede algunas veces. Consulte <link linkend="manualdiffhelp"
>el manual de ayuda de Diff</link
>. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Por que se deben resolver todos los conflictos de fusionado antes de guardarlos? </para
></question
><answer
><para
>Para cada sección ya sea igual o diferente el editor en la ventana de resultado de la fusión recordará su comienzo y su final. Ésto es necesario para que los conflictos puedan resolverse manualmente pulsando el botón de la fuente (A, B o C). Esta información se perderá cuando se guarde el texto y es demasiado complicado crear un formato de archivo especial que soporte el guardado y la restauración de toda la información. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Cómo puedo sincronizar las vista de diferencia y de fusión, de forma que todas muestren la misma posición de texto? </para
></question
><answer
><para
>Pulse en la columna de resumen situada a la izquierda del texto (<link linkend="synchronise_views"
>Consulte también estó.</link
>) </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Por qué el editor en la ventana de resultado no tiene una función «deshacer»? </para
></question
><answer
><para
>Es demasiado esfuerzo por el momento. Siempre puede restaurar una versión a partir de una fuente (A, B o C) pulsando el botón respectivo. Para editar archivos grandes se recomienda utilizar otro editor. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Cuando eliminó texto, de repente aparece «<Sin línea fuente>» y no se puede borrar. ¿Qué significa y cómo puedo eliminarlo? </para
></question
><answer
><para
>Para cada sección ya sea igual o diferente el editor en la ventana de resultado de la fusión recuerda dónde comienza y dónde termina. «<Sin línea fuente>» significa que no falta nada en una sección, ni siquiera un caracter de línea nueva. Esto puede suceder mientras realiza la fusión automática o mientras está editando. Ésto no es un problema, ya que no aparecerá en el archivo guardado. Si desea volver al archivo original seleccione la sección (pulse en la columna de resumen a la izquierda) y después pulse el botón de la fuente con los contenidos necesarios (A/B o C). </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Por qué &kdiff3; no soporta resaltado de sintaxis? </para
></question
><answer
><para
>&kdiff3; ya utiliza muchos colores para resaltar las diferencias. Más resaltado resultaría confuso. Utilice otro editor para esto. </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Puedo utilizar &kdiff3; para comparar archivos OpenOffice.Org, Word, Excel, Pdf, &etc;? </para
></question
><answer
><para
>A pesar de que &kdiff3; analizará cualquier tipo de archivo el resultado no será satisfactorio. </para
><para
>&kdiff3; se creó para comparar archivos de texto puro. OpenOffice, Word, Excel, etc. guardan mucha más información en los archivos (relativa a tipos de letra, imágenes, páginas, colores, etc.) con la que &kdiff3; no sabe qué hacer. Por tanto &kdiff3; le mostrará el contenido del archivo interpretado como si fuera texto puro, pero esto no es para lo que se utiliza. </para
><para
>Desde que muchos programa guardan su contenido en formato XML, puede ser capaz de leer éste como texto puro. Por tanto si el cambio es pequeño, &kdiff3; todavía puede ayudarle. </para
><para
>La mejor solución si solo desea comparar texto (sin objetos empotrados como imágenes) es utilizar «Seleccionar todo» y «Copiar» en su programa para copiar el texto interesante al portapapeles y a continuación pegar en &kdiff3; el texto en cualquiera de las ventanas de diferencias (Consulte también <link linkend="selections"
>Seleccionar, copiar y pegar</link
>). </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Donde está la opción de directorio «Listar solo deltas»? </para
></question
><answer
><para
>Ahora existen varias <link linkend="selectingvisiblefiles"
>opciones «Mostrar»</link
> en el menú directorio. Desactivar «Mostrar archivos idénticos» activará «Listar solo deltas» </para
></answer
></qandaentry>
<qandaentry
><question
><para
>¿Cómo puedo realizar una selección grande en la ventana de entrada de diferencias sin tardar demasiado tiempo? </para
></question
><answer
><para
>Inicie la selección de la forma habitual (pulse y mantenga pulsado el botón izquierdo del ratón). A continuación utilice las teclas de navegación (p.ej. RéPag, AvPág) manteniendo pulsado el botón izquierdo del ratón (consulte también <link linkend="selections"
>Seleccionar, copiar y pegar</link
>). </para
></answer
></qandaentry>
<qandaentry
><question
><para
>Aquí hay mucha información, pero ¿su pregunta no está respondida? </para
></question
><answer
><para
>Por favor, envíeme su pregunta. Aprecio todos los comentarios. </para
></answer
></qandaentry>
</qandaset>
</chapter>
<chapter id="credits">
<title
>Créditos y licencia</title>
<para
>&kdiff3; - Herramienta de comparación y fusionado de archivos y directorios. </para>
<para
>Program copyright 2002-2005 Joachim Eibl <email
>joachim.eibl at gmx.de</email
> </para>
<para
>Algunas buenas ideas e informes de fallos me llegaron de colegas y de mucha gente a lo largo de la red ¡Gracias! </para>
<para
>Documentation Copyright © 2002-2005 Joachim Eibl <email
>joachim.eibl at gmx.de</email
> </para>
<para
>Traducido por Santiago Fernández Sancho <email
>santi@kde-es.org</email
>.</para
>
&underFDL; &underGPL; </chapter>
<appendix id="installation">
<title
>Instalación</title>
<sect1 id="getting-kdiff3">
<title
>Cómo obtener &kdiff3;</title>
<para
>Puede descargar la última versión de &kdiff3; de su página principal: <ulink url="http://kdiff3.sourceforge.net"
>http://kdiff3.sourceforge.net</ulink
>. </para
><para
>&kdiff3; también está disponible para otras plataformas. Vea la página principal para obtener más detalles. </para>
</sect1>
<sect1 id="requirements">
<title
>Requerimientos</title>
<para
>Para utilizar adecuadamente todas las características de &kdiff3;, necesitará &kde; 3.1 o superior. </para
><para
>Para obtener información sobre cómo ejecutar &kdiff3; en otras plataformas sin KDE vea la <ulink url="http://kdiff3.sourceforge.net"
>página principal</ulink
>. </para
><para
>Puede encontrar una lista de cambios en <ulink url="http://kdiff3.sourceforge.net/ChangeLog"
>http://kdiff3.sourceforge.net/ChangeLog</ulink
> o en el archivo «ChangeLog» del paquete fuente. </para>
</sect1>
<sect1 id="compilation">
<title
>Compilación e instalación</title>
<para
>Para compilar en instalar &kdiff3; en un sistema con KDE, teclee lo siguiente en el directorio base de la distribución de &kdiff3;:</para>
<screen
><prompt
>%</prompt
> <userinput
><command
>./configure --prefix=<replaceable
>kde-dir</replaceable
></command
></userinput>
<prompt
>%</prompt
> <userinput
><command
>make</command
></userinput>
<prompt
>%</prompt
> <userinput
><command
>make</command
> install</userinput
>
</screen>
<para
><replaceable
>kde-dir</replaceable
> especifica el directorio que contiene KDE en su sistema. Sino está seguro, lea el archivo README para obtener los detalles. </para>
<para
>Sino utiliza KDE utilice <command
>configure</command
> pero siga las instrucciones para los sistemas que solo tienen Qt en el archivo README.</para>
<para
>Puesto que &kdiff3; utiliza <command
>autoconf</command
> y <command
>automake</command
> no debería tener problemas para compilarlo. Si tiene problemas al ejecutarlo, por favor, informe de ello a las listas de correo de &kde;.</para>
</sect1>
</appendix>
&documentation.index;
</book>
<!--
Local Variables:
mode: sgml
sgml-minimize-attributes:nil
sgml-general-insert-case:lower
sgml-indent-step:0
sgml-indent-data:nil
End:
vim:tabstop=2:shiftwidth=2:expandtab
-->
|