]> git.saurik.com Git - apt.git/blobdiff - apt-private/private-main.cc
correct cross & disappear progress detection
[apt.git] / apt-private / private-main.cc
index 0a9f4713fcd8c9b1fafd845440a13eef0e46259c..52f35cfdc08d4f1b2f5decdaa494161950826006 100644 (file)
@@ -3,6 +3,7 @@
 #include <apt-pkg/cmndline.h>
 #include <apt-pkg/configuration.h>
 #include <apt-pkg/fileutl.h>
+#include <apt-pkg/strutl.h>
 
 #include <apt-private/private-main.h>
 
 #include <apti18n.h>
 
 
-void InitLocale()                                                      /*{{{*/
+void InitLocale(APT_CMD const binary)                          /*{{{*/
 {
-   std::locale::global(std::locale(""));
-   textdomain(PACKAGE);
+   try {
+      std::locale::global(std::locale(""));
+   } catch (...) {
+      setlocale(LC_ALL, "");
+   }
+   switch(binary)
+   {
+      case APT_CMD::APT:
+      case APT_CMD::APT_CACHE:
+      case APT_CMD::APT_CDROM:
+      case APT_CMD::APT_CONFIG:
+      case APT_CMD::APT_DUMP_SOLVER:
+      case APT_CMD::APT_HELPER:
+      case APT_CMD::APT_GET:
+      case APT_CMD::APT_MARK:
+        textdomain("apt");
+        break;
+      case APT_CMD::APT_EXTRACTTEMPLATES:
+      case APT_CMD::APT_FTPARCHIVE:
+      case APT_CMD::APT_INTERNAL_PLANNER:
+      case APT_CMD::APT_INTERNAL_SOLVER:
+      case APT_CMD::APT_SORTPKG:
+        textdomain("apt-utils");
+        break;
+   }
 }
+void InitLocale() {}
                                                                        /*}}}*/
 void InitSignals()                                                     /*{{{*/
 {
@@ -38,11 +63,12 @@ void CheckIfSimulateMode(CommandLine &CmdL)                         /*{{{*/
          strcmp(CmdL.FileList[0], "changelog") != 0)))
    {
       if (getuid() != 0 && _config->FindB("APT::Get::Show-User-Simulation-Note",true) == true)
-         std::cout << _("NOTE: This is only a simulation!\n"
-           "      apt-get needs root privileges for real execution.\n"
+        // TRANSLATORS: placeholder is a binary name like apt or apt-get
+        ioprintf(std::cout, _("NOTE: This is only a simulation!\n"
+           "      %s needs root privileges for real execution.\n"
            "      Keep also in mind that locking is deactivated,\n"
-           "      so don't depend on the relevance to the real current situation!"
-        ) << std::endl;
+           "      so don't depend on the relevance to the real current situation!\n"),
+           _config->Find("Binary").c_str());
       _config->Set("Debug::NoLocking",true);
    }
 }