本文整理汇总了C++中Daemon::jail方法的典型用法代码示例。如果您正苦于以下问题:C++ Daemon::jail方法的具体用法?C++ Daemon::jail怎么用?C++ Daemon::jail使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Daemon
的用法示例。
在下文中一共展示了Daemon::jail方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
int
Globals::run(int argc, char * * argv)
{
Daemon daemon;
char * cp;
char * sockarg;
name(FilePath(argv[0]).filename());
// Parse arguments.
config = FilePath("/etc") + name();
for (;;) {
cp = *++argv;
if (!--argc || *cp != '-' || !cp[1])
break;
while (*++cp)
switch (*cp) {
case 'c': // Configuration file.
if (!--argc)
usage();
config = *++argv;
break;
case 'd': // Increase debug level.
debuglvl++;
break;
case 'e': // Log to stderr only.
stderrOnly = true;
break;
case 'g': // Group.
if (!--argc)
usage();
group = *++argv;
break;
case 'j': // Jail.
if (!--argc)
usage();
jail = *++argv;
break;
case 'l': // Log to stderr too.
logstd = true;
break;
case 'n': // Do not detach.
nodaemon = true;
break;
case 'u': // User.
if (!--argc)
usage();
user = *++argv;
break;
default:
usage();
}
}
if (!cp)
usage();
else if (--argc)
usage();
sockarg = cp;
// Daemonize.
// Do not change user and/or group now, since we need full
// permissions for sockets.
try {
daemon.program(name());
daemon.lock_file(FilePath(LOCKDIR) + daemon.program());
daemon.pid_file(FilePath(RUNDIR) + (daemon.program() + ".pid"));
daemon.user(user);
daemon.group(group);
daemon.log_to_stderr(logstd);
daemon.jail(jail);
daemon.block_signals();
daemon.ignore_signals();
if (!nodaemon)
daemon.detach();
daemon.close_all(!stderrOnly);
daemon.open_log(LOG_PID | LOG_NDELAY, LOG_MAIL);
//.........这里部分代码省略.........