X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/0d5b9da9f597fecae9b912d37d4e58bc903bdd4f..a6ae3d3df490e7a5a1c8324ba9dc2e63972b1529:/apt-private/private-main.cc diff --git a/apt-private/private-main.cc b/apt-private/private-main.cc index 3886c7df6..52f35cfdc 100644 --- a/apt-private/private-main.cc +++ b/apt-private/private-main.cc @@ -2,10 +2,14 @@ #include #include +#include +#include #include #include +#include + #include #include #include @@ -13,14 +17,42 @@ #include -void InitSignals() +void InitLocale(APT_CMD const binary) /*{{{*/ +{ + 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() /*{{{*/ { - // Setup the signals signal(SIGPIPE,SIG_IGN); } - - -void CheckSimulateMode(CommandLine &CmdL) + /*}}}*/ +void CheckIfSimulateMode(CommandLine &CmdL) /*{{{*/ { // disable locking in simulation, but show the message only for users // as root hasn't the same problems like unreadable files which can heavily @@ -31,11 +63,29 @@ void CheckSimulateMode(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); } } + /*}}}*/ +void CheckIfCalledByScript(int argc, const char *argv[]) /*{{{*/ +{ + if (unlikely(argc < 1)) return; + + if(!isatty(STDOUT_FILENO) && + _config->FindB("Apt::Cmd::Disable-Script-Warning", false) == false) + { + std::cerr << std::endl + << "WARNING: " << flNotDir(argv[0]) << " " + << "does not have a stable CLI interface. " + << "Use with caution in scripts." + << std::endl + << std::endl; + } +} + /*}}}*/