blob: a06fceee0ab54321cdbab6522f2afc699c9debdb [file] [log] [blame]
Yingdi Yu40cd1c32014-04-17 15:02:17 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014 University of Memphis,
4 * Regents of the University of California
5 *
6 * This file is part of NLSR (Named-data Link State Routing).
7 * See AUTHORS.md for complete list of NLSR authors and contributors.
8 *
9 * NLSR is free software: you can redistribute it and/or modify it under the terms
10 * of the GNU General Public License as published by the Free Software Foundation,
11 * either version 3 of the License, or (at your option) any later version.
12 *
13 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
14 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
akmhoque3d06e792014-05-27 16:23:20 -050019 *
20 * \author A K M Mahmudul Hoque <ahoque1@memphis.edu>
21 * \author Yingdi Yu <yingdi@cs.ucla.edu>
22 *
Yingdi Yu40cd1c32014-04-17 15:02:17 -070023 **/
akmhoque53353462014-04-22 08:43:45 -050024#include "conf-file-processor.hpp"
akmhoque674b0b12014-05-20 14:33:28 -050025#include "logger.hpp"
Vince Lehman7c603292014-09-11 17:48:16 -050026#include "nlsr.hpp"
Vince Lehmanb722b102014-08-24 16:33:49 -050027#include "version.hpp"
Yingdi Yu40cd1c32014-04-17 15:02:17 -070028
Vince Lehman7c603292014-09-11 17:48:16 -050029#include <boost/asio.hpp>
30#include <boost/cstdint.hpp>
31
32#include <ndn-cxx/util/scheduler.hpp>
33
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070034namespace nlsr {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070035
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070036int
akmhoquefdbddb12014-05-02 18:35:19 -050037main(int32_t argc, char** argv)
Yingdi Yu40cd1c32014-04-17 15:02:17 -070038{
Vince Lehman7c603292014-09-11 17:48:16 -050039 boost::asio::io_service ioService;
40 ndn::Scheduler scheduler(ioService);
41
42 Nlsr nlsr(ioService, scheduler);
43
akmhoquefdbddb12014-05-02 18:35:19 -050044 std::string programName(argv[0]);
akmhoqueb6450b12014-04-24 00:01:03 -050045 nlsr.setConfFileName("nlsr.conf");
akmhoquefdbddb12014-05-02 18:35:19 -050046 int32_t opt;
Vince Lehmanb722b102014-08-24 16:33:49 -050047 while ((opt = getopt(argc, argv, "df:hV")) != -1) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070048 switch (opt)
Vince Lehmanb722b102014-08-24 16:33:49 -050049 {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070050 case 'f':
akmhoqueb6450b12014-04-24 00:01:03 -050051 nlsr.setConfFileName(optarg);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070052 break;
53 case 'd':
akmhoque0494c252014-07-23 23:46:44 -050054 nlsr.setIsDaemonProcess(true);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070055 break;
Vince Lehmanb722b102014-08-24 16:33:49 -050056 case 'V':
57 std::cout << NLSR_VERSION_BUILD_STRING << std::endl;
58 return EXIT_SUCCESS;
59 break;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070060 case 'h':
61 default:
akmhoqueb6450b12014-04-24 00:01:03 -050062 nlsr.usage(programName);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070063 return EXIT_FAILURE;
Vince Lehmanb722b102014-08-24 16:33:49 -050064 }
Yingdi Yu40cd1c32014-04-17 15:02:17 -070065 }
akmhoqueb6450b12014-04-24 00:01:03 -050066 ConfFileProcessor cfp(nlsr, nlsr.getConfFileName());
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070067 if (!cfp.processConfFile()) {
akmhoquead5fe952014-06-26 13:34:12 -050068 std::cerr << "Error in configuration file processing! Exiting from NLSR" << std::endl;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070069 return EXIT_FAILURE;
70 }
Vince Lehmanf99b87f2014-08-26 15:54:27 -050071
72 INIT_LOGGERS(nlsr.getConfParameter().getLogDir(), nlsr.getConfParameter().getLogLevel());
akmhoque674b0b12014-05-20 14:33:28 -050073 INIT_LOGGER("Main");
Vince Lehmanf99b87f2014-08-26 15:54:27 -050074
akmhoqueb6450b12014-04-24 00:01:03 -050075 nlsr.initialize();
akmhoque0494c252014-07-23 23:46:44 -050076 if (nlsr.getIsSetDaemonProcess()) {
77 nlsr.daemonize();
78 }
akmhoquefdbddb12014-05-02 18:35:19 -050079 try {
akmhoqueb6450b12014-04-24 00:01:03 -050080 nlsr.startEventLoop();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070081 }
akmhoque31d1d4b2014-05-05 22:08:14 -050082 catch (std::exception& e) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070083 std::cerr << "ERROR: " << e.what() << std::endl;
akmhoque31d1d4b2014-05-05 22:08:14 -050084 nlsr.getFib().clean();
akmhoquee1765152014-06-30 11:32:01 -050085 nlsr.destroyFaces();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070086 }
87 return EXIT_SUCCESS;
88}
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070089
90} // namespace nlsr
91
92int
93main(int32_t argc, char** argv)
94{
95 return nlsr::main(argc, argv);
96}