| // |
| // Copyright (C) 2015 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // |
| |
| |
| #include <base/command_line.h> |
| #include <base/logging.h> |
| #include <brillo/syslog_logging.h> |
| #include "dhcp_client/daemon.h" |
| |
| using std::vector; |
| |
| namespace { |
| |
| namespace switches { |
| |
| // Don't daemon()ize; run in foreground. |
| const char kForeground[] = "foreground"; |
| // Flag to show the help message. |
| const char kHelp[] = "help"; |
| // The help message shown if help flag is passed to the program. |
| const char kHelpMessage[] = "\n help message \n"; |
| |
| } // namespace switches |
| |
| } // namespace |
| |
| // Always logs to the syslog and logs to stderr if |
| // we are running in the foreground. |
| void SetupLogging(bool foreground, |
| const char* daemon_name) { |
| int log_flags = 0; |
| log_flags |= brillo::kLogToSyslog; |
| log_flags |= brillo::kLogHeader; |
| if (foreground) { |
| log_flags |= brillo::kLogToStderr; |
| } |
| brillo::InitLog(log_flags); |
| } |
| |
| void OnStartup(const char* daemon_name, base::CommandLine* cl) { |
| LOG(INFO) << __func__; |
| SetupLogging(cl->HasSwitch(switches::kForeground), daemon_name); |
| return; |
| } |
| |
| int main(int argc, char* argv[]) { |
| base::CommandLine::Init(argc, argv); |
| base::CommandLine* cl = base::CommandLine::ForCurrentProcess(); |
| |
| if (cl->HasSwitch(switches::kHelp)) { |
| LOG(INFO) << switches::kHelpMessage; |
| return 0; |
| } |
| |
| dhcp_client::Daemon daemon(base::Bind(&OnStartup, argv[0], cl)); |
| |
| daemon.Run(); |
| |
| return 0; |
| } |