Files
scylladb/utils/only_on_shard0.hh
Avi Kivity 0ae22a09d4 LICENSE: Update to version 1.1
Updated terms of non-commercial use (must be a never-customer).
2026-04-12 19:46:33 +03:00

24 lines
529 B
C++

/*
* Copyright (C) 2025-present ScyllaDB
*/
/*
* SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.1
*/
#pragma once
#include <seastar/core/sharded.hh>
#include <seastar/core/shard_id.hh>
// When passed to sharded<>::start(), translates to "val" passed to sharded instances on shard 0 and T{} on other shards.
template <typename T>
auto only_on_shard0(T val) {
return sharded_parameter([val] {
if (seastar::this_shard_id() == 0) {
return val;
}
return T{};
});
}