diff options
author | Paul Mackerras <paulus@samba.org> | 2008-02-16 12:24:52 +0100 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2008-02-16 12:24:52 +0100 |
commit | 585fb5985dcc5c129cb9f095c73dce88c8aacf77 (patch) | |
tree | a125709b0828193abf8c49b7460f84a16f13a411 | |
parent | gitk: Cope better with getting commits that we have already seen (diff) | |
parent | [PATCH] gitk: Heed the lines of context in merge commits (diff) | |
download | git-585fb5985dcc5c129cb9f095c73dce88c8aacf77.tar.xz git-585fb5985dcc5c129cb9f095c73dce88c8aacf77.zip |
Merge branch 'master' into dev
-rw-r--r-- | Makefile | 7 | ||||
-rwxr-xr-x | gitk | 122 | ||||
-rw-r--r-- | po/.gitignore | 1 | ||||
-rw-r--r-- | po/de.po | 418 | ||||
-rw-r--r-- | po/po2msg.sh | 133 |
5 files changed, 427 insertions, 254 deletions
@@ -18,7 +18,12 @@ TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH)) ## po-file creation rules XGETTEXT ?= xgettext -MSGFMT ?= msgfmt +ifdef NO_MSGFMT + MSGFMT ?= $(TCL_PATH) po/po2msg.sh +else + MSGFMT ?= msgfmt +endif + PO_TEMPLATE = po/gitk.pot ALL_POFILES = $(wildcard po/*.po) ALL_MSGFILES = $(subst .po,.msg,$(ALL_POFILES)) @@ -1039,11 +1039,12 @@ proc getcommitlines {fd inst view} { set listed 1 if {$j >= 0 && [string match "commit *" $cmit]} { set ids [string range $cmit 7 [expr {$j - 1}]] - if {[string match {[-<>]*} $ids]} { + if {[string match {[-^<>]*} $ids]} { switch -- [string index $ids 0] { "-" {set listed 0} - "<" {set listed 2} - ">" {set listed 3} + "^" {set listed 2} + "<" {set listed 3} + ">" {set listed 4} } set ids [string range $ids 1 end] } @@ -1412,6 +1413,7 @@ proc makewindow {} { global findtype findtypemenu findloc findstring fstring geometry global entries sha1entry sha1string sha1but global diffcontextstring diffcontext + global ignorespace global maincursor textcursor curtextcursor global rowctxmenu fakerowmenu mergemax wrapcomment global highlight_files gdttype @@ -1630,6 +1632,9 @@ proc makewindow {} { trace add variable diffcontextstring write diffcontextchange lappend entries .bleft.mid.diffcontext pack .bleft.mid.labeldiffcontext .bleft.mid.diffcontext -side left + checkbutton .bleft.mid.ignspace -text [mc "Ignore space change"] \ + -command changeignorespace -variable ignorespace + pack .bleft.mid.ignspace -side left -padx 5 set ctext .bleft.ctext text $ctext -background $bgcolor -foreground $fgcolor \ -state disabled -font textfont \ @@ -1777,6 +1782,7 @@ proc makewindow {} { bind . <$M1B-r> dosearchback bind . <$M1B-s> dosearch bind . <$M1B-equal> {incrfont 1} + bind . <$M1B-plus> {incrfont 1} bind . <$M1B-KP_Add> {incrfont 1} bind . <$M1B-minus> {incrfont -1} bind . <$M1B-KP_Subtract> {incrfont -1} @@ -2087,45 +2093,45 @@ proc keys {} { } toplevel $w wm title $w [mc "Gitk key bindings"] - message $w.m -text [mc " -Gitk key bindings: - -<$M1T-Q> Quit -<Home> Move to first commit -<End> Move to last commit -<Up>, p, i Move up one commit -<Down>, n, k Move down one commit -<Left>, z, j Go back in history list -<Right>, x, l Go forward in history list -<PageUp> Move up one page in commit list -<PageDown> Move down one page in commit list -<$M1T-Home> Scroll to top of commit list -<$M1T-End> Scroll to bottom of commit list -<$M1T-Up> Scroll commit list up one line -<$M1T-Down> Scroll commit list down one line -<$M1T-PageUp> Scroll commit list up one page -<$M1T-PageDown> Scroll commit list down one page -<Shift-Up> Find backwards (upwards, later commits) -<Shift-Down> Find forwards (downwards, earlier commits) -<Delete>, b Scroll diff view up one page -<Backspace> Scroll diff view up one page -<Space> Scroll diff view down one page -u Scroll diff view up 18 lines -d Scroll diff view down 18 lines -<$M1T-F> Find -<$M1T-G> Move to next find hit -<Return> Move to next find hit -/ Move to next find hit, or redo find -? Move to previous find hit -f Scroll diff view to next file -<$M1T-S> Search for next hit in diff view -<$M1T-R> Search for previous hit in diff view -<$M1T-KP+> Increase font size -<$M1T-plus> Increase font size -<$M1T-KP-> Decrease font size -<$M1T-minus> Decrease font size -<F5> Update -"] \ + message $w.m -text " +[mc "Gitk key bindings:"] + +[mc "<%s-Q> Quit" $M1T] +[mc "<Home> Move to first commit"] +[mc "<End> Move to last commit"] +[mc "<Up>, p, i Move up one commit"] +[mc "<Down>, n, k Move down one commit"] +[mc "<Left>, z, j Go back in history list"] +[mc "<Right>, x, l Go forward in history list"] +[mc "<PageUp> Move up one page in commit list"] +[mc "<PageDown> Move down one page in commit list"] +[mc "<%s-Home> Scroll to top of commit list" $M1T] +[mc "<%s-End> Scroll to bottom of commit list" $M1T] +[mc "<%s-Up> Scroll commit list up one line" $M1T] +[mc "<%s-Down> Scroll commit list down one line" $M1T] +[mc "<%s-PageUp> Scroll commit list up one page" $M1T] +[mc "<%s-PageDown> Scroll commit list down one page" $M1T] +[mc "<Shift-Up> Find backwards (upwards, later commits)"] +[mc "<Shift-Down> Find forwards (downwards, earlier commits)"] +[mc "<Delete>, b Scroll diff view up one page"] +[mc "<Backspace> Scroll diff view up one page"] +[mc "<Space> Scroll diff view down one page"] +[mc "u Scroll diff view up 18 lines"] +[mc "d Scroll diff view down 18 lines"] +[mc "<%s-F> Find" $M1T] +[mc "<%s-G> Move to next find hit" $M1T] +[mc "<Return> Move to next find hit"] +[mc "/ Move to next find hit, or redo find"] +[mc "? Move to previous find hit"] +[mc "f Scroll diff view to next file"] +[mc "<%s-S> Search for next hit in diff view" $M1T] +[mc "<%s-R> Search for previous hit in diff view" $M1T] +[mc "<%s-KP+> Increase font size" $M1T] +[mc "<%s-plus> Increase font size" $M1T] +[mc "<%s-KP-> Decrease font size" $M1T] +[mc "<%s-minus> Decrease font size" $M1T] +[mc "<F5> Update"] +" \ -justify left -bg white -border 2 -relief groove pack $w.m -side top -fill both -padx 2 -pady 2 button $w.ok -text [mc "Close"] -command "destroy $w" -default active @@ -3365,12 +3371,12 @@ proc askrelhighlight {row id} { if {![info exists selectedline]} return set isbold 0 - if {$highlight_related eq [mc "Descendent"] || - $highlight_related eq [mc "Not descendent"]} { + if {$highlight_related eq [mc "Descendant"] || + $highlight_related eq [mc "Not descendant"]} { if {![info exists descendent($id)]} { is_descendent $id } - if {$descendent($id) == ($highlight_related eq [mc "Descendent"])} { + if {$descendent($id) == ($highlight_related eq [mc "Descendant"])} { set isbold 1 } } elseif {$highlight_related eq [mc "Ancestor"] || @@ -4386,23 +4392,23 @@ proc drawcmittext {id row col} { global linehtag linentag linedtag selectedline global canvxmax boldrows boldnamerows fgcolor nullid nullid2 - # listed is 0 for boundary, 1 for normal, 2 for left, 3 for right + # listed is 0 for boundary, 1 for normal, 2 for negative, 3 for left, 4 for right set listed $cmitlisted($curview,$id) if {$id eq $nullid} { set ofill red } elseif {$id eq $nullid2} { set ofill green } else { - set ofill [expr {$listed != 0? "blue": "white"}] + set ofill [expr {$listed != 0 ? $listed == 2 ? "gray" : "blue" : "white"}] } set x [xc $row $col] set y [yc $row] set orad [expr {$linespc / 3}] - if {$listed <= 1} { + if {$listed <= 2} { set t [$canv create oval [expr {$x - $orad}] [expr {$y - $orad}] \ [expr {$x + $orad - 1}] [expr {$y + $orad - 1}] \ -fill $ofill -outline $fgcolor -width 1 -tags circle] - } elseif {$listed == 2} { + } elseif {$listed == 3} { # triangle pointing left for left-side commits set t [$canv create polygon \ [expr {$x - $orad}] $y \ @@ -5775,12 +5781,13 @@ proc mergediff {id} { global diffmergeid mdifffd global diffids global parents + global diffcontext global limitdiffs viewfiles curview set diffmergeid $id set diffids $id # this doesn't seem to actually affect anything... - set cmd [concat | git diff-tree --no-commit-id --cc $id] + set cmd [concat | git diff-tree --no-commit-id --cc -U$diffcontext $id] if {$limitdiffs && $viewfiles($curview) ne {}} { set cmd [concat $cmd -- $viewfiles($curview)] } @@ -6017,13 +6024,21 @@ proc diffcontextchange {n1 n2 op} { } } +proc changeignorespace {} { + reselectline +} + proc getblobdiffs {ids} { global blobdifffd diffids env global diffinhdr treediffs global diffcontext + global ignorespace global limitdiffs viewfiles curview set cmd [diffcmd $ids "-p -C --no-commit-id -U$diffcontext"] + if {$ignorespace} { + append cmd " -w" + } if {$limitdiffs && $viewfiles($curview) ne {}} { set cmd [concat $cmd -- $viewfiles($curview)] } @@ -6878,11 +6893,7 @@ proc domktag {} { return } if {[catch { - set dir [gitdir] - set fname [file join $dir "refs/tags" $tag] - set f [open $fname w] - puts $f $id - close $f + exec git tag $tag $id } err]} { error_popup "[mc "Error creating tag:"] $err" return @@ -9210,6 +9221,7 @@ set bgcolor white set fgcolor black set diffcolors {red "#00a000" blue} set diffcontext 3 +set ignorespace 0 set selectbgcolor gray85 ## For msgcat loading, first locate the installation location. diff --git a/po/.gitignore b/po/.gitignore new file mode 100644 index 0000000000..e358dd1903 --- /dev/null +++ b/po/.gitignore @@ -0,0 +1 @@ +*.msg @@ -7,8 +7,8 @@ msgid "" msgstr "" "Project-Id-Version: git-gui\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2007-12-21 12:04+0100\n" -"PO-Revision-Date: 2008-01-08 21:48+0100\n" +"POT-Creation-Date: 2008-01-09 22:20+0100\n" +"PO-Revision-Date: 2008-01-09 22:21+0100\n" "Last-Translator: Christian Stimming <stimming@tuhh.de>\n" "Language-Team: German\n" "MIME-Version: 1.0\n" @@ -17,13 +17,13 @@ msgstr "" #: gitk:101 msgid "Error executing git rev-list:" -msgstr "" +msgstr "Fehler beim Ausführen von git-rev-list:" #: gitk:114 msgid "Reading" msgstr "Lesen" -#: gitk:141 gitk:2151 +#: gitk:141 gitk:2143 msgid "Reading commits..." msgstr "Versionen lesen..." @@ -31,197 +31,197 @@ msgstr "Versionen lesen..." msgid "Can't parse git log output:" msgstr "Git log Ausgabe kann nicht erkannt werden:" -#: gitk:375 gitk:2155 +#: gitk:375 gitk:2147 msgid "No commits selected" msgstr "Keine Versionen ausgewählt." #: gitk:486 msgid "No commit information available" -msgstr "" +msgstr "Keine Versionsinformation verfügbar" -#: gitk:585 gitk:607 gitk:1914 gitk:6374 gitk:7875 gitk:8035 +#: gitk:585 gitk:607 gitk:1908 gitk:6366 gitk:7866 gitk:8020 msgid "OK" msgstr "Ok" -#: gitk:609 gitk:1916 gitk:6054 gitk:6125 gitk:6226 gitk:6272 gitk:6376 -#: gitk:7877 gitk:8037 +#: gitk:609 gitk:1909 gitk:6046 gitk:6117 gitk:6218 gitk:6264 gitk:6368 +#: gitk:7867 gitk:8021 msgid "Cancel" msgstr "Abbrechen" -#: gitk:633 +#: gitk:646 msgid "File" msgstr "Datei" -#: gitk:636 +#: gitk:648 msgid "Update" msgstr "Aktualisieren" -#: gitk:637 +#: gitk:649 msgid "Reread references" msgstr "Zweige neu laden" -#: gitk:638 +#: gitk:650 msgid "List references" msgstr "Zweige auflisten" -#: gitk:639 +#: gitk:651 msgid "Quit" msgstr "Beenden" -#: gitk:642 +#: gitk:653 msgid "Edit" msgstr "Bearbeiten" -#: gitk:643 +#: gitk:654 msgid "Preferences" msgstr "Einstellungen" -#: gitk:647 +#: gitk:657 msgid "View" msgstr "Ansicht" -#: gitk:648 +#: gitk:658 msgid "New view..." msgstr "Neue Ansicht..." -#: gitk:649 gitk:2093 gitk:8666 +#: gitk:659 gitk:2085 gitk:8651 msgid "Edit view..." msgstr "Ansicht bearbeiten..." -#: gitk:651 gitk:2094 gitk:8667 +#: gitk:661 gitk:2086 gitk:8652 msgid "Delete view" msgstr "Ansicht löschen" -#: gitk:653 +#: gitk:663 msgid "All files" msgstr "Alle Dateien" -#: gitk:657 +#: gitk:667 msgid "Help" msgstr "Hilfe" -#: gitk:658 gitk:1280 +#: gitk:668 gitk:1280 msgid "About gitk" msgstr "Über gitk" -#: gitk:659 +#: gitk:669 msgid "Key bindings" msgstr "Tastenkürzel" -#: gitk:716 +#: gitk:726 msgid "SHA1 ID: " -msgstr "" +msgstr "SHA1:" -#: gitk:766 +#: gitk:776 msgid "Find" msgstr "Suche" -#: gitk:767 +#: gitk:777 msgid "next" msgstr "nächste" -#: gitk:768 +#: gitk:778 msgid "prev" msgstr "vorige" -#: gitk:769 +#: gitk:779 msgid "commit" msgstr "Version" -#: gitk:772 gitk:774 gitk:2316 gitk:2339 gitk:2363 gitk:4265 gitk:4328 +#: gitk:782 gitk:784 gitk:2308 gitk:2331 gitk:2355 gitk:4257 gitk:4320 msgid "containing:" msgstr "enthaltend:" -#: gitk:775 gitk:1746 gitk:1751 gitk:2391 +#: gitk:785 gitk:1741 gitk:1746 gitk:2383 msgid "touching paths:" msgstr "Pfad betreffend:" -#: gitk:776 gitk:2396 +#: gitk:786 gitk:2388 msgid "adding/removing string:" msgstr "String dazu/löschen:" -#: gitk:787 gitk:789 +#: gitk:795 gitk:797 msgid "Exact" msgstr "Exakt" -#: gitk:789 gitk:2474 gitk:4233 +#: gitk:797 gitk:2466 gitk:4225 msgid "IgnCase" msgstr "Kein Groß/Klein" -#: gitk:789 gitk:2365 gitk:2472 gitk:4229 +#: gitk:797 gitk:2357 gitk:2464 gitk:4221 msgid "Regexp" msgstr "Regexp" -#: gitk:793 gitk:794 gitk:2493 gitk:2523 gitk:2530 gitk:4339 gitk:4395 +#: gitk:799 gitk:800 gitk:2485 gitk:2515 gitk:2522 gitk:4331 gitk:4387 msgid "All fields" msgstr "Alle Felder" -#: gitk:794 gitk:2491 gitk:2523 gitk:4295 +#: gitk:800 gitk:2483 gitk:2515 gitk:4287 msgid "Headline" msgstr "Überschrift" -#: gitk:795 gitk:2491 gitk:4295 gitk:4395 gitk:4783 +#: gitk:801 gitk:2483 gitk:4287 gitk:4387 gitk:4775 msgid "Comments" msgstr "Beschreibung" -#: gitk:795 gitk:2491 gitk:2495 gitk:2530 gitk:4295 gitk:4719 gitk:5903 -#: gitk:5918 +#: gitk:801 gitk:2483 gitk:2487 gitk:2522 gitk:4287 gitk:4711 gitk:5895 +#: gitk:5910 msgid "Author" msgstr "Autor" -#: gitk:795 gitk:2491 gitk:4295 gitk:4721 +#: gitk:801 gitk:2483 gitk:4287 gitk:4713 msgid "Committer" msgstr "Eintragender" -#: gitk:825 +#: gitk:829 msgid "Search" msgstr "Suche" -#: gitk:833 +#: gitk:836 msgid "Diff" msgstr "Vergleich" -#: gitk:835 +#: gitk:838 msgid "Old version" msgstr "Alte Version" -#: gitk:837 +#: gitk:840 msgid "New version" msgstr "Neue Version" -#: gitk:839 +#: gitk:842 msgid "Lines of context" msgstr "Kontextzeilen" -#: gitk:898 +#: gitk:900 msgid "Patch" -msgstr "" +msgstr "Patch" -#: gitk:901 +#: gitk:902 msgid "Tree" msgstr "Baum" -#: gitk:1018 gitk:1033 gitk:5969 +#: gitk:1018 gitk:1033 gitk:5961 msgid "Diff this -> selected" msgstr "Vergleich diese -> gewählte" -#: gitk:1020 gitk:1035 gitk:5970 +#: gitk:1020 gitk:1035 gitk:5962 msgid "Diff selected -> this" msgstr "Vergleich gewählte -> diese" -#: gitk:1022 gitk:1037 gitk:5971 +#: gitk:1022 gitk:1037 gitk:5963 msgid "Make patch" msgstr "Patch erstellen" -#: gitk:1023 gitk:6109 +#: gitk:1023 gitk:6101 msgid "Create tag" msgstr "Markierung erstellen" -#: gitk:1024 gitk:6206 +#: gitk:1024 gitk:6198 msgid "Write commit to file" msgstr "Version in Datei schreiben" -#: gitk:1025 gitk:6260 +#: gitk:1025 gitk:6252 msgid "Create new branch" msgstr "Neuen Zweig erstellen" @@ -243,11 +243,11 @@ msgstr "Zweig löschen" #: gitk:1052 msgid "Highlight this too" -msgstr "" +msgstr "Diesen auch hervorheben" #: gitk:1054 msgid "Highlight this only" -msgstr "" +msgstr "Nur diesen hervorheben" #: gitk:1281 msgid "" @@ -258,261 +258,271 @@ msgid "" "\n" "Use and redistribute under the terms of the GNU General Public License" msgstr "" +"\n" +"Gitk - eine Visualisierung der Git Historie\n" +"\n" +"Copyright © 2005-2006 Paul Mackerras\n" +"\n" +"Benutzung und Weiterverbreitung gemäß den Bedingungen der GNU General Public " +"License\n" +" " -#: gitk:1290 gitk:1354 gitk:6532 +#: gitk:1289 gitk:1350 gitk:6524 msgid "Close" msgstr "Schließen" -#: gitk:1311 +#: gitk:1308 msgid "Gitk key bindings" -msgstr "" +msgstr "Gitk Tastaturbelegung" -#: gitk:1863 +#: gitk:1858 msgid "Gitk view definition" -msgstr "" +msgstr "Gitk Ansichten" -#: gitk:1888 +#: gitk:1882 msgid "Name" msgstr "Name" -#: gitk:1891 +#: gitk:1885 msgid "Remember this view" msgstr "Diese Ansicht speichern" -#: gitk:1895 +#: gitk:1889 msgid "Commits to include (arguments to git rev-list):" -msgstr "" +msgstr "Versionen anzeigen (Argumente von git-rev-list):" -#: gitk:1901 +#: gitk:1895 msgid "Enter files and directories to include, one per line:" -msgstr "" +msgstr "Folgende Dateien und Verzeichnisse anzeigen (eine pro Zeile):" -#: gitk:1950 +#: gitk:1942 msgid "Error in commit selection arguments:" -msgstr "" +msgstr "Fehler in den ausgewählten Versionen:" -#: gitk:2001 gitk:2087 gitk:2543 gitk:2557 gitk:3740 gitk:8635 gitk:8636 +#: gitk:1993 gitk:2079 gitk:2535 gitk:2549 gitk:3732 gitk:8620 gitk:8621 msgid "None" msgstr "Keine" -#: gitk:2491 gitk:4295 gitk:5905 gitk:5920 +#: gitk:2483 gitk:4287 gitk:5897 gitk:5912 msgid "Date" msgstr "Datum" -#: gitk:2491 gitk:4295 +#: gitk:2483 gitk:4287 msgid "CDate" msgstr "Eintragedatum" -#: gitk:2640 gitk:2645 -msgid "Descendent" -msgstr "" +#: gitk:2632 gitk:2637 +msgid "Descendant" +msgstr "Abkömmling" -#: gitk:2641 -msgid "Not descendent" -msgstr "" +#: gitk:2633 +msgid "Not descendant" +msgstr "Nicht Abkömmling" -#: gitk:2648 gitk:2653 +#: gitk:2640 gitk:2645 msgid "Ancestor" -msgstr "" +msgstr "Vorgänger" -#: gitk:2649 +#: gitk:2641 msgid "Not ancestor" -msgstr "" +msgstr "Nicht Vorgänger" -#: gitk:2883 +#: gitk:2875 msgid "Local changes checked in to index but not committed" msgstr "Lokale Änderungen bereitgestellt, aber nicht eingetragen" -#: gitk:2913 +#: gitk:2905 msgid "Local uncommitted changes, not checked in to index" msgstr "Lokale Änderungen, nicht bereitgestellt" -#: gitk:4264 +#: gitk:4256 msgid "Searching" msgstr "Suchen" -#: gitk:4723 +#: gitk:4715 msgid "Tags:" msgstr "Markierungen:" -#: gitk:4740 gitk:4746 gitk:5898 +#: gitk:4732 gitk:4738 gitk:5890 msgid "Parent" msgstr "Eltern" -#: gitk:4751 +#: gitk:4743 msgid "Child" msgstr "Kind" -#: gitk:4760 +#: gitk:4752 msgid "Branch" msgstr "Zweig" -#: gitk:4763 +#: gitk:4755 msgid "Follows" -msgstr "" +msgstr "Folgt auf" -#: gitk:4766 +#: gitk:4758 msgid "Precedes" -msgstr "" +msgstr "Vorgänger von" -#: gitk:5048 +#: gitk:5040 msgid "Error getting merge diffs:" msgstr "Fehler beim Laden des Vergleichs:" -#: gitk:5725 +#: gitk:5717 msgid "Goto:" -msgstr "" +msgstr "Gehe zu:" -#: gitk:5727 +#: gitk:5719 msgid "SHA1 ID:" -msgstr "" +msgstr "SHA1 Kennung:" -#: gitk:5752 +#: gitk:5744 #, tcl-format msgid "Short SHA1 id %s is ambiguous" -msgstr "" +msgstr "Kurze SHA1-Kennung »%s« ist mehrdeutig" -#: gitk:5764 +#: gitk:5756 #, tcl-format msgid "SHA1 id %s is not known" -msgstr "" +msgstr "SHA1-Kennung »%s« unbekannt" -#: gitk:5766 +#: gitk:5758 #, tcl-format msgid "Tag/Head %s is not known" -msgstr "" +msgstr "Markierung/Zweig »%s« ist unbekannt" -#: gitk:5908 +#: gitk:5900 msgid "Children" msgstr "Kinder" -#: gitk:5965 +#: gitk:5957 #, tcl-format msgid "Reset %s branch to here" msgstr "Zweig »%s« hierher zurücksetzen" -#: gitk:5996 +#: gitk:5988 msgid "Top" msgstr "Oben" -#: gitk:5997 +#: gitk:5989 msgid "From" msgstr "Von" -#: gitk:6002 +#: gitk:5994 msgid "To" msgstr "bis" -#: gitk:6025 +#: gitk:6017 msgid "Generate patch" msgstr "Patch erstellen" -#: gitk:6027 +#: gitk:6019 msgid "From:" msgstr "Von:" -#: gitk:6036 +#: gitk:6028 msgid "To:" msgstr "bis:" -#: gitk:6045 +#: gitk:6037 msgid "Reverse" msgstr "Umgekehrt" -#: gitk:6047 gitk:6220 +#: gitk:6039 gitk:6212 msgid "Output file:" -msgstr "" +msgstr "Ausgabedatei:" -#: gitk:6053 +#: gitk:6045 msgid "Generate" msgstr "Erzeugen" -#: gitk:6089 +#: gitk:6081 msgid "Error creating patch:" -msgstr "" +msgstr "Fehler beim Patch erzeugen:" -#: gitk:6111 gitk:6208 gitk:6262 +#: gitk:6103 gitk:6200 gitk:6254 msgid "ID:" -msgstr "" +msgstr "ID:" -#: gitk:6120 +#: gitk:6112 msgid "Tag name:" msgstr "Markierungsname:" -#: gitk:6124 gitk:6271 +#: gitk:6116 gitk:6263 msgid "Create" msgstr "Erstellen" -#: gitk:6139 +#: gitk:6131 msgid "No tag name specified" -msgstr "" +msgstr "Kein Markierungsname angegeben" -#: gitk:6143 +#: gitk:6135 #, tcl-format msgid "Tag \"%s\" already exists" msgstr "Markierung »%s« existiert bereits." -#: gitk:6153 +#: gitk:6145 msgid "Error creating tag:" -msgstr "" +msgstr "Fehler bei Markierung erstellen:" -#: gitk:6217 +#: gitk:6209 msgid "Command:" -msgstr "" +msgstr "Kommando:" -#: gitk:6225 +#: gitk:6217 msgid "Write" msgstr "Schreiben" -#: gitk:6241 +#: gitk:6233 msgid "Error writing commit:" -msgstr "" +msgstr "Fehler beim Version eintragen:" -#: gitk:6267 +#: gitk:6259 msgid "Name:" msgstr "Name:" -#: gitk:6286 +#: gitk:6278 msgid "Please specify a name for the new branch" -msgstr "" +msgstr "Bitte geben Sie einen Namen für den neuen Zweig an." -#: gitk:6315 +#: gitk:6307 #, tcl-format msgid "Commit %s is already included in branch %s -- really re-apply it?" msgstr "" +"Version »%s« ist bereits im Zweig »%s« enthalten -- trotzdem erneut " +"eintragen?" -#: gitk:6320 +#: gitk:6312 msgid "Cherry-picking" msgstr "Version pflücken" -#: gitk:6332 +#: gitk:6324 msgid "No changes committed" msgstr "Keine Änderungen eingetragen" -#: gitk:6355 +#: gitk:6347 msgid "Confirm reset" msgstr "Zurücksetzen bestätigen" -#: gitk:6357 +#: gitk:6349 #, tcl-format msgid "Reset branch %s to %s?" msgstr "Zweig »%s« auf »%s« zurücksetzen?" -#: gitk:6361 +#: gitk:6353 msgid "Reset type:" msgstr "Art des Zurücksetzens:" -#: gitk:6365 +#: gitk:6357 msgid "Soft: Leave working tree and index untouched" msgstr "Harmlos: Arbeitskopie und Bereitstellung unverändert" -#: gitk:6368 +#: gitk:6360 msgid "Mixed: Leave working tree untouched, reset index" msgstr "" "Gemischt: Arbeitskopie unverändert,\n" "Bereitstellung zurückgesetzt" -#: gitk:6371 +#: gitk:6363 msgid "" "Hard: Reset working tree and index\n" "(discard ALL local changes)" @@ -520,184 +530,196 @@ msgstr "" "Hart: Arbeitskopie und Bereitstellung\n" "(Alle lokalen Änderungen werden gelöscht)" -#: gitk:6387 +#: gitk:6379 msgid "Resetting" msgstr "Zurücksetzen" -#: gitk:6444 +#: gitk:6436 msgid "Checking out" msgstr "Umstellen" -#: gitk:6474 +#: gitk:6466 msgid "Cannot delete the currently checked-out branch" -msgstr "Der Zweig, auf den die Arbeitskopie momentan umgestellt ist, kann nicht gelöscht werden." +msgstr "" +"Der Zweig, auf den die Arbeitskopie momentan umgestellt ist, kann nicht " +"gelöscht werden." -#: gitk:6480 +#: gitk:6472 #, tcl-format msgid "" "The commits on branch %s aren't on any other branch.\n" "Really delete branch %s?" msgstr "" +"Die Versionen auf Zweig »%s« existieren auf keinem anderen Zweig.\n" +"Zweig »%s« trotzdem löschen?" -#: gitk:6511 +#: gitk:6503 #, tcl-format msgid "Tags and heads: %s" -msgstr "" +msgstr "Markierungen und Zweige: %s" -#: gitk:6525 +#: gitk:6517 msgid "Filter" -msgstr "" +msgstr "Filtern" -#: gitk:6820 +#: gitk:6811 msgid "" "Error reading commit topology information; branch and preceding/following " "tag information will be incomplete." msgstr "" +"Fehler beim Lesen der Strukturinformationen; Zweige und Vorgänger/Nachfolger " +"Informationen werden unvollständig sein." -#: gitk:7804 +#: gitk:7795 msgid "Tag" msgstr "Markierung" -#: gitk:7804 +#: gitk:7795 msgid "Id" -msgstr "" +msgstr "Id" -#: gitk:7844 +#: gitk:7835 msgid "Gitk font chooser" -msgstr "" +msgstr "Gitk Schriften wählen" -#: gitk:7861 +#: gitk:7852 msgid "B" msgstr "F" -#: gitk:7864 +#: gitk:7855 msgid "I" msgstr "K" -#: gitk:7959 +#: gitk:7948 msgid "Gitk preferences" msgstr "Gitk Einstellungen" -#: gitk:7960 +#: gitk:7949 msgid "Commit list display options" msgstr "Anzeige Versionsliste" -#: gitk:7964 +#: gitk:7952 msgid "Maximum graph width (lines)" msgstr "Maximale Graphenbreite (Zeilen)" -#: gitk:7968 +#: gitk:7956 #, tcl-format msgid "Maximum graph width (% of pane)" msgstr "Maximale Graphenbreite (% des Fensters)" -#: gitk:7973 +#: gitk:7961 msgid "Show local changes" msgstr "Lokale Änderungen anzeigen" -#: gitk:7978 +#: gitk:7966 msgid "Diff display options" msgstr "Anzeige Vergleich" -#: gitk:7981 +#: gitk:7968 msgid "Tab spacing" msgstr "Tabulatorbreite" -#: gitk:7985 +#: gitk:7972 msgid "Display nearby tags" -msgstr "" +msgstr "Naheliegende Überschriften anzeigen" -#: gitk:7990 +#: gitk:7977 msgid "Limit diffs to listed paths" msgstr "Vergleich nur für angezeigte Pfade" -#: gitk:7995 +#: gitk:7982 msgid "Colors: press to choose" msgstr "Farben: Klicken zum Wählen" -#: gitk:7999 +#: gitk:7985 msgid "Background" msgstr "Vordergrund" -#: gitk:8003 +#: gitk:7989 msgid "Foreground" msgstr "Hintergrund" -#: gitk:8007 +#: gitk:7993 msgid "Diff: old lines" msgstr "Vergleich: Alte Zeilen" -#: gitk:8012 +#: gitk:7998 msgid "Diff: new lines" msgstr "Vergleich: Neue Zeilen" -#: gitk:8017 +#: gitk:8003 msgid "Diff: hunk header" msgstr "Vergleich: Änderungstitel" -#: gitk:8023 +#: gitk:8009 msgid "Select bg" msgstr "Hintergrundfarbe Auswählen" -#: gitk:8027 +#: gitk:8013 msgid "Fonts: press to choose" msgstr "Schriftart: Klicken zum Wählen" -#: gitk:8030 +#: gitk:8015 msgid "Main font" msgstr "Programmschriftart" -#: gitk:8031 +#: gitk:8016 msgid "Diff display font" msgstr "Vergleich" -#: gitk:8032 +#: gitk:8017 msgid "User interface font" msgstr "Beschriftungen" -#: gitk:8050 +#: gitk:8033 #, tcl-format msgid "Gitk: choose color for %s" msgstr "Gitk: Farbe wählen für %s" -#: gitk:8431 +#: gitk:8414 msgid "" "Sorry, gitk cannot run with this version of Tcl/Tk.\n" " Gitk requires at least Tcl/Tk 8.4." msgstr "" +"Gitk läuft nicht mit dieser Version von Tcl/Tk.\n" +"Gitk benötigt mindestens Tcl/Tk 8.4." -#: gitk:8516 +#: gitk:8501 msgid "Cannot find a git repository here." msgstr "Kein Git-Projektarchiv gefunden." -#: gitk:8520 +#: gitk:8505 #, tcl-format msgid "Cannot find the git directory \"%s\"." -msgstr "" +msgstr "Git-Verzeichnis »%s« wurde nicht gefunden." -#: gitk:8559 +#: gitk:8544 #, tcl-format msgid "Ambiguous argument '%s': both revision and filename" -msgstr "" +msgstr "Mehrdeutige Angabe »%s«: Sowohl Version als auch Dateiname existiert." -#: gitk:8571 +#: gitk:8556 msgid "Bad arguments to gitk:" -msgstr "" +msgstr "Falsche Kommandozeilen-Parameter für gitk:" -#: gitk:8583 +#: gitk:8568 msgid "Couldn't get list of unmerged files:" -msgstr "" +msgstr "Liste der nicht-zusammengeführten Dateien nicht gefunden:" -#: gitk:8599 +#: gitk:8584 msgid "No files selected: --merge specified but no files are unmerged." msgstr "" +"Keine Dateien ausgewähle: --merge angegeben, es existieren aber keine nicht-" +"zusammengeführten Dateien." -#: gitk:8602 +#: gitk:8587 msgid "" "No files selected: --merge specified but no unmerged files are within file " "limit." msgstr "" +"Keine Dateien ausgewähle: --merge angegeben, aber keine nicht-" +"zusammengeführten Dateien sind in der Dateiauswahl." -#: gitk:8661 +#: gitk:8646 msgid "Command line" msgstr "Kommandozeile" diff --git a/po/po2msg.sh b/po/po2msg.sh new file mode 100644 index 0000000000..c63248e375 --- /dev/null +++ b/po/po2msg.sh @@ -0,0 +1,133 @@ +#!/bin/sh +# Tcl ignores the next line -*- tcl -*- \ +exec tclsh "$0" -- "$@" + +# This is a really stupid program, which serves as an alternative to +# msgfmt. It _only_ translates to Tcl mode, does _not_ validate the +# input, and does _not_ output any statistics. + +proc u2a {s} { + set res "" + foreach i [split $s ""] { + scan $i %c c + if {$c<128} { + # escape '[', '\' and ']' + if {$c == 0x5b || $c == 0x5d} { + append res "\\" + } + append res $i + } else { + append res \\u[format %04.4x $c] + } + } + return $res +} + +set output_directory "." +set lang "dummy" +set files [list] +set show_statistics 0 + +# parse options +for {set i 0} {$i < $argc} {incr i} { + set arg [lindex $argv $i] + if {$arg == "--statistics"} { + incr show_statistics + continue + } + if {$arg == "--tcl"} { + # we know + continue + } + if {$arg == "-l"} { + incr i + set lang [lindex $argv $i] + continue + } + if {$arg == "-d"} { + incr i + set tmp [lindex $argv $i] + regsub "\[^/\]$" $tmp "&/" output_directory + continue + } + lappend files $arg +} + +proc flush_msg {} { + global msgid msgstr mode lang out fuzzy + global translated_count fuzzy_count not_translated_count + + if {![info exists msgid] || $mode == ""} { + return + } + set mode "" + if {$fuzzy == 1} { + incr fuzzy_count + set fuzzy 0 + return + } + + if {$msgid == ""} { + set prefix "set ::msgcat::header" + } else { + if {$msgstr == ""} { + incr not_translated_count + return + } + set prefix "::msgcat::mcset $lang \"[u2a $msgid]\"" + incr translated_count + } + + puts $out "$prefix \"[u2a $msgstr]\"" +} + +set fuzzy 0 +set translated_count 0 +set fuzzy_count 0 +set not_translated_count 0 +foreach file $files { + regsub "^.*/\(\[^/\]*\)\.po$" $file "$output_directory\\1.msg" outfile + set in [open $file "r"] + fconfigure $in -encoding utf-8 + set out [open $outfile "w"] + + set mode "" + while {[gets $in line] >= 0} { + if {[regexp "^#" $line]} { + if {[regexp ", fuzzy" $line]} { + set fuzzy 1 + } else { + flush_msg + } + continue + } elseif {[regexp "^msgid \"(.*)\"$" $line dummy match]} { + flush_msg + set msgid $match + set mode "msgid" + } elseif {[regexp "^msgstr \"(.*)\"$" $line dummy match]} { + set msgstr $match + set mode "msgstr" + } elseif {$line == ""} { + flush_msg + } elseif {[regexp "^\"(.*)\"$" $line dummy match]} { + if {$mode == "msgid"} { + append msgid $match + } elseif {$mode == "msgstr"} { + append msgstr $match + } else { + puts stderr "I do not know what to do: $match" + } + } else { + puts stderr "Cannot handle $line" + } + } + flush_msg + close $in + close $out +} + +if {$show_statistics} { + puts [concat "$translated_count translated messages, " \ + "$fuzzy_count fuzzy ones, " \ + "$not_translated_count untranslated ones."] +} |