Instead of lengthy blurbs, switch to single-line, machine-readable standardized (https://spdx.dev) license identifiers. The Linux kernel switched long ago, so there is strong precedent. Three cases are handled: AGPL-only, Apache-only, and dual licensed. For the latter case, I chose (AGPL-3.0-or-later and Apache-2.0), reasoning that our changes are extensive enough to apply our license. The changes we applied mechanically with a script, except to licenses/README.md. Closes #9937
41 lines
888 B
C++
41 lines
888 B
C++
/*
|
|
* Copyright (C) 2020-present ScyllaDB
|
|
*/
|
|
|
|
/*
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <atomic>
|
|
|
|
namespace utils {
|
|
|
|
/*
|
|
* The neat_id class is purely a debugging thing -- when reading
|
|
* the logs with object IDs in it it's more handy to look at those
|
|
* consisting * of 1-3 digits, rather than 16 hex-digits of a printed
|
|
* pointer.
|
|
*
|
|
* Embed with [[no_unique_address]] tag for memory efficiency
|
|
*/
|
|
template <bool Debug>
|
|
struct neat_id {
|
|
unsigned int operator()() const noexcept { return reinterpret_cast<uintptr_t>(this); }
|
|
};
|
|
|
|
template <>
|
|
struct neat_id<true> {
|
|
unsigned int _id;
|
|
static unsigned int _next() noexcept {
|
|
static std::atomic<unsigned int> rover {1};
|
|
return rover.fetch_add(1);
|
|
}
|
|
|
|
neat_id() noexcept : _id(_next()) {}
|
|
unsigned int operator()() const noexcept { return _id; }
|
|
};
|
|
|
|
} // namespace
|