IBR-DTNSuite  0.10
Random.cpp
Go to the documentation of this file.
1 /*
2  * Random.cpp
3  *
4  * Copyright (C) 2011 IBR, TU Braunschweig
5  *
6  * Written-by: Johannes Morgenroth <morgenroth@ibr.cs.tu-bs.de>
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  */
21 
22 #include "Random.h"
23 #include <time.h>
24 #include <stdlib.h>
25 #include <vector>
26 #include <sys/time.h>
27 
28 namespace dtn
29 {
30  namespace utils
31  {
33  {
34  static bool initialized = false;
35 
36  if (!initialized) {
37  struct timeval time;
38  ::gettimeofday(&time, NULL);
39 
40  // initialize a random seed only once
41  srand(static_cast<unsigned int>((time.tv_sec * 100) + (time.tv_usec / 100)));
42  initialized = true;
43  }
44  }
45 
47  {
48  }
49 
50  const std::string Random::gen_chars(const dtn::data::Length &size) const
51  {
52  static const char text[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
53  std::vector<char> dst(size);
54  const dtn::data::Length len = size - 1;
55  for ( dtn::data::Length i = 0; i <= len; ++i )
56  {
57  dst[i] = text[rand() % (sizeof text - 1)];
58  }
59  return std::string(dst.begin(), dst.end());
60  }
61  }
62 }