aboutsummaryrefslogtreecommitdiffstats
path: root/po/tr.po
diff options
context:
space:
mode:
authorThierry Vignaud <tv@mandriva.org>2008-02-13 13:42:32 +0000
committerThierry Vignaud <tv@mandriva.org>2008-02-13 13:42:32 +0000
commit57f3c6ba46825a1c7da431ee0655fd7245e65afe (patch)
tree040297fab15388fe39380b8efb4a288de6a14325 /po/tr.po
parent318b9b1a43722250c1a6504146349eb087110fb1 (diff)
downloadrpmdrake-57f3c6ba46825a1c7da431ee0655fd7245e65afe.tar
rpmdrake-57f3c6ba46825a1c7da431ee0655fd7245e65afe.tar.gz
rpmdrake-57f3c6ba46825a1c7da431ee0655fd7245e65afe.tar.bz2
rpmdrake-57f3c6ba46825a1c7da431ee0655fd7245e65afe.tar.xz
rpmdrake-57f3c6ba46825a1c7da431ee0655fd7245e65afe.zip
sync with code
Diffstat (limited to 'po/tr.po')
-rw-r--r--po/tr.po193
1 files changed, 110 insertions, 83 deletions
diff --git a/po/tr.po b/po/tr.po
index e4c8d6ac..8dca14a5 100644
--- a/po/tr.po
+++ b/po/tr.po
@@ -12,7 +12,7 @@ msgid ""
msgstr ""
"Project-Id-Version: tr\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2008-02-12 12:31+0100\n"
+"POT-Creation-Date: 2008-02-13 14:40+0100\n"
"PO-Revision-Date: 2007-09-26 16:21+0300\n"
"Last-Translator: Taha Özket <taha.ozket@obss.net>\n"
"Language-Team: Turkce <tr@li.org>\n"
@@ -22,7 +22,7 @@ msgstr ""
"Plural-Forms: nplurals=1; plural=0;\n"
"X-Generator: KBabel 1.11.4\n"
-#: ../MandrivaUpdate:86 ../Rpmdrake/gui.pm:759
+#: ../MandrivaUpdate:86 ../Rpmdrake/gui.pm:780
#, c-format
msgid ""
"The list of updates is empty. This means that either there is\n"
@@ -284,8 +284,8 @@ msgstr "Medya Türü:"
#: ../Rpmdrake/edit_urpm_sources.pm:447 ../Rpmdrake/edit_urpm_sources.pm:474
#: ../Rpmdrake/edit_urpm_sources.pm:556 ../Rpmdrake/edit_urpm_sources.pm:643
#: ../Rpmdrake/edit_urpm_sources.pm:684 ../Rpmdrake/edit_urpm_sources.pm:742
-#: ../Rpmdrake/edit_urpm_sources.pm:891 ../Rpmdrake/gui.pm:524
-#: ../Rpmdrake/init.pm:136 ../Rpmdrake/pkg.pm:204 ../Rpmdrake/pkg.pm:700
+#: ../Rpmdrake/edit_urpm_sources.pm:891 ../Rpmdrake/gui.pm:545
+#: ../Rpmdrake/init.pm:136 ../Rpmdrake/pkg.pm:204 ../Rpmdrake/pkg.pm:707
#: ../rpmdrake.pm:301 ../rpmdrake.pm:619 ../rpmdrake.pm:692 ../rpmdrake.pm:765
#, c-format
msgid "Cancel"
@@ -296,8 +296,8 @@ msgstr "İptal"
#: ../Rpmdrake/edit_urpm_sources.pm:640 ../Rpmdrake/edit_urpm_sources.pm:683
#: ../Rpmdrake/edit_urpm_sources.pm:735 ../Rpmdrake/edit_urpm_sources.pm:808
#: ../Rpmdrake/edit_urpm_sources.pm:937 ../Rpmdrake/edit_urpm_sources.pm:1135
-#: ../Rpmdrake/gui.pm:524 ../Rpmdrake/gui.pm:540 ../Rpmdrake/gui.pm:545
-#: ../Rpmdrake/init.pm:136 ../Rpmdrake/pkg.pm:520 ../Rpmdrake/pkg.pm:700
+#: ../Rpmdrake/gui.pm:545 ../Rpmdrake/gui.pm:561 ../Rpmdrake/gui.pm:566
+#: ../Rpmdrake/init.pm:136 ../Rpmdrake/pkg.pm:527 ../Rpmdrake/pkg.pm:707
#: ../Rpmdrake/rpmnew.pm:180 ../rpmdrake.pm:124 ../rpmdrake.pm:239
#: ../rpmdrake.pm:304 ../rpmdrake.pm:619
#, c-format
@@ -523,7 +523,7 @@ msgid "Command"
msgstr "Komut"
#: ../Rpmdrake/edit_urpm_sources.pm:772 ../Rpmdrake/formatting.pm:126
-#: ../Rpmdrake/gui.pm:756 ../Rpmdrake/pkg.pm:119 ../Rpmdrake/pkg.pm:164
+#: ../Rpmdrake/gui.pm:777 ../Rpmdrake/pkg.pm:119 ../Rpmdrake/pkg.pm:164
#: ../Rpmdrake/pkg.pm:172 ../Rpmdrake/pkg.pm:193 ../Rpmdrake/rpmnew.pm:77
#, c-format
msgid "(none)"
@@ -913,80 +913,107 @@ msgstr "Özet: "
msgid "Description: "
msgstr "Tanım: "
-#: ../Rpmdrake/gui.pm:405 ../Rpmdrake/gui.pm:411 ../Rpmdrake/pkg.pm:710
-#: ../rpmdrake.pm:748 ../rpmdrake.pm:863
+#: ../Rpmdrake/gui.pm:217 ../Rpmdrake/gui.pm:426 ../Rpmdrake/gui.pm:432
+#: ../Rpmdrake/pkg.pm:717 ../rpmdrake.pm:748 ../rpmdrake.pm:863
#, c-format
msgid "Warning"
msgstr "Uyarı"
-#: ../Rpmdrake/gui.pm:406
+#: ../Rpmdrake/gui.pm:219
+#, c-format
+msgid "The package \"%s\" was found."
+msgstr ""
+
+#: ../Rpmdrake/gui.pm:220
+#, c-format
+msgid "However this package is not in the package list."
+msgstr ""
+
+#: ../Rpmdrake/gui.pm:221
+#, c-format
+msgid "You may want to update your urpmi database."
+msgstr ""
+
+#: ../Rpmdrake/gui.pm:223
+#, fuzzy, c-format
+msgid "Matching packages:"
+msgstr "Paketleme"
+
+#. -PO: this is list fomatting: "- <package_name> (medium: <medium_name>)"
+#. -PO: eg: "- rpmdrake (medium: "Main Release"
+#: ../Rpmdrake/gui.pm:228
+#, fuzzy, c-format
+msgid "- %s (medium: %s)"
+msgstr "%s kaynağından %s "
+
+#: ../Rpmdrake/gui.pm:427
#, fuzzy, c-format
msgid "Removing package %s would break your system"
msgstr ""
"Bu paketleri kaldırmak sisteminizin göçmesine sebeb olabilir, üzgünüm:\n"
"\n"
-#: ../Rpmdrake/gui.pm:411
+#: ../Rpmdrake/gui.pm:432
#, c-format
msgid ""
"The \"%s\" package is in urpmi skip list.\n"
"Do you want to select it anyway?"
msgstr ""
-#: ../Rpmdrake/gui.pm:506 ../Rpmdrake/gui.pm:536 ../Rpmdrake/gui.pm:538
+#: ../Rpmdrake/gui.pm:527 ../Rpmdrake/gui.pm:557 ../Rpmdrake/gui.pm:559
#, c-format
msgid "More information on package..."
msgstr "Paket hakkında daha fazla bilgi..."
-#: ../Rpmdrake/gui.pm:508
+#: ../Rpmdrake/gui.pm:529
#, c-format
msgid "Please choose"
msgstr "Lütfen seçin"
-#: ../Rpmdrake/gui.pm:509
+#: ../Rpmdrake/gui.pm:530
#, fuzzy, c-format
msgid "The following package is needed:"
msgstr "Şu paketler birinin yüklenmesi gerekiyor:"
-#: ../Rpmdrake/gui.pm:509
+#: ../Rpmdrake/gui.pm:530
#, c-format
msgid "One of the following packages is needed:"
msgstr "Aşağıdaki paketlerden birine ihtiyaç var:"
#. -PO: Keep it short, this is gonna be on a button
-#: ../Rpmdrake/gui.pm:524 ../Rpmdrake/gui.pm:529
+#: ../Rpmdrake/gui.pm:545 ../Rpmdrake/gui.pm:550
#, c-format
msgid "More info"
msgstr "Daha fazla bilgi"
-#: ../Rpmdrake/gui.pm:531
+#: ../Rpmdrake/gui.pm:552
#, c-format
msgid "Information on packages"
msgstr "Paket hakkında daha fazla bilgi"
-#: ../Rpmdrake/gui.pm:559
+#: ../Rpmdrake/gui.pm:580
#, c-format
msgid "Checking dependencies of package..."
msgstr ""
-#: ../Rpmdrake/gui.pm:566
+#: ../Rpmdrake/gui.pm:587
#, c-format
msgid "Some additional packages need to be removed"
msgstr "Bazı ek paketlerin kaldırılması gerekiyor"
-#: ../Rpmdrake/gui.pm:567
+#: ../Rpmdrake/gui.pm:588
#, c-format
msgid ""
"Because of their dependencies, the following package(s) also need to be\n"
"removed:"
msgstr "Bağımlılıkları nedeniyle şu paketlerinde kaldırlması gerekiyor: "
-#: ../Rpmdrake/gui.pm:573 ../Rpmdrake/gui.pm:583
+#: ../Rpmdrake/gui.pm:594 ../Rpmdrake/gui.pm:604
#, c-format
msgid "Some packages can't be removed"
msgstr "Bazı paketler kaldırılamadı"
-#: ../Rpmdrake/gui.pm:574
+#: ../Rpmdrake/gui.pm:595
#, c-format
msgid ""
"Removing these packages would break your system, sorry:\n"
@@ -995,7 +1022,7 @@ msgstr ""
"Bu paketleri kaldırmak sisteminizin göçmesine sebeb olabilir, üzgünüm:\n"
"\n"
-#: ../Rpmdrake/gui.pm:584 ../Rpmdrake/gui.pm:653
+#: ../Rpmdrake/gui.pm:605 ../Rpmdrake/gui.pm:674
#, c-format
msgid ""
"Because of their dependencies, the following package(s) must be\n"
@@ -1005,12 +1032,12 @@ msgstr ""
"Bağımlılıkları nedeniyle şu paketlerin seçili olmaması gerekiyor:\n"
"\n"
-#: ../Rpmdrake/gui.pm:614
+#: ../Rpmdrake/gui.pm:635
#, c-format
msgid "Additional packages needed"
msgstr "Ek paketlere ihtiyaç var"
-#: ../Rpmdrake/gui.pm:615
+#: ../Rpmdrake/gui.pm:636
#, c-format
msgid ""
"To satisfy dependencies, the following package(s) also need\n"
@@ -1021,22 +1048,22 @@ msgstr ""
"gerekiyor:\n"
"\n"
-#: ../Rpmdrake/gui.pm:629
+#: ../Rpmdrake/gui.pm:650
#, c-format
msgid "%s (belongs to the skip list)"
msgstr ""
-#: ../Rpmdrake/gui.pm:633
+#: ../Rpmdrake/gui.pm:654
#, fuzzy, c-format
msgid "One package cannot be installed"
msgstr "Bazı paketler kurulamadı"
-#: ../Rpmdrake/gui.pm:633
+#: ../Rpmdrake/gui.pm:654
#, c-format
msgid "Some packages can't be installed"
msgstr "Bazı paketler kurulamadı"
-#: ../Rpmdrake/gui.pm:635
+#: ../Rpmdrake/gui.pm:656
#, fuzzy, c-format
msgid ""
"Sorry, the following package cannot be selected:\n"
@@ -1047,7 +1074,7 @@ msgstr ""
"\n"
"%s"
-#: ../Rpmdrake/gui.pm:636
+#: ../Rpmdrake/gui.pm:657
#, fuzzy, c-format
msgid ""
"Sorry, the following packages can't be selected:\n"
@@ -1058,27 +1085,27 @@ msgstr ""
"\n"
"%s"
-#: ../Rpmdrake/gui.pm:652 ../Rpmdrake/pkg.pm:612
+#: ../Rpmdrake/gui.pm:673 ../Rpmdrake/pkg.pm:619
#, c-format
msgid "Some packages need to be removed"
msgstr "Bazı paketlerin kaldırılması gerekiyor"
-#: ../Rpmdrake/gui.pm:685
+#: ../Rpmdrake/gui.pm:706
#, c-format
msgid "Error: %s appears to be mounted read-only."
msgstr ""
-#: ../Rpmdrake/gui.pm:689
+#: ../Rpmdrake/gui.pm:710
#, c-format
msgid "You need to select some packages first."
msgstr "Önce paket seçmelisin."
-#: ../Rpmdrake/gui.pm:694
+#: ../Rpmdrake/gui.pm:715
#, c-format
msgid "Too many packages are selected"
msgstr "Aşırı fazla paket seçildi"
-#: ../Rpmdrake/gui.pm:695
+#: ../Rpmdrake/gui.pm:716
#, c-format
msgid ""
"Warning: it seems that you are attempting to add so much\n"
@@ -1094,42 +1121,42 @@ msgstr ""
"\n"
"Bütün seçili paketleri gerçekten yüklemek istiyor musunuz?"
-#: ../Rpmdrake/gui.pm:721 ../Rpmdrake/open_db.pm:75
+#: ../Rpmdrake/gui.pm:742 ../Rpmdrake/open_db.pm:75
#, c-format
msgid "Fatal error"
msgstr "Ölümcül hata"
-#: ../Rpmdrake/gui.pm:722 ../Rpmdrake/open_db.pm:76
+#: ../Rpmdrake/gui.pm:743 ../Rpmdrake/open_db.pm:76
#, c-format
msgid "A fatal error occurred: %s."
msgstr "Bir ölümcül hata oluştu: %s."
-#: ../Rpmdrake/gui.pm:740
+#: ../Rpmdrake/gui.pm:761
#, c-format
msgid "Please wait, listing packages..."
msgstr "Lütfen bekleyin, paketler listeleniyor..."
-#: ../Rpmdrake/gui.pm:758
+#: ../Rpmdrake/gui.pm:779
#, c-format
msgid "No update"
msgstr "Güncelleme yok"
-#: ../Rpmdrake/gui.pm:782 ../rpmdrake:308
+#: ../Rpmdrake/gui.pm:803 ../rpmdrake:308
#, c-format
msgid "All"
msgstr "Hepsi"
-#: ../Rpmdrake/gui.pm:791 ../rpmdrake:181
+#: ../Rpmdrake/gui.pm:812 ../rpmdrake:181
#, c-format
msgid "Upgradable"
msgstr "Güncellenebilinir"
-#: ../Rpmdrake/gui.pm:791 ../rpmdrake:181
+#: ../Rpmdrake/gui.pm:812 ../rpmdrake:181
#, c-format
msgid "Addable"
msgstr "Eklenebilir"
-#: ../Rpmdrake/gui.pm:811
+#: ../Rpmdrake/gui.pm:832
#, c-format
msgid "Description not available for this package\n"
msgstr ""
@@ -1925,8 +1952,8 @@ msgstr ""
msgid "Getting '%s' from XML meta-data..."
msgstr ""
-#: ../Rpmdrake/pkg.pm:137 ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:630
-#: ../Rpmdrake/pkg.pm:781 ../rpmdrake:119 ../rpmdrake.pm:329
+#: ../Rpmdrake/pkg.pm:137 ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:637
+#: ../Rpmdrake/pkg.pm:788 ../rpmdrake:119 ../rpmdrake.pm:329
#, c-format
msgid "Please wait"
msgstr "Lütfen bekleyin"
@@ -1957,7 +1984,7 @@ msgstr " %s%% / %s tamamlandı, ETA = %s, hız = %s"
msgid " %s%% completed, speed = %s"
msgstr " %s%% tamamlandı, hız = %s"
-#: ../Rpmdrake/pkg.pm:254 ../Rpmdrake/pkg.pm:612
+#: ../Rpmdrake/pkg.pm:254 ../Rpmdrake/pkg.pm:619
#, fuzzy, c-format
msgid "Confirmation"
msgstr "Yapılandırma"
@@ -2042,12 +2069,12 @@ msgstr ""
"\n"
"Sonra %s'yi tekrar çalıştırın."
-#: ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:630
+#: ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:637
#, c-format
msgid "Package installation..."
msgstr "Paket Kurulumu..."
-#: ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:630 ../Rpmdrake/pkg.pm:781
+#: ../Rpmdrake/pkg.pm:307 ../Rpmdrake/pkg.pm:637 ../Rpmdrake/pkg.pm:788
#, c-format
msgid "Initializing..."
msgstr "Başlatılıyor..."
@@ -2072,42 +2099,42 @@ msgstr "Lütfen bekleyin, paketler listeleniyor..."
msgid "Please wait, finding installed packages..."
msgstr "Lütfen bekleyin, erişilebilir paketler aranıyor..."
-#: ../Rpmdrake/pkg.pm:500
+#: ../Rpmdrake/pkg.pm:507
#, fuzzy, c-format
msgid "Upgrade information"
msgstr "Normal bilgi"
-#: ../Rpmdrake/pkg.pm:502
+#: ../Rpmdrake/pkg.pm:509
#, c-format
msgid "These packages come with upgrade information"
msgstr ""
-#: ../Rpmdrake/pkg.pm:510
+#: ../Rpmdrake/pkg.pm:517
#, fuzzy, c-format
msgid "Upgrade information about this package"
msgstr "Paket hakkında daha fazla bilgi..."
-#: ../Rpmdrake/pkg.pm:513
+#: ../Rpmdrake/pkg.pm:520
#, fuzzy, c-format
msgid "Upgrade information about package %s"
msgstr "Paket hakkında daha fazla bilgi..."
-#: ../Rpmdrake/pkg.pm:529
+#: ../Rpmdrake/pkg.pm:536
#, c-format
msgid "Could not create temporary directory '%s'"
msgstr ""
-#: ../Rpmdrake/pkg.pm:537 ../Rpmdrake/pkg.pm:757
+#: ../Rpmdrake/pkg.pm:544 ../Rpmdrake/pkg.pm:764
#, c-format
msgid "All requested packages were installed successfully."
msgstr "İstenen paketler başarılı bir şekilde yüklendi."
-#: ../Rpmdrake/pkg.pm:541 ../Rpmdrake/pkg.pm:731
+#: ../Rpmdrake/pkg.pm:548 ../Rpmdrake/pkg.pm:738
#, c-format
msgid "Problem during installation"
msgstr "Kurulum sırasında problem"
-#: ../Rpmdrake/pkg.pm:542 ../Rpmdrake/pkg.pm:562 ../Rpmdrake/pkg.pm:733
+#: ../Rpmdrake/pkg.pm:549 ../Rpmdrake/pkg.pm:569 ../Rpmdrake/pkg.pm:740
#, c-format
msgid ""
"There was a problem during the installation:\n"
@@ -2118,27 +2145,27 @@ msgstr ""
"\n"
"%s"
-#: ../Rpmdrake/pkg.pm:561 ../Rpmdrake/pkg.pm:721
+#: ../Rpmdrake/pkg.pm:568 ../Rpmdrake/pkg.pm:728
#, c-format
msgid "Installation failed"
msgstr "Kurulum başarısız"
-#: ../Rpmdrake/pkg.pm:581
+#: ../Rpmdrake/pkg.pm:588
#, c-format
msgid "Checking validity of requested packages..."
msgstr ""
-#: ../Rpmdrake/pkg.pm:592
+#: ../Rpmdrake/pkg.pm:599
#, c-format
msgid "Unable to get source packages."
msgstr "Kaynak paketleri alınamıyor."
-#: ../Rpmdrake/pkg.pm:593
+#: ../Rpmdrake/pkg.pm:600
#, c-format
msgid "Unable to get source packages, sorry. %s"
msgstr "%s kaynak paketleri alınamadı, üzgünüm."
-#: ../Rpmdrake/pkg.pm:594 ../Rpmdrake/pkg.pm:724
+#: ../Rpmdrake/pkg.pm:601 ../Rpmdrake/pkg.pm:731
#, c-format
msgid ""
"\n"
@@ -2151,7 +2178,7 @@ msgstr ""
"Hata(lar) rapor edildi:\n"
"%s"
-#: ../Rpmdrake/pkg.pm:609
+#: ../Rpmdrake/pkg.pm:616
#, fuzzy, c-format
msgid "The following package is going to be installed:"
msgid_plural "The following %d packages are going to be installed:"
@@ -2159,13 +2186,13 @@ msgstr[0] ""
"Bağımlılık sorununu aşabilmek için, aşağıdaki paketlerin kaldırılması "
"gerekiyor (%d Mb)"
-#: ../Rpmdrake/pkg.pm:615
+#: ../Rpmdrake/pkg.pm:622
#, c-format
msgid "Remove one package?"
msgid_plural "Remove %d packages?"
msgstr[0] "Bir anahtar kaldır"
-#: ../Rpmdrake/pkg.pm:617
+#: ../Rpmdrake/pkg.pm:624
#, fuzzy, c-format
msgid "The following package has to be removed for others to be upgraded:"
msgstr ""
@@ -2175,7 +2202,7 @@ msgstr ""
"\n"
"Devam edilsin mi?"
-#: ../Rpmdrake/pkg.pm:618
+#: ../Rpmdrake/pkg.pm:625
#, fuzzy, c-format
msgid "The following packages have to be removed for others to be upgraded:"
msgstr ""
@@ -2183,7 +2210,7 @@ msgstr ""
"gerekiyor:\n"
"%s"
-#: ../Rpmdrake/pkg.pm:621
+#: ../Rpmdrake/pkg.pm:628
#, fuzzy, c-format
msgid "Is it ok to continue?"
msgstr ""
@@ -2191,48 +2218,48 @@ msgstr ""
"\n"
"Devam etmek için herşey tamam mı ?"
-#: ../Rpmdrake/pkg.pm:642
+#: ../Rpmdrake/pkg.pm:649
#, c-format
msgid "Preparing packages installation..."
msgstr "Paket kurulumuna hazırlanılıyor..."
-#: ../Rpmdrake/pkg.pm:642
+#: ../Rpmdrake/pkg.pm:649
#, fuzzy, c-format
msgid "Preparing package installation transaction..."
msgstr "Paket kurulumuna hazırlanılıyor..."
-#: ../Rpmdrake/pkg.pm:645
+#: ../Rpmdrake/pkg.pm:652
#, c-format
msgid "Installing package `%s' (%s/%s)..."
msgstr "'%s' paketi kuruluyor ( %s/%s)..."
-#: ../Rpmdrake/pkg.pm:646
+#: ../Rpmdrake/pkg.pm:653
#, c-format
msgid "Total: %s/%s"
msgstr ""
-#: ../Rpmdrake/pkg.pm:674 ../Rpmdrake/pkg.pm:740 ../Rpmdrake/pkg.pm:763
+#: ../Rpmdrake/pkg.pm:681 ../Rpmdrake/pkg.pm:747 ../Rpmdrake/pkg.pm:770
#: ../rpmdrake.pm:735 ../rpmdrake.pm:822 ../rpmdrake.pm:846
#, c-format
msgid "Error"
msgstr "Hata"
-#: ../Rpmdrake/pkg.pm:698
+#: ../Rpmdrake/pkg.pm:705
#, c-format
msgid "Change medium"
msgstr "Ortam değiştir"
-#: ../Rpmdrake/pkg.pm:699
+#: ../Rpmdrake/pkg.pm:706
#, c-format
msgid "Please insert the medium named \"%s\" on device [%s]"
msgstr "Lütfen [%s] aygıtına \"%s\" kaynağını yerleştirin."
-#: ../Rpmdrake/pkg.pm:703
+#: ../Rpmdrake/pkg.pm:710
#, c-format
msgid "Verifying package signatures..."
msgstr "Paket imzaları kontrol ediliyor..."
-#: ../Rpmdrake/pkg.pm:722
+#: ../Rpmdrake/pkg.pm:729
#, c-format
msgid ""
"Installation failed, some files are missing:\n"
@@ -2245,23 +2272,23 @@ msgstr ""
"\n"
"Medya(kaynak) veritabanınızı güncellemek isteyebilirsiniz."
-#: ../Rpmdrake/pkg.pm:732
+#: ../Rpmdrake/pkg.pm:739
#, fuzzy, c-format
msgid "%d installation transactions failed"
msgstr "kurulum yönergeleri"
-#: ../Rpmdrake/pkg.pm:741
+#: ../Rpmdrake/pkg.pm:748
#, c-format
msgid "Unrecoverable error: no package found for installation, sorry."
msgstr ""
"Düzeltilemeyecek hata; yüklemek için herhangi bir paket bulunamadı,üzgünüm. "
-#: ../Rpmdrake/pkg.pm:744
+#: ../Rpmdrake/pkg.pm:751
#, c-format
msgid "Inspecting configuration files..."
msgstr ""
-#: ../Rpmdrake/pkg.pm:752
+#: ../Rpmdrake/pkg.pm:759
#, c-format
msgid ""
"The installation is finished; everything was installed correctly.\n"
@@ -2274,22 +2301,22 @@ msgstr ""
"'.rpmnew' veya '.rpmsave' olak bazı yapılandırma dosyaları oluşturuldu.\n"
"Harekete geçmek için artık birkaçını inceleyebilirsiniz:"
-#: ../Rpmdrake/pkg.pm:758
+#: ../Rpmdrake/pkg.pm:765
#, c-format
msgid "Looking for \"README\" files..."
msgstr ""
-#: ../Rpmdrake/pkg.pm:781 ../Rpmdrake/pkg.pm:797
+#: ../Rpmdrake/pkg.pm:788 ../Rpmdrake/pkg.pm:804
#, c-format
msgid "Please wait, removing packages..."
msgstr "Lütfen bekleyin, paketler kaldırılıyor..."
-#: ../Rpmdrake/pkg.pm:810
+#: ../Rpmdrake/pkg.pm:817
#, c-format
msgid "Problem during removal"
msgstr "Kaldırım esnasında problem"
-#: ../Rpmdrake/pkg.pm:811
+#: ../Rpmdrake/pkg.pm:818
#, c-format
msgid ""
"There was a problem during the removal of packages:\n"
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
package Rpmdrake::edit_urpm_sources;
#*****************************************************************************
# 
#  Copyright (c) 2002 Guillaume Cottenceau
#  Copyright (c) 2002-2007 Thierry Vignaud <tvignaud@mandriva.com>
#  Copyright (c) 2002-2007 Mandriva Linux
# 
#  This program is free software; you can redistribute it and/or modify
#  it under the terms of the GNU General Public License version 2, as
#  published by the Free Software Foundation.
# 
#  This program is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
# 
#  You should have received a copy of the GNU General Public License
#  along with this program; if not, write to the Free Software
#  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# 
#*****************************************************************************
#
# $Id$


use strict;
use lib qw(/usr/lib/libDrakX);
use common;
use rpmdrake;
use Rpmdrake::open_db;
use Rpmdrake::formatting;
use URPM::Signature;
use MDK::Common::Math qw(max);
use urpm::media;
use urpm::download;
use urpm::lock;

use Exporter;
our @ISA = qw(Exporter);
our @EXPORT = qw(run);

use mygtk2 qw(gtknew gtkset);
use ugtk2 qw(:all);

my $urpm;
my ($mainw, $list_tv, $something_changed);

my %col = (
    mainw => {
        is_enabled => 0,
        is_update  => 1,
        type       => 2,
        name       => 3,
        activatable => 4
    },
);


sub get_medium_type {
    my ($medium) = @_;
    my %medium_type = (
        cdrom     => N("CD-ROM"),
        ftp       => N("FTP"),
        file      => N("Local"),
        http      => N("HTTP"),
        https     => N("HTTPS"),
        nfs       => N("NFS"),
        removable => N("Removable"),
        rsync     => N("rsync"),
        ssh       => N("NFS"),
    );
    return N("Mirror list") if $medium->{mirrorlist};
    return $medium_type{$1} if $medium->{url} =~ m!^([^:]*)://!;
    return N("Local");
}

sub selrow {
    my ($o_list_tv) = @_;
    defined $o_list_tv or $o_list_tv = $list_tv;
    my ($model, $iter) = $o_list_tv->get_selection->get_selected;
    $model && $iter or return -1;
    my $path = $model->get_path($iter);
    my $row = $path->to_string;
    return $row;
}

sub selected_rows {
    my ($o_list_tv) = @_;
    defined $o_list_tv or $o_list_tv = $list_tv;
    my (@rows) = $o_list_tv->get_selection->get_selected_rows;
    return -1 if @rows == 0;
    map { $_->to_string } @rows;
}

sub remove_row {
    my ($model, $path_str) = @_;
    my $iter = $model->get_iter_from_string($path_str);
    $iter or return;
    $model->remove($iter);
}

sub remove_from_list {
    my ($list, $list_ref, $model) = @_;
    my $row = selrow($list);
    if ($row != -1) {
        splice @$list_ref, $row, 1;
        remove_row($model, $row);
    }

}

sub _want_base_distro() {
    distro_type(0) eq 'updates' ? interactive_msg(
	N("Choose media type"),
N("In order to keep your system secure and stable, you must at a minimum set up
sources for official security and stability updates. You can also choose to set
up a fuller set of sources which includes the complete official Mandriva
repositories, giving you access to more software than can fit on the Mandriva
discs. Please choose whether to configure update sources only, or the full set
of sources."),
	 transient => $::main_window,
	yesno => 1, text => { yes => N("Full set of sources"), no => N("Update sources only") },
    ) : 1;
}

sub easy_add_callback_with_mirror() {
    # when called on early init by rpmdrake
    $urpm ||= fast_open_urpmi_db();

    #- cooker and community don't have update sources
    my $want_base_distro = _want_base_distro();
    defined $want_base_distro or return;
    my $distro = $rpmdrake::mandrake_release;
    my ($mirror) = choose_mirror($urpm, message =>
N("This will attempt to install all official sources corresponding to your
distribution (%s).

I need to contact the Mandriva website to get the mirror list.
Please check that your network is currently running.

Is it ok to continue?", $distro),
     transient => $::main_window,
    ) or return 0;
    ref $mirror or return;
    my $wait = wait_msg(N("Please wait, adding media..."));
    add_distrib_update_media($urpm, $mirror, if_(!$want_base_distro, only_updates => 1));
    $offered_to_add_sources->[0] = 1;
    remove_wait_msg($wait);
    return 1;
}

sub easy_add_callback() {
    # when called on early init by rpmdrake
    $urpm ||= fast_open_urpmi_db();

    #- cooker and community don't have update sources
    my $want_base_distro = _want_base_distro();
    defined $want_base_distro or return;
    warn_for_network_need(undef, transient => $::main_window) or return;
    my $wait = wait_msg(N("Please wait, adding media..."));
    add_distrib_update_media($urpm, undef, if_(!$want_base_distro, only_updates => 1));
    $offered_to_add_sources->[0] = 1;
    remove_wait_msg($wait);
    return 1;
}

sub add_callback() {
    my $w = ugtk2->new(N("Add a medium"), grab => 1, center => 1,  transient => $::main_window);
    my $prev_main_window = $::main_window;
    local $::main_window = $w->{real_window};
    my %radios_infos = (
	local => { name => N("Local files"), url => N("Medium path:"), dirsel => 1 },
	ftp => { name => N("FTP server"), url => N("URL:"), loginpass => 1 },
	rsync => { name => N("RSYNC server"), url => N("URL:") },
	http => { name => N("HTTP server"), url => N("URL:") },
	removable => { name => N("Removable device (CD-ROM, DVD, ...)"), url => N("Path or mount point:"), dirsel => 1 },
    );
    my @radios_names_ordered = qw(local ftp rsync http removable);
    # TODO: replace NoteBook by sensitive widgets and Label->set()
    my $notebook = gtknew('Notebook');
    $notebook->set_show_tabs(0); $notebook->set_show_border(0);
    my ($count_nbs, %pages);
    my $size_group = Gtk2::SizeGroup->new('horizontal');
    my ($cb1, $cb2);
    foreach (@radios_names_ordered) {
	my $info = $radios_infos{$_};
	my $url_entry = sub {
	    gtkpack_(
		gtknew('HBox'),
		1, $info->{url_entry} = gtkentry(),
		if_(
		    $info->{dirsel},
		    0, gtksignal_connect(
			gtknew('Button', text => but(N("Browse..."))),
			clicked => sub { $info->{url_entry}->set_text(ask_dir()) },
		    )
		),
	    );
	};
        my $checkbut_entry = sub {
            my ($name, $label, $visibility, $callback, $tip) = @_;
            my $w = [ gtksignal_connect(
		    $info->{$name . '_check'} = gtkset(gtknew('CheckButton', text => $label), tip => $tip),
		    clicked => sub {
			$info->{$name . '_entry'}->set_sensitive($_[0]->get_active);
			$callback and $callback->(@_);
		    },
	    ),
	    gtkset_visibility(gtkset_sensitive($info->{$name . '_entry'} = gtkentry(), 0), $visibility) ];
	    $size_group->add_widget($info->{$name . '_check'});
	    $w;
        };
	my $loginpass_entries = sub {
	    map {
		$checkbut_entry->(
		    @$_, sub {
			$info->{pass_check}->set_active($_[0]->get_active);
			$info->{login_check}->set_active($_[0]->get_active);
		    }
		);
	    } ([ 'login', N("Login:"), 1 ], [ 'pass', N("Password:"), 0 ]);
	};
	$pages{$info->{name}} = $count_nbs++;
	$notebook->append_page(
	    gtkshow(create_packtable(
		{ xpadding => 0, ypadding => 0 },
		[ gtkset_alignment(gtknew('Label', text => N("Medium name:")), 0, 0.5),
		    $info->{name_entry} = gtkentry('') ],
		[ gtkset_alignment(gtknew('Label', text => $info->{url}), 0, 0.5),
		    $url_entry->() ],
		if_($info->{loginpass}, $loginpass_entries->()),
		sub {
		    [ $info->{distrib_check} = $cb1 = gtknew('CheckButton', text => N("Create media for a whole distribution"),
                                                         toggled => sub {
                                                             return if !$cb2;
                                                             my ($w) = @_;
                                                             $info->{update_check}->set_sensitive(!$w->get_active);
                                                         })
		    ];
		}->(),
		sub {
		    [ $info->{update_check} = $cb2 = gtknew('CheckButton', text => N("Tag this medium as an update medium")) ];
		}->(),
	    ))
	);
    }
    $size_group->add_widget($_) foreach $cb1, $cb2;

    my $checkok = sub {
	my $info = $radios_infos{$radios_names_ordered[$notebook->get_current_page]};
	my ($name, $url) = map { $info->{$_ . '_entry'}->get_text } qw(name url);
	$name eq '' || $url eq '' and interactive_msg('rpmdrake', N("You need to fill up at least the two first entries.")), return 0;
	if (member($name, map { $_->{name} } @{$urpm->{media}})) {
	    $info->{name_entry}->select_region(0, -1);
	    interactive_msg('rpmdrake',
N("There is already a medium by that name, do you
really want to replace it?"), yesno => 1) or return 0;
	}
	1;
    };

    my $type = 'local';
    my (%i, %make_url);
    gtkadd(
	$w->{window},
	gtkpack(
	    gtknew('VBox', spacing => 5),
	    gtknew('Title2', label => N("Adding a medium:")),
	    gtknew('HBox', children_tight => [
                      Gtk2::Label->new(but(N("Type of medium:"))),
                      gtknew('ComboBox', text_ref => \$type, 
                             list => \@radios_names_ordered,
                             format => sub { $radios_infos{$_[0]}{name} },
                             changed => sub { $notebook->set_current_page($pages{$_[0]->get_text}) })
                     ]),
	    $notebook,
	    gtknew('HSeparator'),
	    gtkpack(
		gtknew('HButtonBox'),
		gtknew('Button', text => N("Cancel"), clicked => sub { $w->{retval} = 0; Gtk2->main_quit }),
		gtksignal_connect(
		    gtknew('Button', text => N("Ok")), clicked => sub {
			if ($checkok->()) {
			    $w->{retval} = { nb => $notebook->get_current_page };
			    my $info = $radios_infos{$type};
			    %i = (
				name => $info->{name_entry}->get_text,
				url => $info->{url_entry}->get_text,
				distrib => $info->{distrib_check} ? $info->{distrib_check}->get_active : 0,
				update => $info->{update_check}->get_active ? 1 : undef,
			    );
			    %make_url = (
				local => "file:/$i{url}",
				http => $i{url},
				rsync => $i{url},
				removable => "removable:/$i{url}",
			    );
			    $i{url} =~ s|^ftp://||;
			    $make_url{ftp} = sprintf "ftp://%s%s",
				$info->{login_check}->get_active
				    ? ($info->{login_entry}->get_text . ':' . $info->{pass_entry}->get_text . '@')
				    : '',
				$i{url};
			    Gtk2->main_quit;
			}
		    },
		),
	    ),
	),
    );

    if ($w->main) {
	$::main_window = $prev_main_window;
	if ($i{distrib}) {
	    add_medium_and_check(
		$urpm,
		{ nolock => 1, distrib => 1 },
		$i{name}, $make_url{$type}, probe_with => 'synthesis', update => $i{update},
	    );
	} else {
	    if (member($i{name}, map { $_->{name} } @{$urpm->{media}})) {
		urpm::media::select_media($urpm, $i{name});
		urpm::media::remove_selected_media($urpm);
	    }
	    add_medium_and_check(
		$urpm,
		{ nolock => 1 },
		$i{name}, $make_url{$type}, $i{hdlist}, update => $i{update},
	    );
	}
	return 1;
    }
    return 0;
}

sub options_callback() {
    my $w = ugtk2->new(N("Global options for package installation"), grab => 1, center => 1,  transient => $::main_window);
    local $::main_window = $w->{real_window};
    my %verif = (0 => N("never"), 1 => N("always"));
    my $verify_rpm = $urpm->{global_config}{'verify-rpm'};
    my @avail_downloaders = urpm::download::available_ftp_http_downloaders();
    my $downloader = $urpm->{global_config}{downloader} || $avail_downloaders[0];
    my %xml_info_policies = (
        'never'       => N("Never"), 
        'on-demand'   => N("On-demand"), 
        'update-only' => N("Update-only"), 
        'always'      => N("Always"), 
    );
    my $xml_info_policy = $urpm->{global_config}{'xml-info'};

    gtkadd(
	$w->{window},
	gtkpack(
	    gtknew('VBox', spacing => 5),
	    gtknew('HBox', children_loose => [ gtknew('Label', text => N("Verify RPMs to be installed:")),
                                               gtknew('ComboBox', list => [ keys %verif ], text_ref => \$verify_rpm,
                                                      format => sub { $verif{$_[0]} || $_[0] },
                                                  )
                                           ]),
	    gtknew('HBox', children_loose => [ gtknew('Label', text => N("Download program to use:")),
                                               gtknew('ComboBox', list => \@avail_downloaders, text_ref => \$downloader,
                                                      format => sub { $verif{$_[0]} || $_[0] },
                                                  )
                                           ]),
	    gtknew('HBox',
                   children_loose =>
                     [ gtknew('Label', text => N("XML meta-data download policy:")),
                       gtknew('ComboBox',
                              list => [ keys %xml_info_policies ], text_ref => \$xml_info_policy,

                              format => sub { $xml_info_policies{$_[0]} || $_[0] },
                              tip => 
                                join("\n",
                                     N("For remote media, specify when XML meta-data (file lists, changelogs & informations) are downloaded."),
                                     '',
                                     N("Never"),
                                     N("For remote media, XML meta-data are never downloaded."),
                                     '',
                                     N("On-demand"),
                                     N("(This is the default)"),
                                     N("The specific XML info file is downloaded when clicking on package."),
                                     '',
                                     N("Update-only"), 
                                     N("Updating media implies updating XML info files already required at least once."),
                                     '',
                                     N("Always"),
                                     N("All XML info files are downloaded when adding or updating media."),
                                 ),
                          ),
                   ]),

	    gtkpack(
		gtknew('HButtonBox'),
		gtknew('Button', text => N("Cancel"), clicked => sub { Gtk2->main_quit }),
		gtksignal_connect(
		    gtknew('Button', text => N("Ok")), clicked => sub {
                        $urpm->{global_config}{'verify-rpm'} = $verify_rpm;
                        $urpm->{global_config}{downloader} = $downloader;
                        $urpm->{global_config}{'xml-info'} = $xml_info_policy;
                        $something_changed = 1;
			urpm::media::write_config($urpm);
			$urpm = fast_open_urpmi_db();
			Gtk2->main_quit;
		    },
		),
	    ),
	),
    );
    $w->main;
}

sub remove_callback() {
    my @rows = selected_rows();
    @rows == 0 and return;
    interactive_msg(
	N("Source Removal"),
	@rows == 1 ?
	  N("Are you sure you want to remove source \"%s\"?", to_utf8($urpm->{media}[$rows[0]]{name})) :
	    N("Are you sure you want to remove the following sources?") . "\n\n" .
	      format_list(map { to_utf8($urpm->{media}[$_]{name}) } @rows),
	yesno => 1, scroll => 1,
	 transient => $::main_window,
    ) or return;

    my $wait = wait_msg(N("Please wait, removing medium..."));
    foreach my $row (reverse(@rows)) {
     $something_changed = 1;
	urpm::media::remove_media($urpm, [ $urpm->{media}[$row] ]);
	urpm::media::write_urpmi_cfg($urpm);
	remove_wait_msg($wait);
    }
    return 1;
}

sub renum_media ($$$) {
    my ($model, @iters) = @_;
    my @rows = map { $model->get_path($_)->to_string } @iters;
    my @media = map { $urpm->{media}[$_] } @rows;
    $urpm->{media}[$rows[$_]] = $media[1 - $_] foreach 0, 1;
    $model->swap(@iters);
    $something_changed = 1;
    urpm::media::write_config($urpm);
    $urpm = fast_open_urpmi_db();
}

sub upwards_callback() {
    my @rows = selected_rows();
    @rows == 0 and return;
    my $model = $list_tv->get_model;
    my $prev = $model->get_iter_from_string($rows[0] - 1);
    defined $prev and renum_media($model, $model->get_iter_from_string($rows[0]), $prev);
    $list_tv->get_selection->signal_emit('changed');
}

sub downwards_callback() {
    my @rows = selected_rows();
    @rows == 0 and return;
    my $model = $list_tv->get_model;
    my $iter = $model->get_iter_from_string($rows[0]);
    my $next = $model->iter_next($iter);
    defined $next and renum_media($model, $iter, $next);
    $list_tv->get_selection->signal_emit('changed');
}

#- returns the name of the media for which edition failed, or undef on success
sub edit_callback() {
    my ($row) = selected_rows();
    $row == -1 and return;
    my $medium = $urpm->{media}[$row];
    my $config = urpm::cfg::load_config_raw($urpm->{config}, 1);
    my ($verbatim_medium) = grep { $medium->{name} eq $_->{name} } @$config;
    my $old_main_window = $::main_window;
    my $w = ugtk2->new(N("Edit a medium"), grab => 1, center => 1,  transient => $::main_window);
    local $::main_window = $w->{real_window};
    my ($url_entry, $downloader_entry, $url, $downloader);
    gtkadd(
	$w->{window},
	gtkpack_(
	    gtknew('VBox', spacing => 5),
	    0, gtknew('Title2', label => N("Editing medium \"%s\":", $medium->{name})),
	    0, create_packtable(
		{},
		[ gtknew('Label_Left', text => N("URL:")), $url_entry = gtkentry($verbatim_medium->{url} || $verbatim_medium->{mirrorlist}) ],
		[ gtknew('Label_Left', text => N("Downloader:")),
            my $download_combo = Gtk2::ComboBox->new_with_strings([ urpm::download::available_ftp_http_downloaders() ],
                                                                  $verbatim_medium->{downloader} || '') ],
	    ),
	    0, gtknew('HSeparator'),
	    0, gtkpack(
		gtknew('HButtonBox'),
		gtksignal_connect(
		    gtknew('Button', text => N("Cancel")),
		    clicked => sub { $w->{retval} = 0; Gtk2->main_quit },
		),
		gtksignal_connect(
		    gtknew('Button', text => N("Save changes")),
		    clicked => sub {
			$w->{retval} = 1;
			$url = $url_entry->get_text;
			$downloader = $downloader_entry->get_text;
			Gtk2->main_quit;
		    },
		),
		gtksignal_connect(
		    gtknew('Button', text => N("Proxy...")),
		    clicked => sub { proxy_callback($medium) },
		),
	    )
	)
    );
    $downloader_entry = $download_combo->entry;
    $w->{rwindow}->set_size_request(600, -1);
    if ($w->main) {
	my ($name, $update) = map { $medium->{$_} } qw(name update);
	$url =~ m|^removable://| and (
	    interactive_msg(
		N("You need to insert the medium to continue"),
		N("In order to save the changes, you need to insert the medium in the drive."),
		yesno => 1, text => { yes => N("Ok"), no => N("Cancel") }
	    ) or return 0
	);
	my $saved_proxy = urpm::download::get_proxy($name);
	undef $saved_proxy if !defined $saved_proxy->{http_proxy} && !defined $saved_proxy->{ftp_proxy};
	urpm::media::select_media($urpm, $name);
     if (my ($media) = grep { $_->{name} eq $name } @{$urpm->{media}}) {
         put_in_hash($media, {
             ($verbatim_medium->{mirrorlist} ? 'mirrorlist' : 'url') => $url,
             name => $name,
             if_($update ne $media->{update} || $update, update => $update),
             if_($saved_proxy ne $media->{proxy} || $saved_proxy, proxy => $saved_proxy),
             if_($downloader ne $media->{downloader} || $downloader, downloader => $downloader),
             modified => 1,
         });
         urpm::media::write_config($urpm);
         local $::main_window = $old_main_window;
         update_sources_noninteractive($urpm, [ $name ], transient => $::main_window, nolock => 1);
     } else {
         urpm::media::remove_selected_media($urpm);
         add_medium_and_check($urpm, { nolock => 1, proxy => $saved_proxy }, $name, $url, undef, update => $update, if_($downloader, downloader => $downloader));
     }
	return $name;
    }
    return undef;
}

sub update_callback() {
    update_sources_interactive($urpm,  transient => $::main_window, nolock => 1);
}

sub proxy_callback {
    my ($medium) = @_;
    my $medium_name = $medium ? $medium->{name} : '';
    my $w = ugtk2->new(N("Configure proxies"), grab => 1, center => 1,  transient => $::main_window);
    local $::main_window = $w->{real_window};
    require curl_download;
    my ($proxy, $proxy_user) = curl_download::readproxy($medium_name);
    my ($user, $pass) = $proxy_user =~ /^([^:]*):(.*)$/;
    my ($proxybutton, $proxyentry, $proxyuserbutton, $proxyuserentry, $proxypasswordentry);
    my $sg = Gtk2::SizeGroup->new('horizontal');
    gtkadd(
	$w->{window},
	gtkpack__(
	    gtknew('VBox', spacing => 5),
	    gtknew('Title2', label =>
		$medium_name
		    ? N("Proxy settings for media \"%s\"", $medium_name)
		    : N("Global proxy settings")
	    ),
	    gtknew('Label_Left', text => N("If you need a proxy, enter the hostname and an optional port (syntax: <proxyhost[:port]>):")),
	    gtkpack_(
		gtknew('HBox', spacing => 10),
		1, gtkset_active($proxybutton = gtknew('CheckButton', text => N("Proxy hostname:")), to_bool($proxy)),
		0, gtkadd_widget($sg, gtkset_sensitive($proxyentry = gtkentry($proxy), to_bool($proxy))),
	    ),
         gtkset_active($proxyuserbutton = gtknew('CheckButton', text => N("You may specify a user/password for the proxy authentication:")), to_bool($proxy_user)),
	    gtkpack_(
		my $hb_user = gtknew('HBox', spacing => 10, sensitive => to_bool($proxy_user)),
		1, gtknew('Label_Left', text => N("User:")),
		0, gtkadd_widget($sg, $proxyuserentry = gtkentry($user)),
      ),
	    gtkpack_(
		my $hb_pswd = gtknew('HBox', spacing => 10, sensitive => to_bool($proxy_user)),
		1, gtknew('Label_Left', text => N("Password:")),
		0, gtkadd_widget($sg, gtkset_visibility($proxypasswordentry = gtkentry($pass), 0)),
	    ),
	    gtknew('HSeparator'),
	    gtkpack(
		gtknew('HButtonBox'),
		gtksignal_connect(
		    gtknew('Button', text => N("Ok")),
		    clicked => sub {
			$w->{retval} = 1;
			$proxy = $proxybutton->get_active ? $proxyentry->get_text : '';
			$proxy_user = $proxyuserbutton->get_active
			    ? ($proxyuserentry->get_text . ':' . $proxypasswordentry->get_text) : '';
			Gtk2->main_quit;
		    },
		),
		gtksignal_connect(
		    gtknew('Button', text => N("Cancel")),
		    clicked => sub { $w->{retval} = 0; Gtk2->main_quit },
		)
	    )
	)
    );
    $sg->add_widget($_) foreach $proxyentry, $proxyuserentry, $proxypasswordentry;
    $proxybutton->signal_connect(
	clicked => sub {
	    $proxyentry->set_sensitive($_[0]->get_active);
	    $_[0]->get_active and return;
	    $proxyuserbutton->set_active(0);
	    $hb_user->set_sensitive(0);
	    $hb_pswd->set_sensitive(0);
	}
    );
    $proxyuserbutton->signal_connect(clicked => sub { $_->set_sensitive($_[0]->get_active) foreach $hb_user, $hb_pswd;
    $proxypasswordentry->set_sensitive($_[0]->get_active) });

    $w->main and do {
        $something_changed = 1;
        curl_download::writeproxy($proxy, $proxy_user, $medium_name);
    };
}

sub parallel_read_sysconf() {
    my @conf;
    foreach (cat_('/etc/urpmi/parallel.cfg')) {
        my ($name, $protocol, $command) = /([^:]+):([^:]+):(.*)/ or print STDERR "Warning, unrecognized line in /etc/urpmi/parallel.cfg:\n$_";
        my $medias = $protocol =~ s/\(([^\)]+)\)$// ? [ split /,/, $1 ] : [];
        push @conf, { name => $name, protocol => $protocol, medias => $medias, command => $command };
    }
    \@conf;
}

sub parallel_write_sysconf {
    my ($conf) = @_;
    output '/etc/urpmi/parallel.cfg',
           map { my $m = @{$_->{medias}} ? '(' . join(',', @{$_->{medias}}) . ')' : '';
                 "$_->{name}:$_->{protocol}$m:$_->{command}\n" } @$conf;
}

sub remove_parallel {
    my ($num, $conf) = @_;
    if ($num != -1) {
        splice @$conf, $num, 1;
        parallel_write_sysconf($conf);
    }
}

sub add_callback_ {
    my ($title, $label, $mainw, $widget, $get_value, $check) = @_;
    my $w = ugtk2->new($title, grab => 1,  transient => $mainw->{real_window});
    local $::main_window = $w->{real_window};
    gtkadd(
        $w->{window},
        gtkpack__(
            gtknew('VBox', spacing => 5),
            gtknew('Label', text => $label),
            $widget,
            gtknew('HSeparator'),
            gtkpack(
                gtknew('HButtonBox'),
                gtknew('Button', text => N("Ok"), clicked => sub { $w->{retval} = 1; $get_value->(); Gtk2->main_quit }),
                gtknew('Button', text => N("Cancel"), clicked => sub { $w->{retval} = 0; Gtk2->main_quit })
            )
        )
    );
    $check->() if $w->main;
}

sub edit_parallel {
    my ($num, $conf) = @_;
    my $edited = $num == -1 ? {} : $conf->[$num];
    my $w = ugtk2->new($num == -1 ? N("Add a parallel group") : N("Edit a parallel group"), grab => 1, center => 1,  transient => $::main_window);
    local $::main_window = $w->{real_window};
    my $name_entry;

    my ($medias_ls, $hosts_ls) = (Gtk2::ListStore->new("Glib::String"), Gtk2::ListStore->new("Glib::String"));

    my ($medias, $hosts) = map {
        my $list = Gtk2::TreeView->new_with_model($_);
        $list->append_column(Gtk2::TreeViewColumn->new_with_attributes(undef, Gtk2::CellRendererText->new, 'text' => 0));
        $list->set_headers_visible(0);
        $list->get_selection->set_mode('browse');
        $list;
    } $medias_ls, $hosts_ls;

    $medias_ls->append_set([ 0 => $_ ]) foreach @{$edited->{medias}};

    my $add_media = sub {
        my $medias_list_ls = Gtk2::ListStore->new("Glib::String");
        my $medias_list = Gtk2::TreeView->new_with_model($medias_list_ls);
        $medias_list->append_column(Gtk2::TreeViewColumn->new_with_attributes(undef, Gtk2::CellRendererText->new, 'text' => 0));
        $medias_list->set_headers_visible(0);
        $medias_list->get_selection->set_mode('browse');
        $medias_list_ls->append_set([ 0 => $_->{name} ]) foreach @{$urpm->{media}};
        my $sel;
        add_callback_(N("Add a medium limit"), N("Choose a medium for adding in the media limit:"),
                      $w, $medias_list, sub { $sel = selrow($medias_list) },
                      sub {
                          return if $sel == -1;
                          my $media = ${$urpm->{media}}[$sel]{name};
                          $medias_ls->append_set([ 0 => $media ]);
                          push @{$edited->{medias}}, $media;
                      }
                  );
    };

    my $hosts_list;
    if    ($edited->{protocol} eq 'ssh')    { $hosts_list = [ split /:/, $edited->{command} ] }
    elsif ($edited->{protocol} eq 'ka-run') { push @$hosts_list, $1 while $edited->{command} =~ /-m (\S+)/g }
    $hosts_ls->append_set([ 0 => $_ ]) foreach @$hosts_list;
    my $add_host = sub {
        my ($entry, $value);
        add_callback_(N("Add a host"), N("Type in the hostname or IP address of the host to add:"),
                      $mainw, $entry = gtkentry(), sub { $value = $entry->get_text },
                      sub { $hosts_ls->append_set([ 0 => $value ]); push @$hosts_list, $value }
                  );
    };

    my @protocols_names = qw(ka-run ssh);
    my @protocols;
    gtkadd(
	$w->{window},
	gtkpack_(
	    gtknew('VBox', spacing => 5),
	    if_(
		$num != -1,
		0, gtknew('Label', text => N("Editing parallel group \"%s\":", $edited->{name}))
	    ),
	    1, create_packtable(
		{},
		[ N("Group name:"), $name_entry = gtkentry($edited->{name}) ],
		[ N("Protocol:"), gtknew('HBox', children_tight => [
		    @protocols = gtkradio($edited->{protocol}, @protocols_names) ]) ],
		[ N("Media limit:"),
		gtknew('HBox', spacing => 5, children => [
		    1, gtknew('Frame', shadow_type => 'in', child => 
			gtknew('ScrolledWindow', h_policy => 'never', child => $medias)),
		    0, gtknew('VBox', children_tight => [
			gtksignal_connect(Gtk2::Button->new(but(N("Add"))),    clicked => sub { $add_media->() }),
			gtksignal_connect(Gtk2::Button->new(but(N("Remove"))), clicked => sub {
                                              remove_from_list($medias, $edited->{medias}, $medias_ls);
                                          }) ]) ]) ],
		[ N("Hosts:"),
		gtknew('HBox', spacing => 5, children => [
		    1, gtknew('Frame', shadow_type => 'in', child => 
			gtknew('ScrolledWindow', h_policy => 'never', child => $hosts)),
		    0, gtknew('VBox', children_tight => [
			gtksignal_connect(Gtk2::Button->new(but(N("Add"))),    clicked => sub { $add_host->() }),
			gtksignal_connect(Gtk2::Button->new(but(N("Remove"))), clicked => sub {
                                              remove_from_list($hosts, $hosts_list, $hosts_ls);
                                          }) ]) ]) ]
	    ),
	    0, gtknew('HSeparator'),
	    0, gtkpack(
		gtknew('HButtonBox'),
		gtksignal_connect(
		    gtknew('Button', text => N("Ok")), clicked => sub {
			$w->{retval} = 1;
			$edited->{name} = $name_entry->get_text;
			mapn { $_[0]->get_active and $edited->{protocol} = $_[1] } \@protocols, \@protocols_names;
			Gtk2->main_quit;
		    }
		),
		gtknew('Button', text => N("Cancel"), clicked => sub { $w->{retval} = 0; Gtk2->main_quit }))
	)
    );
    $w->{rwindow}->set_size_request(600, -1);
    if ($w->main) {
        $num == -1 and push @$conf, $edited;
        if ($edited->{protocol} eq 'ssh')    { $edited->{command} = join(':', @$hosts_list) }
        if ($edited->{protocol} eq 'ka-run') { $edited->{command} = "-c ssh " . join(' ', map { "-m $_" } @$hosts_list) }
        parallel_write_sysconf($conf);
	return 1;
    }
    return 0;
}

sub parallel_callback() {
    my $w = ugtk2->new(N("Configure parallel urpmi (distributed execution of urpmi)"), grab => 1, center => 1,  transient => $mainw->{real_window});
    local $::main_window = $w->{real_window};
    my $list_ls = Gtk2::ListStore->new("Glib::String", "Glib::String", "Glib::String", "Glib::String");
    my $list = Gtk2::TreeView->new_with_model($list_ls);
    each_index { $list->append_column(Gtk2::TreeViewColumn->new_with_attributes($_, Gtk2::CellRendererText->new, 'text' => $::i)) } N("Group"), N("Protocol"), N("Media limit");
    $list->append_column(my $commandcol = Gtk2::TreeViewColumn->new_with_attributes(N("Command"), Gtk2::CellRendererText->new, 'text' => 3));
    $commandcol->set_max_width(200);

    my $conf;
    my $reread = sub {
	$list_ls->clear;
        $conf = parallel_read_sysconf();
	foreach (@$conf) {
            $list_ls->append_set([ 0 => $_->{name},
                                   1 => $_->{protocol},
                                   2 => @{$_->{medias}} ? join(', ', @{$_->{medias}}) : N("(none)"),
                                   3 => $_->{command} ]);
	}
    };
    $reread->();

    gtkadd(
	$w->{window},
	gtkpack_(
	    gtknew('VBox', spacing => 5),
	    1, gtkpack_(
		gtknew('HBox', spacing => 10),
		1, $list,
		0, gtkpack__(
		    gtknew('VBox', spacing => 5),
		    gtksignal_connect(
			Gtk2::Button->new(but(N("Remove"))),
			clicked => sub { remove_parallel(selrow($list), $conf); $reread->() },
		    ),
		    gtksignal_connect(
			Gtk2::Button->new(but(N("Edit..."))),
			clicked => sub {
			    my $row = selrow($list);
			    $row != -1 and edit_parallel($row, $conf);
			    $reread->();
			},
		    ),
		    gtksignal_connect(
			Gtk2::Button->new(but(N("Add..."))),
			clicked => sub { edit_parallel(-1, $conf) and $reread->() },
		    )
		)
	    ),
	    0, gtknew('HSeparator'),
	    0, gtkpack(
		gtknew('HButtonBox'),
		gtknew('Button', text => N("Ok"), clicked => sub { Gtk2->main_quit })
	    )
	)
    );
    $w->main;
}

sub keys_callback() {
    my $w = ugtk2->new(N("Manage keys for digital signatures of packages"), grab => 1, center => 1,  transient => $mainw->{real_window});
    local $::main_window = $w->{real_window};
    $w->{real_window}->set_size_request(600, 300);

    my $media_list_ls = Gtk2::ListStore->new("Glib::String");
    my $media_list = Gtk2::TreeView->new_with_model($media_list_ls);
    $media_list->append_column(Gtk2::TreeViewColumn->new_with_attributes(N("Medium"), Gtk2::CellRendererText->new, 'text' => 0));
    $media_list->get_selection->set_mode('browse');

    my $key_col_size = 200;
    my $keys_list_ls = Gtk2::ListStore->new("Glib::String", "Glib::String");
    my $keys_list = Gtk2::TreeView->new_with_model($keys_list_ls);
    $keys_list->set_rules_hint(1);
    $keys_list->append_column(my $col = Gtk2::TreeViewColumn->new_with_attributes(N("_:cryptographic keys\nKeys"), my $renderer = Gtk2::CellRendererText->new, 'text' => 0));
    $col->set_sizing('fixed');
    $col->set_fixed_width($key_col_size);
    $renderer->set_property('width' => 1);
    $renderer->set_property('wrap-width', $key_col_size);
    $keys_list->get_selection->set_mode('browse');

    my ($current_medium, $current_medium_nb, @keys);

    my $read_conf = sub {
        $urpm->parse_pubkeys(root => $urpm->{root});
        @keys = map { [ split /[,\s]+/, $_->{'key-ids'} ] } @{$urpm->{media}};
    };
    my $write = sub {
        $something_changed = 1;
        urpm::media::write_config($urpm);
        $urpm = fast_open_urpmi_db();
        $read_conf->();
        $media_list->get_selection->signal_emit('changed');
    };
    $read_conf->();
    my $key_name = sub {
        exists $urpm->{keys}{$_[0]} ? $urpm->{keys}{$_[0]}{name}
                                    : N("no name found, key doesn't exist in rpm keyring!");
    };
    $media_list_ls->append_set([ 0 => $_->{name} ]) foreach @{$urpm->{media}};
    $media_list->get_selection->signal_connect(changed => sub {
        my ($model, $iter) = $_[0]->get_selected;
        $model && $iter or return;
        $current_medium = $model->get($iter, 0);
        $current_medium_nb = $model->get_path($iter)->to_string;
        $keys_list_ls->clear;
        $keys_list_ls->append_set([ 0 => sprintf("%s (%s)", $_, $key_name->($_)), 1 => $_ ]) foreach @{$keys[$current_medium_nb]};
    });

    my $add_key = sub {
        my $available_keyz_ls = Gtk2::ListStore->new("Glib::String", "Glib::String");
        my $available_keyz = Gtk2::TreeView->new_with_model($available_keyz_ls);
        $available_keyz->append_column(Gtk2::TreeViewColumn->new_with_attributes(undef, Gtk2::CellRendererText->new, 'text' => 0));
        $available_keyz->set_headers_visible(0);
        $available_keyz->get_selection->set_mode('browse');
        $available_keyz_ls->append_set([ 0 => sprintf("%s (%s)", $_, $key_name->($_)), 1 => $_ ]) foreach keys %{$urpm->{keys}};
        my $key;
        add_callback_(N("Add a key"), N("Choose a key for adding to the medium %s", $current_medium), $w, $available_keyz,
                      sub {
                          my ($model, $iter) = $available_keyz->get_selection->get_selected;
                          $model && $iter and $key = $model->get($iter, 1);
                      },
                      sub {
                          return if !defined $key;
                          $urpm->{media}[$current_medium_nb]{'key-ids'} = join(',', sort(uniq(@{$keys[$current_medium_nb]}, $key)));
                          $write->();
                      }
                  );


    };

    my $remove_key = sub {
        my ($model, $iter) = $keys_list->get_selection->get_selected;
        $model && $iter or return;
        my $key = $model->get($iter, 1);
	interactive_msg(N("Remove a key"),
                        N("Are you sure you want to remove the key %s from medium %s?\n(name of the key: %s)",
                          $key, $current_medium, $key_name->($key)),
                        yesno => 1,  transient => $w->{real_window}) or return;