1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-23 08:52:12 +01:00
dxvk/src/util/util_env.h

74 lines
1.8 KiB
C
Raw Normal View History

2017-12-08 11:18:23 +01:00
#pragma once
#include "util_string.h"
namespace dxvk::env {
2021-10-01 14:18:42 +02:00
/**
* \brief Checks whether the host platform is 32-bit
*/
constexpr bool is32BitHostPlatform() {
return sizeof(void*) == 4;
}
2017-12-08 11:18:23 +01:00
/**
* \brief Gets environment variable
*
* If the variable is not defined, this will return
* an empty string. Note that environment variables
* may be defined with an empty value.
* \param [in] name Name of the variable
* \returns Value of the variable
*/
std::string getEnvVar(const char* name);
2017-12-08 11:18:23 +01:00
/**
* \brief Checks whether a file name has a given extension
*
* \param [in] name File name
* \param [in] ext Extension to match, in lowercase letters
* \returns Position of the extension within the file name, or
* \c std::string::npos if the file has a different extension
*/
size_t matchFileExtension(const std::string& name, const char* ext);
/**
* \brief Gets the executable name
*
* Returns the base name (not the full path) of the
* program executable, including the file extension.
* This function should be used to identify programs.
* \returns Executable name
*/
std::string getExeName();
/**
* \brief Gets the executable name without extension
*
* Same as \ref getExeName but without the file extension.
* \returns Executable name
*/
std::string getExeBaseName();
/**
* \brief Gets full path to executable
* \returns Path to executable
*/
std::string getExePath();
/**
* \brief Sets name of the calling thread
* \param [in] name Thread name
*/
void setThreadName(const std::string& name);
/**
* \brief Creates a directory
*
* \param [in] path Path to directory
* \returns \c true on success
*/
bool createDirectory(const std::string& path);
}