mirror of https://github.com/Icinga/icinga2.git
Merge pull request #5725 from Icinga/feature/proper-uuids
Use real UUIDs for Utility::NewUniqueID
This commit is contained in:
commit
1b4206e5b1
|
@ -16,7 +16,7 @@
|
||||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 2.6)
|
cmake_minimum_required(VERSION 2.6)
|
||||||
set(BOOST_MIN_VERSION "1.41.0")
|
set(BOOST_MIN_VERSION "1.48.0")
|
||||||
|
|
||||||
project(icinga2)
|
project(icinga2)
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include <boost/algorithm/string/classification.hpp>
|
#include <boost/algorithm/string/classification.hpp>
|
||||||
#include <boost/algorithm/string/trim.hpp>
|
#include <boost/algorithm/string/trim.hpp>
|
||||||
#include <boost/algorithm/string/replace.hpp>
|
#include <boost/algorithm/string/replace.hpp>
|
||||||
|
#include <boost/uuid/uuid_io.hpp>
|
||||||
#include <ios>
|
#include <ios>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
@ -438,27 +439,8 @@ void Utility::Sleep(double timeout)
|
||||||
*/
|
*/
|
||||||
String Utility::NewUniqueID(void)
|
String Utility::NewUniqueID(void)
|
||||||
{
|
{
|
||||||
static boost::mutex mutex;
|
boost::uuids::uuid u;
|
||||||
static int next_id = 0;
|
return boost::lexical_cast<std::string>(u);
|
||||||
|
|
||||||
/* I'd much rather use UUIDs but RHEL is way too cool to have
|
|
||||||
* a semi-recent version of boost. Yay. */
|
|
||||||
|
|
||||||
String id;
|
|
||||||
|
|
||||||
char buf[128];
|
|
||||||
if (gethostname(buf, sizeof(buf)) == 0)
|
|
||||||
id = String(buf) + "-";
|
|
||||||
|
|
||||||
id += Convert::ToString((long)Utility::GetTime()) + "-";
|
|
||||||
|
|
||||||
{
|
|
||||||
boost::mutex::scoped_lock lock(mutex);
|
|
||||||
id += Convert::ToString(next_id);
|
|
||||||
next_id++;
|
|
||||||
}
|
|
||||||
|
|
||||||
return id;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
|
Loading…
Reference in New Issue