blob: f044346a9a5683a5b4e0419da7b17bfeb63e69d8 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#pragma once
#include <ignite/common/ignite_error.h>
#include <future>
#include <memory>
#include <utility>
#include <optional>
#include <string>
namespace ignite::detail {
/**
* Make future error.
*
* @tparam T Value type.
* @param err Error.
* @return Failed future with the specified error.
*/
template<typename T>
std::future<T> make_future_error(ignite_error err) {
std::promise<T> promise;
promise.set_exception(std::make_exception_ptr(std::move(err)));
return promise.get_future();
}
/**
* Make future value.
*
* @tparam T Value type.
* @param value Value.
* @return Failed future with the specified error.
*/
template<typename T>
std::future<T> make_future_value(T value) {
std::promise<T> promise;
promise.set_value(std::move(value));
return promise.get_future();
}
/**
* Get environment variable.
*
* @param name Variable name.
* @return Variable value if it is set, or @c std::nullopt otherwise.
*/
inline std::optional<std::string> get_env(const std::string &name) {
const char *env = std::getenv(name.c_str());
if (!env)
return {};
return env;
}
} // namespace ignite::detail