blob: 319e622e7c4e809f9380e969d54685417dbca390 [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);
Vince Lehman904c2412014-09-23 19:36:11 -050041 ndn::Face face(ioService);
Vince Lehman7c603292014-09-11 17:48:16 -050042
Vince Lehman904c2412014-09-23 19:36:11 -050043 Nlsr nlsr(ioService, scheduler, face);
Vince Lehman7c603292014-09-11 17:48:16 -050044
akmhoquefdbddb12014-05-02 18:35:19 -050045 std::string programName(argv[0]);
akmhoqueb6450b12014-04-24 00:01:03 -050046 nlsr.setConfFileName("nlsr.conf");
akmhoquefdbddb12014-05-02 18:35:19 -050047 int32_t opt;
Vince Lehmanb722b102014-08-24 16:33:49 -050048 while ((opt = getopt(argc, argv, "df:hV")) != -1) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070049 switch (opt)
Vince Lehmanb722b102014-08-24 16:33:49 -050050 {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070051 case 'f':
akmhoqueb6450b12014-04-24 00:01:03 -050052 nlsr.setConfFileName(optarg);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070053 break;
54 case 'd':
akmhoque0494c252014-07-23 23:46:44 -050055 nlsr.setIsDaemonProcess(true);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070056 break;
Vince Lehmanb722b102014-08-24 16:33:49 -050057 case 'V':
58 std::cout << NLSR_VERSION_BUILD_STRING << std::endl;
59 return EXIT_SUCCESS;
60 break;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070061 case 'h':
62 default:
akmhoqueb6450b12014-04-24 00:01:03 -050063 nlsr.usage(programName);
Yingdi Yu40cd1c32014-04-17 15:02:17 -070064 return EXIT_FAILURE;
Vince Lehmanb722b102014-08-24 16:33:49 -050065 }
Yingdi Yu40cd1c32014-04-17 15:02:17 -070066 }
akmhoqueb6450b12014-04-24 00:01:03 -050067 ConfFileProcessor cfp(nlsr, nlsr.getConfFileName());
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070068 if (!cfp.processConfFile()) {
akmhoquead5fe952014-06-26 13:34:12 -050069 std::cerr << "Error in configuration file processing! Exiting from NLSR" << std::endl;
Yingdi Yu40cd1c32014-04-17 15:02:17 -070070 return EXIT_FAILURE;
71 }
Vince Lehmanf99b87f2014-08-26 15:54:27 -050072
73 INIT_LOGGERS(nlsr.getConfParameter().getLogDir(), nlsr.getConfParameter().getLogLevel());
akmhoque674b0b12014-05-20 14:33:28 -050074 INIT_LOGGER("Main");
Vince Lehmanf99b87f2014-08-26 15:54:27 -050075
akmhoqueb6450b12014-04-24 00:01:03 -050076 nlsr.initialize();
akmhoque0494c252014-07-23 23:46:44 -050077 if (nlsr.getIsSetDaemonProcess()) {
78 nlsr.daemonize();
79 }
akmhoquefdbddb12014-05-02 18:35:19 -050080 try {
akmhoqueb6450b12014-04-24 00:01:03 -050081 nlsr.startEventLoop();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070082 }
akmhoque31d1d4b2014-05-05 22:08:14 -050083 catch (std::exception& e) {
Yingdi Yu40cd1c32014-04-17 15:02:17 -070084 std::cerr << "ERROR: " << e.what() << std::endl;
akmhoque31d1d4b2014-05-05 22:08:14 -050085 nlsr.getFib().clean();
akmhoquee1765152014-06-30 11:32:01 -050086 nlsr.destroyFaces();
Yingdi Yu40cd1c32014-04-17 15:02:17 -070087 }
88 return EXIT_SUCCESS;
89}
Alexander Afanasyev7decbbf2014-08-24 21:29:01 -070090
91} // namespace nlsr
92
93int
94main(int32_t argc, char** argv)
95{
96 return nlsr::main(argc, argv);
97}