IBR-DTNSuite  0.12
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  int Random::gen_number() const
51  {
52  return ::rand();
53  }
54 
55  const std::string Random::gen_chars(const size_t &size) const
56  {
57  static const char text[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
58  std::vector<char> dst(size);
59  const size_t len = size - 1;
60  for ( size_t i = 0; i <= len; ++i )
61  {
62  dst[i] = text[::rand() % (sizeof text - 1)];
63  }
64  return std::string(dst.begin(), dst.end());
65  }
66  }
67 }