ITokens.h#

Fully qualified name: carb/tokens/ITokens.h

File members: carb/tokens/ITokens.h

// SPDX-FileCopyrightText: Copyright (c) 2019-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
// SPDX-License-Identifier: LicenseRef-NvidiaProprietary
//
// NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
// property and proprietary rights in and to this material, related
// documentation and any modifications thereto. Any use, reproduction,
// disclosure or distribution of this material and related documentation
// without an express license agreement from NVIDIA CORPORATION or
// its affiliates is strictly prohibited.

#pragma once

#include "../Interface.h"
#include "../cpp/ZStringView.h"
#include "../cpp/StringView.h"
#include "../../omni/String.h"

#define carb_tokens_ITokens_latest CARB_HEXVERSION(1, 1)
#ifndef carb_tokens_ITokens
#    define carb_tokens_ITokens CARB_HEXVERSION(1, 0)
#endif

namespace carb
{
namespace tokens
{

enum class ResolveResult
{
    eSuccess,
    eTruncated,
    eFailure,
};

enum class StringEndingMode
{
    eNullTerminator,
    eNoNullTerminator
};

using ResolveFlags = uint32_t;
const ResolveFlags kResolveFlagNone = 0;
const ResolveFlags kResolveFlagLeaveTokenIfNotFound = 1;

struct ITokens
{
    // 1.0 - Initial release
    // 1.1 - added string_view-based functions
    CARB_PLUGIN_INTERFACE_EX("carb::tokens::ITokens", carb_tokens_ITokens_latest, carb_tokens_ITokens)
    // Ensure proper initialization order
    // Members must be declared in the same sequence as initialized

    bool(CARB_ABI* setValue)(const char* name, const char* value);

    void setInitialValue(const char* name, const char* value) const;

    bool removeToken(const char* name) const;

    ResolveResult(CARB_ABI* resolveString)(const char* sourceBuf,
                                           size_t sourceBufLen,
                                           char* destBuf,
                                           size_t destBufLen,
                                           StringEndingMode endingMode,
                                           ResolveFlags resolveFlags,
                                           size_t* resolvedSize);

    size_t(CARB_ABI* calculateDestinationBufferSize)(const char* sourceBuf,
                                                     size_t sourceBufLen,
                                                     StringEndingMode endingMode,
                                                     ResolveFlags resolveFlags,
                                                     ResolveResult* resolveResult);

    bool(CARB_ABI* exists)(const char* tokenName);

#if CARB_VERSION_ATLEAST(carb_tokens_ITokens, 1, 1)

    // Extended interface functions (v1.1)
    bool(CARB_ABI* setValueS)(const cpp::zstring_view& name, const cpp::string_view& value);

    ResolveResult(CARB_ABI* resolveStringS)(const cpp::string_view& sourceBuf,
                                            omni::string& destBuf,
                                            ResolveFlags resolveFlags);

    bool(CARB_ABI* existsS)(const cpp::zstring_view& tokenName);

    bool(CARB_ABI* deleteValueS)(const cpp::zstring_view& name);

    size_t(CARB_ABI* calculateDestinationBufferSizeS)(const cpp::string_view& sourceBuf,
                                                      StringEndingMode endingMode,
                                                      ResolveFlags resolveFlags,
                                                      ResolveResult* resolveResult);

    void setInitialValueS(cpp::zstring_view name, cpp::string_view value) const
    {
        if (!existsS(name))
        {
            setValueS(name, value);
        }
    }

#endif
};

inline void ITokens::setInitialValue(const char* name, const char* value) const
{
    if (!exists(name) && value)
    {
        setValue(name, value);
    }
}

inline bool ITokens::removeToken(const char* name) const
{
    return setValue(name, nullptr);
}

} // namespace tokens
} // namespace carb