blob: a21b0fdfac30e7928595b8fd2d02ac7c08e75ce9 [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 **/
Alexander Afanasyevb669f9c2014-11-14 12:41:54 -080024
25#include <ndn-cxx/util/scheduler.hpp>
26
akmhoque53353462014-04-22 08:43:45 -050027#include "conf-file-processor.hpp"
akmhoque674b0b12014-05-20 14:33:28 -050028#include "logger.hpp"
Vince Lehman7c603292014-09-11 17:48:16 -050029#include "nlsr.hpp"
Vince Lehmanb722b102014-08-24 16:33:49 -050030#include "version.hpp"
Yingdi Yu40cd1c32014-04-17 15:02:17 -070031
Alexander Afanasyevb669f9c2014-11-14 12:41:54 -080032// boost needs to be included after ndn-cxx, otherwise there will be conflict with _1, _2, ...
Vince Lehman7c603292014-09-11 17:48:16 -050033#include <boost/asio.hpp>
34#include <boost/cstdint.hpp>
35
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070036namespace nlsr {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070037
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070038int
akmhoquefdbddb12014-05-02 18:35:19 -050039main(int32_t argc, char** argv)
Yingdi Yu40cd1c32014-04-17 15:02:17 -070040{
Vince Lehman7c603292014-09-11 17:48:16 -050041 boost::asio::io_service ioService;
42 ndn::Scheduler scheduler(ioService);
Vince Lehman904c2412014-09-23 19:36:11 -050043 ndn::Face face(ioService);
Vince Lehman7c603292014-09-11 17:48:16 -050044
Vince Lehman904c2412014-09-23 19:36:11 -050045 Nlsr nlsr(ioService, scheduler, face);
Vince Lehman7c603292014-09-11 17:48:16 -050046
akmhoquefdbddb12014-05-02 18:35:19 -050047 std::string programName(argv[0]);
akmhoqueb6450b12014-04-24 00:01:03 -050048 nlsr.setConfFileName("nlsr.conf");
akmhoquefdbddb12014-05-02 18:35:19 -050049 int32_t opt;
Vince Lehmanb722b102014-08-24 16:33:49 -050050 while ((opt = getopt(argc, argv, "df:hV")) != -1) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070051 switch (opt)
Vince Lehmanb722b102014-08-24 16:33:49 -050052 {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070053 case 'f':
akmhoqueb6450b12014-04-24 00:01:03 -050054 nlsr.setConfFileName(optarg);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070055 break;
56 case 'd':
akmhoque0494c252014-07-23 23:46:44 -050057 nlsr.setIsDaemonProcess(true);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070058 break;
Vince Lehmanb722b102014-08-24 16:33:49 -050059 case 'V':
60 std::cout << NLSR_VERSION_BUILD_STRING << std::endl;
61 return EXIT_SUCCESS;
62 break;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070063 case 'h':
64 default:
akmhoqueb6450b12014-04-24 00:01:03 -050065 nlsr.usage(programName);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070066 return EXIT_FAILURE;
Vince Lehmanb722b102014-08-24 16:33:49 -050067 }
Yingdi Yu40cd1c32014-04-17 15:02:17 -070068 }
akmhoqueb6450b12014-04-24 00:01:03 -050069 ConfFileProcessor cfp(nlsr, nlsr.getConfFileName());
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070070 if (!cfp.processConfFile()) {
akmhoquead5fe952014-06-26 13:34:12 -050071 std::cerr << "Error in configuration file processing! Exiting from NLSR" << std::endl;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070072 return EXIT_FAILURE;
73 }
Vince Lehmanf99b87f2014-08-26 15:54:27 -050074
75 INIT_LOGGERS(nlsr.getConfParameter().getLogDir(), nlsr.getConfParameter().getLogLevel());
akmhoque674b0b12014-05-20 14:33:28 -050076 INIT_LOGGER("Main");
Vince Lehmanf99b87f2014-08-26 15:54:27 -050077
akmhoqueb6450b12014-04-24 00:01:03 -050078 nlsr.initialize();
akmhoque0494c252014-07-23 23:46:44 -050079 if (nlsr.getIsSetDaemonProcess()) {
80 nlsr.daemonize();
81 }
akmhoquefdbddb12014-05-02 18:35:19 -050082 try {
akmhoqueb6450b12014-04-24 00:01:03 -050083 nlsr.startEventLoop();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070084 }
akmhoque31d1d4b2014-05-05 22:08:14 -050085 catch (std::exception& e) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070086 std::cerr << "ERROR: " << e.what() << std::endl;
akmhoque31d1d4b2014-05-05 22:08:14 -050087 nlsr.getFib().clean();
akmhoquee1765152014-06-30 11:32:01 -050088 nlsr.destroyFaces();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070089 }
90 return EXIT_SUCCESS;
91}
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070092
93} // namespace nlsr
94
95int
96main(int32_t argc, char** argv)
97{
98 return nlsr::main(argc, argv);
99}