blob: 99e8faee68331723c1cba64f2b40f18873cd22fc [file] [log] [blame]
Jeff Thompsonfa306642013-06-17 15:06:57 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
2/*
3 * Copyright (c) 2013, Regents of the University of California
4 * Alexander Afanasyev
5 * Zhenkai Zhu
6 *
7 * BSD license, See the LICENSE file for more information
8 *
9 * Author: Zhenkai Zhu <zhenkai@cs.ucla.edu>
10 * Alexander Afanasyev <alexander.afanasyev@ucla.edu>
11 */
12
13#ifndef NDN_COMMON_H
14#define NDN_COMMON_H
15
16#include <boost/shared_ptr.hpp>
17#include <boost/make_shared.hpp>
18#include <boost/date_time/posix_time/posix_time_types.hpp>
19
20namespace ndn
21{
Jeff Thompsonfa306642013-06-17 15:06:57 -070022typedef boost::posix_time::ptime Time;
23typedef boost::posix_time::time_duration TimeInterval;
24
25namespace time
26{
27inline TimeInterval Seconds (int secs) { return boost::posix_time::seconds (secs); }
28inline TimeInterval Milliseconds (int msecs) { return boost::posix_time::milliseconds (msecs); }
29inline TimeInterval Microseconds (int musecs) { return boost::posix_time::microseconds (musecs); }
30
31inline TimeInterval Seconds (double fractionalSeconds)
32{
33 double seconds, microseconds;
34 seconds = std::modf (fractionalSeconds, &microseconds);
35 microseconds *= 1000000;
36
37 return time::Seconds((int)seconds) + time::Microseconds((int)microseconds);
38}
39
40inline Time Now () { return boost::posix_time::microsec_clock::universal_time (); }
41
42const Time UNIX_EPOCH_TIME = Time (boost::gregorian::date (1970, boost::gregorian::Jan, 1));
43inline TimeInterval NowUnixTimestamp ()
44{
45 return TimeInterval (time::Now () - UNIX_EPOCH_TIME);
46}
47} // time
48} // ndn
49
50
51extern "C" {
52#include <ccn/ccn.h>
53#include <ccn/charbuf.h>
54#include <ccn/keystore.h>
55#include <ccn/uri.h>
56#include <ccn/bloom.h>
57#include <ccn/signing.h>
58}
59#include <vector>
60#include <boost/shared_ptr.hpp>
61#include <boost/exception/all.hpp>
62#include <boost/function.hpp>
63#include <string>
64#include <sstream>
65#include <map>
66#include <utility>
67#include <string.h>
68#include <boost/iostreams/filter/gzip.hpp>
69#include <boost/iostreams/filtering_stream.hpp>
70#include <boost/iostreams/device/back_inserter.hpp>
71#include <boost/range/iterator_range.hpp>
72#include <boost/make_shared.hpp>
73
74namespace ndn {
75typedef std::vector<unsigned char> Bytes;
76typedef std::vector<std::string>Comps;
77
78typedef boost::shared_ptr<Bytes> BytesPtr;
Jeff Thompson4454bf72013-06-18 13:33:12 -070079typedef boost::shared_ptr<const Bytes> ConstBytesPtr;
Jeff Thompsonfa306642013-06-17 15:06:57 -070080
81inline
82const unsigned char *
83head(const Bytes &bytes)
84{
85 return &bytes[0];
86}
87
88inline
89unsigned char *
90head (Bytes &bytes)
91{
92 return &bytes[0];
93}
94
95// --- Bytes operations start ---
96inline void
97readRaw(Bytes &bytes, const unsigned char *src, size_t len)
98{
99 if (len > 0)
100 {
101 bytes.resize(len);
102 memcpy (head (bytes), src, len);
103 }
104}
105
106inline BytesPtr
107readRawPtr (const unsigned char *src, size_t len)
108{
109 if (len > 0)
110 {
111 BytesPtr ret (new Bytes (len));
112 memcpy (head (*ret), src, len);
113
114 return ret;
115 }
116 else
117 return BytesPtr ();
118}
Jeff Thompsonfa306642013-06-17 15:06:57 -0700119} // ndn
120#endif // NDN_COMMON_H