refactor: add WF prefix for c/c++ binding members
This commit is contained in:
@@ -19,13 +19,13 @@
|
|||||||
|
|
||||||
namespace wfassocpp {
|
namespace wfassocpp {
|
||||||
|
|
||||||
using wfassoc::CStyleString;
|
using CString = wfassoc::WFCString;
|
||||||
using wfassoc::Token;
|
using Token = wfassoc::WFToken;
|
||||||
using wfassoc::HICON;
|
using HICON = wfassoc::WFHICON;
|
||||||
using wfassoc::INVALID_HICON;
|
using INVALID_HICON = wfassoc::WF_INVALID_HICON;
|
||||||
using wfassoc::INVALID_INDEX;
|
using INVALID_INDEX = wfassoc::WF_INVALID_INDEX;
|
||||||
using wfassoc::Scope;
|
using Scope = wfassoc::WFScope;
|
||||||
using wfassoc::View;
|
using View = wfassoc::WFView;
|
||||||
|
|
||||||
/// @private
|
/// @private
|
||||||
inline void _Check(bool result) {
|
inline void _Check(bool result) {
|
||||||
|
|||||||
@@ -28,35 +28,35 @@ namespace wfassoc {
|
|||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
/** Type representing a null-terminated UTF-8 C-style string */
|
/** Type representing a null-terminated UTF-8 C-style string */
|
||||||
using CStyleString = const char*;
|
using WFCString = const char*;
|
||||||
/**
|
/**
|
||||||
* @brief Type representing a handle/token for managed objects
|
* @brief Type representing a handle/token for managed objects
|
||||||
*
|
*
|
||||||
* This library use object pool to manage any objects created during calling.
|
* This library use object pool to manage any objects created during calling.
|
||||||
* And we expose this type as an opaque handle for visiting your created object.
|
* And we expose this type as an opaque handle for visiting your created object.
|
||||||
*/
|
*/
|
||||||
using Token = uint64_t;
|
using WFToken = uint64_t;
|
||||||
/**
|
/**
|
||||||
* @brief Type representing an icon handle (opaque pointer)
|
* @brief Type representing an icon handle (opaque pointer)
|
||||||
*
|
*
|
||||||
* This type is equivalent with Win32 HICON type.
|
* This type is equivalent with Win32 HICON type.
|
||||||
*/
|
*/
|
||||||
using HICON = void*;
|
using WFHICON = void*;
|
||||||
#else // __cplusplus
|
#else // __cplusplus
|
||||||
typedef const char *CStyleString;
|
typedef const char *WFCString;
|
||||||
typedef uint64_t Token;
|
typedef uint64_t WFToken;
|
||||||
typedef void *HICON;
|
typedef void *WFHICON;
|
||||||
#endif // __cplusplus
|
#endif // __cplusplus
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
/** Invalid icon handle value */
|
/** Invalid icon handle value */
|
||||||
constexpr HICON INVALID_HICON = nullptr;
|
constexpr WFHICON WF_INVALID_HICON = nullptr;
|
||||||
/** Invalid index value used for error conditions */
|
/** Invalid index value used for error conditions */
|
||||||
constexpr size_t INVALID_INDEX = static_cast<size_t>(-1);
|
constexpr size_t WF_INVALID_INDEX = static_cast<size_t>(-1);
|
||||||
#else // __cplusplus
|
#else // __cplusplus
|
||||||
static const HICON INVALID_HICON = NULL;
|
static const WFHICON WF_INVALID_HICON = NULL;
|
||||||
static const size_t INVALID_INDEX = ((size_t)-1);
|
static const size_t WF_INVALID_INDEX = ((size_t)-1);
|
||||||
#endif // __cplusplus
|
#endif // __cplusplus
|
||||||
|
|
||||||
|
|
||||||
@@ -66,7 +66,7 @@ static const size_t INVALID_INDEX = ((size_t)-1);
|
|||||||
*
|
*
|
||||||
* Determines whether a program is registered for the current user or system-wide.
|
* Determines whether a program is registered for the current user or system-wide.
|
||||||
*/
|
*/
|
||||||
enum class Scope : uint32_t {
|
enum class WFScope : uint32_t {
|
||||||
/** Current user scope */
|
/** Current user scope */
|
||||||
User = 0u,
|
User = 0u,
|
||||||
/** System-wide scope */
|
/** System-wide scope */
|
||||||
@@ -77,7 +77,7 @@ enum class Scope : uint32_t {
|
|||||||
*
|
*
|
||||||
* Determines how the association status is viewed/queried.
|
* Determines how the association status is viewed/queried.
|
||||||
*/
|
*/
|
||||||
enum class View : uint32_t {
|
enum class WFView : uint32_t {
|
||||||
/** User-level view */
|
/** User-level view */
|
||||||
User = 0u,
|
User = 0u,
|
||||||
/** System-level view */
|
/** System-level view */
|
||||||
@@ -86,18 +86,18 @@ enum class View : uint32_t {
|
|||||||
Hybrid = 2u
|
Hybrid = 2u
|
||||||
};
|
};
|
||||||
#else // __cplusplus
|
#else // __cplusplus
|
||||||
typedef uint32_t Scope;
|
typedef uint32_t WFScope;
|
||||||
/** Current user scope */
|
/** Current user scope */
|
||||||
static const Scope SCOPE_USER = 0u;
|
static const WFScope WF_SCOPE_USER = 0u;
|
||||||
/** System-wide scope */
|
/** System-wide scope */
|
||||||
static const Scope SCOPE_SYSTEM = 1u;
|
static const WFScope WF_SCOPE_SYSTEM = 1u;
|
||||||
typedef uint32_t View;
|
typedef uint32_t WFView;
|
||||||
/** User-level view */
|
/** User-level view */
|
||||||
static const View VIEW_USER = 0u;
|
static const WFView WF_VIEW_USER = 0u;
|
||||||
/** System-level view */
|
/** System-level view */
|
||||||
static const View VIEW_SYSTEM = 1u;
|
static const WFView WF_VIEW_SYSTEM = 1u;
|
||||||
/** Combined hybrid view of both user and system */
|
/** Combined hybrid view of both user and system */
|
||||||
static const View VIEW_HYBRID = 2u;
|
static const WFView WF_VIEW_HYBRID = 2u;
|
||||||
#endif // __cplusplus
|
#endif // __cplusplus
|
||||||
|
|
||||||
|
|
||||||
@@ -143,7 +143,7 @@ bool WFShutdown(void);
|
|||||||
* If no error has occurred, the string is empty.
|
* If no error has occurred, the string is empty.
|
||||||
* There is no possibility of a NULL return value.
|
* There is no possibility of a NULL return value.
|
||||||
*/
|
*/
|
||||||
CStyleString WFGetLastError(void);
|
WFCString WFGetLastError(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Check if the current process has administrative privileges
|
* @brief Check if the current process has administrative privileges
|
||||||
@@ -170,7 +170,7 @@ bool WFHasPrivilege(void);
|
|||||||
*
|
*
|
||||||
* @return An invalid token value
|
* @return An invalid token value
|
||||||
*/
|
*/
|
||||||
Token WFInvalidToken(void);
|
WFToken WFInvalidWFToken(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Create a new Schema object
|
* @brief Create a new Schema object
|
||||||
@@ -185,7 +185,7 @@ Token WFInvalidToken(void);
|
|||||||
* or consumed by creating a Program object via WFProgramCreate().
|
* or consumed by creating a Program object via WFProgramCreate().
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaCreate(Token *out_schema);
|
bool WFSchemaCreate(WFToken *out_schema);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Destroy a Schema object
|
* @brief Destroy a Schema object
|
||||||
@@ -198,7 +198,7 @@ bool WFSchemaCreate(Token *out_schema);
|
|||||||
* @param[in] in_schema Schema token to destroy
|
* @param[in] in_schema Schema token to destroy
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaDestroy(Token in_schema);
|
bool WFSchemaDestroy(WFToken in_schema);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program identifier for a Schema
|
* @brief Set the program identifier for a Schema
|
||||||
@@ -209,7 +209,7 @@ bool WFSchemaDestroy(Token in_schema);
|
|||||||
* and follow with alphabet characters, digits, underline, or hyphens.
|
* and follow with alphabet characters, digits, underline, or hyphens.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetIdentifier(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetIdentifier(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program path for a Schema
|
* @brief Set the program path for a Schema
|
||||||
@@ -219,7 +219,7 @@ bool WFSchemaSetIdentifier(Token in_schema, CStyleString in_value);
|
|||||||
* This path should be the fully qualified path to the application.
|
* This path should be the fully qualified path to the application.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetPath(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetPath(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program CLSID for a Schema
|
* @brief Set the program CLSID for a Schema
|
||||||
@@ -230,7 +230,7 @@ bool WFSchemaSetPath(Token in_schema, CStyleString in_value);
|
|||||||
* Please note that curly braces are required.
|
* Please note that curly braces are required.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetClsid(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetClsid(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program name for a Schema (optional)
|
* @brief Set the program name for a Schema (optional)
|
||||||
@@ -239,7 +239,7 @@ bool WFSchemaSetClsid(Token in_schema, CStyleString in_value);
|
|||||||
* @param[in] in_value Null-terminated UTF-8 string containing the name, or NULL to clear
|
* @param[in] in_value Null-terminated UTF-8 string containing the name, or NULL to clear
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetName(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetName(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program icon for a Schema (optional)
|
* @brief Set the program icon for a Schema (optional)
|
||||||
@@ -248,7 +248,7 @@ bool WFSchemaSetName(Token in_schema, CStyleString in_value);
|
|||||||
* @param[in] in_value Null-terminated UTF-8 string containing the icon path, or NULL to clear
|
* @param[in] in_value Null-terminated UTF-8 string containing the icon path, or NULL to clear
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetIcon(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetIcon(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set the program behavior for a Schema (optional)
|
* @brief Set the program behavior for a Schema (optional)
|
||||||
@@ -257,7 +257,7 @@ bool WFSchemaSetIcon(Token in_schema, CStyleString in_value);
|
|||||||
* @param[in] in_value Null-terminated UTF-8 string containing the behavior command, or NULL to clear
|
* @param[in] in_value Null-terminated UTF-8 string containing the behavior command, or NULL to clear
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaSetBehavior(Token in_schema, CStyleString in_value);
|
bool WFSchemaSetBehavior(WFToken in_schema, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Add a string resource entry to a Schema
|
* @brief Add a string resource entry to a Schema
|
||||||
@@ -268,7 +268,7 @@ bool WFSchemaSetBehavior(Token in_schema, CStyleString in_value);
|
|||||||
* It can be a plain string or a reference string to resource.
|
* It can be a plain string or a reference string to resource.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaAddStr(Token in_schema, CStyleString in_name, CStyleString in_value);
|
bool WFSchemaAddStr(WFToken in_schema, WFCString in_name, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Add an icon registry entry to a Schema
|
* @brief Add an icon registry entry to a Schema
|
||||||
@@ -279,7 +279,7 @@ bool WFSchemaAddStr(Token in_schema, CStyleString in_name, CStyleString in_value
|
|||||||
* It can be a path to icon or a reference string to resource.
|
* It can be a path to icon or a reference string to resource.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaAddIcon(Token in_schema, CStyleString in_name, CStyleString in_value);
|
bool WFSchemaAddIcon(WFToken in_schema, WFCString in_name, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Add a behavior registry entry to a Schema
|
* @brief Add a behavior registry entry to a Schema
|
||||||
@@ -290,7 +290,7 @@ bool WFSchemaAddIcon(Token in_schema, CStyleString in_name, CStyleString in_valu
|
|||||||
* It should be a valid command line string which use \c %1, \c %2, etc. to represent parameters.
|
* It should be a valid command line string which use \c %1, \c %2, etc. to represent parameters.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaAddBehavior(Token in_schema, CStyleString in_name, CStyleString in_value);
|
bool WFSchemaAddBehavior(WFToken in_schema, WFCString in_name, WFCString in_value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Add a file extension to a Schema
|
* @brief Add a file extension to a Schema
|
||||||
@@ -305,11 +305,11 @@ bool WFSchemaAddBehavior(Token in_schema, CStyleString in_name, CStyleString in_
|
|||||||
* This name should be registered by calling WFSchemaAddBehavior().
|
* This name should be registered by calling WFSchemaAddBehavior().
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSchemaAddExt(Token in_schema,
|
bool WFSchemaAddExt(WFToken in_schema,
|
||||||
CStyleString in_ext,
|
WFCString in_ext,
|
||||||
CStyleString in_ext_name,
|
WFCString in_ext_name,
|
||||||
CStyleString in_ext_icon,
|
WFCString in_ext_icon,
|
||||||
CStyleString in_ext_behavior);
|
WFCString in_ext_behavior);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Create a Program object from a Schema
|
* @brief Create a Program object from a Schema
|
||||||
@@ -327,7 +327,7 @@ bool WFSchemaAddExt(Token in_schema,
|
|||||||
* And it should be freed by calling WFProgramDestroy() when it is no longer needed.
|
* And it should be freed by calling WFProgramDestroy() when it is no longer needed.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramCreate(Token in_schema, Token *out_program);
|
bool WFProgramCreate(WFToken in_schema, WFToken *out_program);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Destroy a Program object
|
* @brief Destroy a Program object
|
||||||
@@ -337,7 +337,7 @@ bool WFProgramCreate(Token in_schema, Token *out_program);
|
|||||||
* @param[in] in_program Program token to destroy
|
* @param[in] in_program Program token to destroy
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramDestroy(Token in_program);
|
bool WFProgramDestroy(WFToken in_program);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Resolve the provided program name of this Program
|
* @brief Resolve the provided program name of this Program
|
||||||
@@ -352,7 +352,7 @@ bool WFProgramDestroy(Token in_program);
|
|||||||
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramResolveName(Token in_program, CStyleString *out_name);
|
bool WFProgramResolveName(WFToken in_program, WFCString *out_name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Resolve the Program icon resource
|
* @brief Resolve the Program icon resource
|
||||||
@@ -367,7 +367,7 @@ bool WFProgramResolveName(Token in_program, CStyleString *out_name);
|
|||||||
* And it should be freed by calling WFIconRcDestroy() when it is no longer needed.
|
* And it should be freed by calling WFIconRcDestroy() when it is no longer needed.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramResolveIcon(Token in_program, Token *out_icon_rc);
|
bool WFProgramResolveIcon(WFToken in_program, WFToken *out_icon_rc);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the number of file extensions in the Program
|
* @brief Get the number of file extensions in the Program
|
||||||
@@ -376,17 +376,17 @@ bool WFProgramResolveIcon(Token in_program, Token *out_icon_rc);
|
|||||||
* @param[out] out_len Pointer to receive the number of extensions
|
* @param[out] out_len Pointer to receive the number of extensions
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramExtsLen(Token in_program, size_t *out_len);
|
bool WFProgramExtsLen(WFToken in_program, size_t *out_len);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Find a file extension by its body (extension string)
|
* @brief Find a file extension by its body (extension string)
|
||||||
*
|
*
|
||||||
* @param[in] in_program Program token
|
* @param[in] in_program Program token
|
||||||
* @param[in] in_body Null-terminated UTF-8 string containing the file extension name (without leading dot) to find.
|
* @param[in] in_body Null-terminated UTF-8 string containing the file extension name (without leading dot) to find.
|
||||||
* @param[out] out_index Pointer to receive the file extension index, or INVALID_INDEX if not found.
|
* @param[out] out_index Pointer to receive the file extension index, or WF_INVALID_INDEX if not found.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramFindExt(Token in_program, CStyleString in_body, size_t *out_index);
|
bool WFProgramFindExt(WFToken in_program, WFCString in_body, size_t *out_index);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Resolve this program provided extension's details by index
|
* @brief Resolve this program provided extension's details by index
|
||||||
@@ -398,7 +398,7 @@ bool WFProgramFindExt(Token in_program, CStyleString in_body, size_t *out_index)
|
|||||||
* And it should be freed by calling WFSelfExtStatusDestroy() when it is no longer needed.
|
* And it should be freed by calling WFSelfExtStatusDestroy() when it is no longer needed.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramResolveExt(Token in_program, size_t in_index, Token *out_self_ext_status);
|
bool WFProgramResolveExt(WFToken in_program, size_t in_index, WFToken *out_self_ext_status);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Register the Program in the specified scope
|
* @brief Register the Program in the specified scope
|
||||||
@@ -407,7 +407,7 @@ bool WFProgramResolveExt(Token in_program, size_t in_index, Token *out_self_ext_
|
|||||||
* @param[in] in_scope Registration scope
|
* @param[in] in_scope Registration scope
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramRegister(Token in_program, Scope in_scope);
|
bool WFProgramRegister(WFToken in_program, WFScope in_scope);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Unregister the Program from the specified scope
|
* @brief Unregister the Program from the specified scope
|
||||||
@@ -416,7 +416,7 @@ bool WFProgramRegister(Token in_program, Scope in_scope);
|
|||||||
* @param[in] in_scope Registration scope
|
* @param[in] in_scope Registration scope
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramUnregister(Token in_program, Scope in_scope);
|
bool WFProgramUnregister(WFToken in_program, WFScope in_scope);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Check if the Program is registered in the specified scope
|
* @brief Check if the Program is registered in the specified scope
|
||||||
@@ -427,7 +427,7 @@ bool WFProgramUnregister(Token in_program, Scope in_scope);
|
|||||||
* True if the Program is registered in the specified scope, false otherwise.
|
* True if the Program is registered in the specified scope, false otherwise.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramIsRegistered(Token in_program, Scope in_scope, bool *out_is_registered);
|
bool WFProgramIsRegistered(WFToken in_program, WFScope in_scope, bool *out_is_registered);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Link a file extension in the specified scope
|
* @brief Link a file extension in the specified scope
|
||||||
@@ -437,7 +437,7 @@ bool WFProgramIsRegistered(Token in_program, Scope in_scope, bool *out_is_regist
|
|||||||
* @param[in] in_index Index of the extension to link
|
* @param[in] in_index Index of the extension to link
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramLinkExt(Token in_program, Scope in_scope, size_t in_index);
|
bool WFProgramLinkExt(WFToken in_program, WFScope in_scope, size_t in_index);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Unlink a file extension in the specified scope
|
* @brief Unlink a file extension in the specified scope
|
||||||
@@ -447,7 +447,7 @@ bool WFProgramLinkExt(Token in_program, Scope in_scope, size_t in_index);
|
|||||||
* @param[in] in_index Index of the extension to unlink
|
* @param[in] in_index Index of the extension to unlink
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramUnlinkExt(Token in_program, Scope in_scope, size_t in_index);
|
bool WFProgramUnlinkExt(WFToken in_program, WFScope in_scope, size_t in_index);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Query the status of a file extension
|
* @brief Query the status of a file extension
|
||||||
@@ -461,7 +461,7 @@ bool WFProgramUnlinkExt(Token in_program, Scope in_scope, size_t in_index);
|
|||||||
* And it should be freed by calling WFExtStatusDestroy() when it is no longer needed.
|
* And it should be freed by calling WFExtStatusDestroy() when it is no longer needed.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFProgramQueryExt(Token in_program, View in_view, size_t in_index, Token *out_ext_status);
|
bool WFProgramQueryExt(WFToken in_program, WFView in_view, size_t in_index, WFToken *out_ext_status);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Destroy an extension status object
|
* @brief Destroy an extension status object
|
||||||
@@ -469,7 +469,7 @@ bool WFProgramQueryExt(Token in_program, View in_view, size_t in_index, Token *o
|
|||||||
* @param[in] in_ext_status Extension status token to destroy
|
* @param[in] in_ext_status Extension status token to destroy
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFExtStatusDestroy(Token in_ext_status);
|
bool WFExtStatusDestroy(WFToken in_ext_status);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the display name from an extension status object
|
* @brief Get the display name from an extension status object
|
||||||
@@ -484,7 +484,7 @@ bool WFExtStatusDestroy(Token in_ext_status);
|
|||||||
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFExtStatusGetName(Token in_ext_status, CStyleString *out_name);
|
bool WFExtStatusGetName(WFToken in_ext_status, WFCString *out_name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the icon from an extension status object
|
* @brief Get the icon from an extension status object
|
||||||
@@ -498,7 +498,7 @@ bool WFExtStatusGetName(Token in_ext_status, CStyleString *out_name);
|
|||||||
* Please make a copy immediately if you need to use it longer.
|
* Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFExtStatusGetIcon(Token in_ext_status, HICON *out_icon);
|
bool WFExtStatusGetIcon(WFToken in_ext_status, WFHICON *out_icon);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Destroy a self extension status object
|
* @brief Destroy a self extension status object
|
||||||
@@ -506,7 +506,7 @@ bool WFExtStatusGetIcon(Token in_ext_status, HICON *out_icon);
|
|||||||
* @param[in] in_self_ext_status Self extension status token to destroy
|
* @param[in] in_self_ext_status Self extension status token to destroy
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSelfExtStatusDestroy(Token in_self_ext_status);
|
bool WFSelfExtStatusDestroy(WFToken in_self_ext_status);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the display name from a self extension status object
|
* @brief Get the display name from a self extension status object
|
||||||
@@ -520,7 +520,7 @@ bool WFSelfExtStatusDestroy(Token in_self_ext_status);
|
|||||||
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSelfExtStatusGetName(Token in_self_ext_status, CStyleString *out_name);
|
bool WFSelfExtStatusGetName(WFToken in_self_ext_status, WFCString *out_name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the icon from a self extension status object
|
* @brief Get the icon from a self extension status object
|
||||||
@@ -534,7 +534,7 @@ bool WFSelfExtStatusGetName(Token in_self_ext_status, CStyleString *out_name);
|
|||||||
* Please make a copy immediately if you need to use it longer.
|
* Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSelfExtStatusGetIcon(Token in_self_ext_status, HICON *out_icon);
|
bool WFSelfExtStatusGetIcon(WFToken in_self_ext_status, WFHICON *out_icon);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the extension string (without leading dot) from a self extension status object
|
* @brief Get the extension string (without leading dot) from a self extension status object
|
||||||
@@ -545,7 +545,7 @@ bool WFSelfExtStatusGetIcon(Token in_self_ext_status, HICON *out_icon);
|
|||||||
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSelfExtStatusGetExt(Token in_self_ext_status, CStyleString *out_inner);
|
bool WFSelfExtStatusGetExt(WFToken in_self_ext_status, WFCString *out_inner);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the dotted extension string (with leading dot) from a self extension status object
|
* @brief Get the dotted extension string (with leading dot) from a self extension status object
|
||||||
@@ -556,7 +556,7 @@ bool WFSelfExtStatusGetExt(Token in_self_ext_status, CStyleString *out_inner);
|
|||||||
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
* This string will be freed at the next API call. Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFSelfExtStatusGetDottedExt(Token in_self_ext_status, CStyleString *out_inner);
|
bool WFSelfExtStatusGetDottedExt(WFToken in_self_ext_status, WFCString *out_inner);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Destroy an icon resource object
|
* @brief Destroy an icon resource object
|
||||||
@@ -564,19 +564,19 @@ bool WFSelfExtStatusGetDottedExt(Token in_self_ext_status, CStyleString *out_inn
|
|||||||
* @param[in] in_icon_rc Icon resource token to destroy
|
* @param[in] in_icon_rc Icon resource token to destroy
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFIconRcDestroy(Token in_icon_rc);
|
bool WFIconRcDestroy(WFToken in_icon_rc);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get the icon handle from an icon resource object
|
* @brief Get the icon handle from an icon resource object
|
||||||
*
|
*
|
||||||
* @param[in] in_icon_rc Icon resource token
|
* @param[in] in_icon_rc Icon resource token
|
||||||
* @param[out] out_icon Pointer to receive the icon handle.
|
* @param[out] out_icon Pointer to receive the icon handle.
|
||||||
* There is no possibility that this value is INVALID_HICON.
|
* There is no possibility that this value is WF_INVALID_HICON.
|
||||||
* This icon handle will be freed once this icon resource object is destroyed.
|
* This icon handle will be freed once this icon resource object is destroyed.
|
||||||
* Please make a copy immediately if you need to use it longer.
|
* Please make a copy immediately if you need to use it longer.
|
||||||
* @return true on success, false on failure
|
* @return true on success, false on failure
|
||||||
*/
|
*/
|
||||||
bool WFIconRcGetIcon(Token in_icon_rc, HICON *out_icon);
|
bool WFIconRcGetIcon(WFToken in_icon_rc, WFHICON *out_icon);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
|||||||
@@ -9,11 +9,9 @@
|
|||||||
//! The only thing that outer programs should note is that this string is volatile,
|
//! The only thing that outer programs should note is that this string is volatile,
|
||||||
//! once they get it, they must dupliate it immediately before any futher calling to this dynamic library.
|
//! once they get it, they must dupliate it immediately before any futher calling to this dynamic library.
|
||||||
use std::cell::RefCell;
|
use std::cell::RefCell;
|
||||||
use std::ffi::{CStr, CString, c_char};
|
use std::ffi::{CStr, CString};
|
||||||
use thiserror::Error as TeError;
|
use thiserror::Error as TeError;
|
||||||
|
use crate::ffi_types::CStyleString;
|
||||||
/// The type representing the raw pointer to immutable C-style NUL-terminated string.
|
|
||||||
pub type CStyleString = *const c_char;
|
|
||||||
|
|
||||||
// region: Error
|
// region: Error
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,15 @@
|
|||||||
//! The module including all FFI types used by this crate, except string type.
|
//! The module including all FFI types used by this crate, except string type.
|
||||||
//! For string type, see also [crate::cstr_ffi].
|
//! For string type, see also [crate::cstr_ffi].
|
||||||
|
|
||||||
use std::ffi::c_void;
|
use std::ffi::{c_void, c_char};
|
||||||
use num_enum::TryFromPrimitive;
|
use num_enum::TryFromPrimitive;
|
||||||
|
|
||||||
// region: File Extension Index
|
// region: Misc Types and Constants
|
||||||
|
|
||||||
|
/// The type representing the raw pointer to immutable C-style NUL-terminated string.
|
||||||
|
pub type CStyleString = *const c_char;
|
||||||
|
|
||||||
|
/// The invalid value of index.
|
||||||
pub const INVALID_INDEX: usize = usize::MAX;
|
pub const INVALID_INDEX: usize = usize::MAX;
|
||||||
|
|
||||||
// endregion
|
// endregion
|
||||||
@@ -23,7 +27,7 @@ pub type HICON = *mut c_void;
|
|||||||
|
|
||||||
/// The invalid value of Win32 HICON handle.
|
/// The invalid value of Win32 HICON handle.
|
||||||
///
|
///
|
||||||
/// The same reason like [HICON] to re-define it in there.
|
/// The same reason like [WFHICON] to re-define it in there.
|
||||||
pub const INVALID_HICON: HICON = std::ptr::null_mut();
|
pub const INVALID_HICON: HICON = std::ptr::null_mut();
|
||||||
|
|
||||||
// endregion
|
// endregion
|
||||||
|
|||||||
@@ -202,9 +202,11 @@ static ICON_RC_POOL: LazyLock<RwLock<ObjectPool<wfassoc::win32::concept::IconRc>
|
|||||||
|
|
||||||
// region: Exposed Types
|
// region: Exposed Types
|
||||||
|
|
||||||
pub use cstr_ffi::CStyleString;
|
pub use ffi_types::{
|
||||||
pub use ffi_types::{HICON, Scope, View};
|
CStyleString as WFCString, HICON as WFHICON, Scope as WFScope, View as WFView,
|
||||||
pub use object_pool::Token;
|
};
|
||||||
|
pub use ffi_types::{INVALID_HICON as WF_INVALID_HICON, INVALID_INDEX as WF_INVALID_INDEX};
|
||||||
|
pub use object_pool::Token as WFToken;
|
||||||
|
|
||||||
// endregion
|
// endregion
|
||||||
|
|
||||||
@@ -244,7 +246,7 @@ pub extern "C" fn WFShutdown() -> bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFGetLastError() -> CStyleString {
|
pub extern "C" fn WFGetLastError() -> WFCString {
|
||||||
last_error::get_last_error()
|
last_error::get_last_error()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -254,7 +256,7 @@ pub extern "C" fn WFHasPrivilege() -> bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFInvalidToken() -> Token {
|
pub extern "C" fn WFInvalidToken() -> WFToken {
|
||||||
object_pool::invalid_token()
|
object_pool::invalid_token()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -263,16 +265,16 @@ pub extern "C" fn WFInvalidToken() -> Token {
|
|||||||
// region: Schema
|
// region: Schema
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaCreate(out_schema: out_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFSchemaCreate(out_schema: out_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|| -> (out_schema: Token) {
|
cffi_wrapper!(|| -> (out_schema: WFToken) {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
Ok(pool.allocate(Schema::new())?)
|
Ok(pool.allocate(Schema::new())?)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaDestroy(in_schema: in_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFSchemaDestroy(in_schema: in_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token| {
|
cffi_wrapper!(|in_schema: WFToken| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
Ok(pool.free(in_schema)?)
|
Ok(pool.free(in_schema)?)
|
||||||
})
|
})
|
||||||
@@ -280,10 +282,10 @@ pub extern "C" fn WFSchemaDestroy(in_schema: in_param_ty!(Token)) -> bool {
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetIdentifier(
|
pub extern "C" fn WFSchemaSetIdentifier(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.set_identifier(cstr_ffi::parse_ffi_string(in_value)?);
|
schema.set_identifier(cstr_ffi::parse_ffi_string(in_value)?);
|
||||||
@@ -293,10 +295,10 @@ pub extern "C" fn WFSchemaSetIdentifier(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetPath(
|
pub extern "C" fn WFSchemaSetPath(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.set_path(cstr_ffi::parse_ffi_string(in_value)?);
|
schema.set_path(cstr_ffi::parse_ffi_string(in_value)?);
|
||||||
@@ -306,10 +308,10 @@ pub extern "C" fn WFSchemaSetPath(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetClsid(
|
pub extern "C" fn WFSchemaSetClsid(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.set_clsid(cstr_ffi::parse_ffi_string(in_value)?);
|
schema.set_clsid(cstr_ffi::parse_ffi_string(in_value)?);
|
||||||
@@ -319,10 +321,10 @@ pub extern "C" fn WFSchemaSetClsid(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetName(
|
pub extern "C" fn WFSchemaSetName(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
|
|
||||||
@@ -338,10 +340,10 @@ pub extern "C" fn WFSchemaSetName(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetIcon(
|
pub extern "C" fn WFSchemaSetIcon(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
|
|
||||||
@@ -357,10 +359,10 @@ pub extern "C" fn WFSchemaSetIcon(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaSetBehavior(
|
pub extern "C" fn WFSchemaSetBehavior(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token, in_value: CStyleString| {
|
cffi_wrapper!(|in_schema: WFToken, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
|
|
||||||
@@ -376,12 +378,12 @@ pub extern "C" fn WFSchemaSetBehavior(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaAddStr(
|
pub extern "C" fn WFSchemaAddStr(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_name: in_param_ty!(CStyleString),
|
in_name: in_param_ty!(WFCString),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(
|
cffi_wrapper!(
|
||||||
|in_schema: Token, in_name: CStyleString, in_value: CStyleString| {
|
|in_schema: WFToken, in_name: WFCString, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.add_str(
|
schema.add_str(
|
||||||
@@ -395,12 +397,12 @@ pub extern "C" fn WFSchemaAddStr(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaAddIcon(
|
pub extern "C" fn WFSchemaAddIcon(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_name: in_param_ty!(CStyleString),
|
in_name: in_param_ty!(WFCString),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(
|
cffi_wrapper!(
|
||||||
|in_schema: Token, in_name: CStyleString, in_value: CStyleString| {
|
|in_schema: WFToken, in_name: WFCString, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.add_icon(
|
schema.add_icon(
|
||||||
@@ -414,12 +416,12 @@ pub extern "C" fn WFSchemaAddIcon(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaAddBehavior(
|
pub extern "C" fn WFSchemaAddBehavior(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_name: in_param_ty!(CStyleString),
|
in_name: in_param_ty!(WFCString),
|
||||||
in_value: in_param_ty!(CStyleString),
|
in_value: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(
|
cffi_wrapper!(
|
||||||
|in_schema: Token, in_name: CStyleString, in_value: CStyleString| {
|
|in_schema: WFToken, in_name: WFCString, in_value: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.add_behavior(
|
schema.add_behavior(
|
||||||
@@ -433,17 +435,17 @@ pub extern "C" fn WFSchemaAddBehavior(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSchemaAddExt(
|
pub extern "C" fn WFSchemaAddExt(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
in_ext: in_param_ty!(CStyleString),
|
in_ext: in_param_ty!(WFCString),
|
||||||
in_ext_name: in_param_ty!(CStyleString),
|
in_ext_name: in_param_ty!(WFCString),
|
||||||
in_ext_icon: in_param_ty!(CStyleString),
|
in_ext_icon: in_param_ty!(WFCString),
|
||||||
in_ext_behavior: in_param_ty!(CStyleString),
|
in_ext_behavior: in_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token,
|
cffi_wrapper!(|in_schema: WFToken,
|
||||||
in_ext: CStyleString,
|
in_ext: WFCString,
|
||||||
in_ext_name: CStyleString,
|
in_ext_name: WFCString,
|
||||||
in_ext_icon: CStyleString,
|
in_ext_icon: WFCString,
|
||||||
in_ext_behavior: CStyleString| {
|
in_ext_behavior: WFCString| {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.get_mut(in_schema)?;
|
let schema = pool.get_mut(in_schema)?;
|
||||||
schema.add_ext(
|
schema.add_ext(
|
||||||
@@ -462,10 +464,10 @@ pub extern "C" fn WFSchemaAddExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramCreate(
|
pub extern "C" fn WFProgramCreate(
|
||||||
in_schema: in_param_ty!(Token),
|
in_schema: in_param_ty!(WFToken),
|
||||||
out_program: out_param_ty!(Token),
|
out_program: out_param_ty!(WFToken),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_schema: Token| -> (out_program: Token) {
|
cffi_wrapper!(|in_schema: WFToken| -> (out_program: WFToken) {
|
||||||
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
let mut pool = pull_writer!(SCHEMA_POOL)?;
|
||||||
let schema = pool.pop(in_schema)?;
|
let schema = pool.pop(in_schema)?;
|
||||||
|
|
||||||
@@ -476,8 +478,8 @@ pub extern "C" fn WFProgramCreate(
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramDestroy(in_program: in_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFProgramDestroy(in_program: in_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token| {
|
cffi_wrapper!(|in_program: WFToken| {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
Ok(pool.free(in_program)?)
|
Ok(pool.free(in_program)?)
|
||||||
})
|
})
|
||||||
@@ -485,10 +487,10 @@ pub extern "C" fn WFProgramDestroy(in_program: in_param_ty!(Token)) -> bool {
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramResolveName(
|
pub extern "C" fn WFProgramResolveName(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
out_name: out_param_ty!(CStyleString),
|
out_name: out_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token| -> (out_name: CStyleString) {
|
cffi_wrapper!(|in_program: WFToken| -> (out_name: WFCString) {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
|
|
||||||
@@ -500,10 +502,10 @@ pub extern "C" fn WFProgramResolveName(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramResolveIcon(
|
pub extern "C" fn WFProgramResolveIcon(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
out_icon_rc: out_param_ty!(Token),
|
out_icon_rc: out_param_ty!(WFToken),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token| -> (out_icon_rc: Token) {
|
cffi_wrapper!(|in_program: WFToken| -> (out_icon_rc: WFToken) {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
|
|
||||||
@@ -515,10 +517,10 @@ pub extern "C" fn WFProgramResolveIcon(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramExtsLen(
|
pub extern "C" fn WFProgramExtsLen(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
out_len: out_param_ty!(usize),
|
out_len: out_param_ty!(usize),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token| -> (out_len: usize) {
|
cffi_wrapper!(|in_program: WFToken| -> (out_len: usize) {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
Ok(program.exts_len())
|
Ok(program.exts_len())
|
||||||
@@ -527,18 +529,18 @@ pub extern "C" fn WFProgramExtsLen(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramFindExt(
|
pub extern "C" fn WFProgramFindExt(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_body: in_param_ty!(CStyleString),
|
in_body: in_param_ty!(WFCString),
|
||||||
out_index: out_param_ty!(usize),
|
out_index: out_param_ty!(usize),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_body: CStyleString| -> (out_index: usize) {
|
cffi_wrapper!(|in_program: WFToken, in_body: WFCString| -> (out_index: usize) {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
|
|
||||||
let body = cstr_ffi::parse_ffi_string(in_body)?;
|
let body = cstr_ffi::parse_ffi_string(in_body)?;
|
||||||
let index = match program.find_ext(body) {
|
let index = match program.find_ext(body) {
|
||||||
Some(index) => index,
|
Some(index) => index,
|
||||||
None => ffi_types::INVALID_INDEX,
|
None => WF_INVALID_INDEX,
|
||||||
};
|
};
|
||||||
Ok(index)
|
Ok(index)
|
||||||
})
|
})
|
||||||
@@ -546,11 +548,11 @@ pub extern "C" fn WFProgramFindExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramResolveExt(
|
pub extern "C" fn WFProgramResolveExt(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_index: in_param_ty!(usize),
|
in_index: in_param_ty!(usize),
|
||||||
out_self_ext_status: out_param_ty!(Token),
|
out_self_ext_status: out_param_ty!(WFToken),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_index: usize| -> (out_self_ext_status: Token) {
|
cffi_wrapper!(|in_program: WFToken, in_index: usize| -> (out_self_ext_status: WFToken) {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
|
|
||||||
@@ -563,13 +565,13 @@ pub extern "C" fn WFProgramResolveExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramRegister(
|
pub extern "C" fn WFProgramRegister(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_scope: in_param_ty!(u32),
|
in_scope: in_param_ty!(u32),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_scope: u32| {
|
cffi_wrapper!(|in_program: WFToken, in_scope: u32| {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
let scope = resolve_enum!(Scope, in_scope)?;
|
let scope = resolve_enum!(WFScope, in_scope)?;
|
||||||
program.register(scope.into())?;
|
program.register(scope.into())?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@@ -577,13 +579,13 @@ pub extern "C" fn WFProgramRegister(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramUnregister(
|
pub extern "C" fn WFProgramUnregister(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_scope: in_param_ty!(u32),
|
in_scope: in_param_ty!(u32),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_scope: u32| {
|
cffi_wrapper!(|in_program: WFToken, in_scope: u32| {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
let scope = resolve_enum!(Scope, in_scope)?;
|
let scope = resolve_enum!(WFScope, in_scope)?;
|
||||||
program.unregister(scope.into())?;
|
program.unregister(scope.into())?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@@ -591,28 +593,28 @@ pub extern "C" fn WFProgramUnregister(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramIsRegistered(
|
pub extern "C" fn WFProgramIsRegistered(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_scope: in_param_ty!(u32),
|
in_scope: in_param_ty!(u32),
|
||||||
out_is_registered: out_param_ty!(bool),
|
out_is_registered: out_param_ty!(bool),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_scope: u32| -> (out_is_registered: bool) {
|
cffi_wrapper!(|in_program: WFToken, in_scope: u32| -> (out_is_registered: bool) {
|
||||||
let pool = pull_reader!(PROGRAM_POOL)?;
|
let pool = pull_reader!(PROGRAM_POOL)?;
|
||||||
let program = pool.get(in_program)?;
|
let program = pool.get(in_program)?;
|
||||||
let scope = resolve_enum!(Scope, in_scope)?;
|
let scope = resolve_enum!(WFScope, in_scope)?;
|
||||||
Ok(program.is_registered(scope.into())?)
|
Ok(program.is_registered(scope.into())?)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramLinkExt(
|
pub extern "C" fn WFProgramLinkExt(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_scope: in_param_ty!(u32),
|
in_scope: in_param_ty!(u32),
|
||||||
in_index: in_param_ty!(usize),
|
in_index: in_param_ty!(usize),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_scope: u32, in_index: usize| {
|
cffi_wrapper!(|in_program: WFToken, in_scope: u32, in_index: usize| {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
let scope = resolve_enum!(Scope, in_scope)?;
|
let scope = resolve_enum!(WFScope, in_scope)?;
|
||||||
program.link_ext(scope.into(), in_index)?;
|
program.link_ext(scope.into(), in_index)?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@@ -620,14 +622,14 @@ pub extern "C" fn WFProgramLinkExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramUnlinkExt(
|
pub extern "C" fn WFProgramUnlinkExt(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_scope: in_param_ty!(u32),
|
in_scope: in_param_ty!(u32),
|
||||||
in_index: in_param_ty!(usize),
|
in_index: in_param_ty!(usize),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_scope: u32, in_index: usize| {
|
cffi_wrapper!(|in_program: WFToken, in_scope: u32, in_index: usize| {
|
||||||
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
let mut pool = pull_writer!(PROGRAM_POOL)?;
|
||||||
let program = pool.get_mut(in_program)?;
|
let program = pool.get_mut(in_program)?;
|
||||||
let scope = resolve_enum!(Scope, in_scope)?;
|
let scope = resolve_enum!(WFScope, in_scope)?;
|
||||||
program.unlink_ext(scope.into(), in_index)?;
|
program.unlink_ext(scope.into(), in_index)?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@@ -635,15 +637,15 @@ pub extern "C" fn WFProgramUnlinkExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFProgramQueryExt(
|
pub extern "C" fn WFProgramQueryExt(
|
||||||
in_program: in_param_ty!(Token),
|
in_program: in_param_ty!(WFToken),
|
||||||
in_view: in_param_ty!(u32),
|
in_view: in_param_ty!(u32),
|
||||||
in_index: in_param_ty!(usize),
|
in_index: in_param_ty!(usize),
|
||||||
out_ext_status: out_param_ty!(Token),
|
out_ext_status: out_param_ty!(WFToken),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_program: Token, in_view: u32, in_index: usize| -> (out_ext_status: Token) {
|
cffi_wrapper!(|in_program: WFToken, in_view: u32, in_index: usize| -> (out_ext_status: WFToken) {
|
||||||
let pool = pull_reader!(PROGRAM_POOL)?;
|
let pool = pull_reader!(PROGRAM_POOL)?;
|
||||||
let program = pool.get(in_program)?;
|
let program = pool.get(in_program)?;
|
||||||
let view = resolve_enum!(View, in_view)?;
|
let view = resolve_enum!(WFView, in_view)?;
|
||||||
|
|
||||||
let ext_status = program.query_ext(view.into(), in_index)?;
|
let ext_status = program.query_ext(view.into(), in_index)?;
|
||||||
let token = match ext_status {
|
let token = match ext_status {
|
||||||
@@ -662,8 +664,8 @@ pub extern "C" fn WFProgramQueryExt(
|
|||||||
// region: Extension Status
|
// region: Extension Status
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFExtStatusDestroy(in_ext_status: in_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFExtStatusDestroy(in_ext_status: in_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|in_ext_status: Token| {
|
cffi_wrapper!(|in_ext_status: WFToken| {
|
||||||
let mut pool = pull_writer!(EXT_STATUS_POOL)?;
|
let mut pool = pull_writer!(EXT_STATUS_POOL)?;
|
||||||
Ok(pool.free(in_ext_status)?)
|
Ok(pool.free(in_ext_status)?)
|
||||||
})
|
})
|
||||||
@@ -671,10 +673,10 @@ pub extern "C" fn WFExtStatusDestroy(in_ext_status: in_param_ty!(Token)) -> bool
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFExtStatusGetName(
|
pub extern "C" fn WFExtStatusGetName(
|
||||||
in_ext_status: in_param_ty!(Token),
|
in_ext_status: in_param_ty!(WFToken),
|
||||||
out_name: out_param_ty!(CStyleString),
|
out_name: out_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_ext_status: Token| -> (out_name: CStyleString) {
|
cffi_wrapper!(|in_ext_status: WFToken| -> (out_name: WFCString) {
|
||||||
let pool = pull_reader!(EXT_STATUS_POOL)?;
|
let pool = pull_reader!(EXT_STATUS_POOL)?;
|
||||||
let ext_status = pool.get(in_ext_status)?;
|
let ext_status = pool.get(in_ext_status)?;
|
||||||
|
|
||||||
@@ -685,10 +687,10 @@ pub extern "C" fn WFExtStatusGetName(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFExtStatusGetIcon(
|
pub extern "C" fn WFExtStatusGetIcon(
|
||||||
in_ext_status: in_param_ty!(Token),
|
in_ext_status: in_param_ty!(WFToken),
|
||||||
out_icon: out_param_ty!(HICON),
|
out_icon: out_param_ty!(WFHICON),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_ext_status: Token| -> (out_icon: HICON) {
|
cffi_wrapper!(|in_ext_status: WFToken| -> (out_icon: WFHICON) {
|
||||||
let pool = pull_reader!(EXT_STATUS_POOL)?;
|
let pool = pull_reader!(EXT_STATUS_POOL)?;
|
||||||
let ext_status = pool.get(in_ext_status)?;
|
let ext_status = pool.get(in_ext_status)?;
|
||||||
|
|
||||||
@@ -702,8 +704,8 @@ pub extern "C" fn WFExtStatusGetIcon(
|
|||||||
// region: Self Extension Status
|
// region: Self Extension Status
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSelfExtStatusDestroy(in_self_ext_status: in_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFSelfExtStatusDestroy(in_self_ext_status: in_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|in_self_ext_status: Token| {
|
cffi_wrapper!(|in_self_ext_status: WFToken| {
|
||||||
let mut pool = pull_writer!(SELF_EXT_STATUS_POOL)?;
|
let mut pool = pull_writer!(SELF_EXT_STATUS_POOL)?;
|
||||||
Ok(pool.free(in_self_ext_status)?)
|
Ok(pool.free(in_self_ext_status)?)
|
||||||
})
|
})
|
||||||
@@ -711,10 +713,10 @@ pub extern "C" fn WFSelfExtStatusDestroy(in_self_ext_status: in_param_ty!(Token)
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSelfExtStatusGetName(
|
pub extern "C" fn WFSelfExtStatusGetName(
|
||||||
in_self_ext_status: in_param_ty!(Token),
|
in_self_ext_status: in_param_ty!(WFToken),
|
||||||
out_name: out_param_ty!(CStyleString),
|
out_name: out_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_self_ext_status: Token| -> (out_name: CStyleString) {
|
cffi_wrapper!(|in_self_ext_status: WFToken| -> (out_name: WFCString) {
|
||||||
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
||||||
let self_ext_status = pool.get(in_self_ext_status)?;
|
let self_ext_status = pool.get(in_self_ext_status)?;
|
||||||
|
|
||||||
@@ -725,10 +727,10 @@ pub extern "C" fn WFSelfExtStatusGetName(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSelfExtStatusGetIcon(
|
pub extern "C" fn WFSelfExtStatusGetIcon(
|
||||||
in_self_ext_status: in_param_ty!(Token),
|
in_self_ext_status: in_param_ty!(WFToken),
|
||||||
out_icon: out_param_ty!(HICON),
|
out_icon: out_param_ty!(WFHICON),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_self_ext_status: Token| -> (out_icon: HICON) {
|
cffi_wrapper!(|in_self_ext_status: WFToken| -> (out_icon: WFHICON) {
|
||||||
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
||||||
let self_ext_status = pool.get(in_self_ext_status)?;
|
let self_ext_status = pool.get(in_self_ext_status)?;
|
||||||
|
|
||||||
@@ -739,10 +741,10 @@ pub extern "C" fn WFSelfExtStatusGetIcon(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSelfExtStatusGetExt(
|
pub extern "C" fn WFSelfExtStatusGetExt(
|
||||||
in_self_ext_status: in_param_ty!(Token),
|
in_self_ext_status: in_param_ty!(WFToken),
|
||||||
out_inner: out_param_ty!(CStyleString),
|
out_inner: out_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_self_ext_status: Token| -> (out_inner: CStyleString) {
|
cffi_wrapper!(|in_self_ext_status: WFToken| -> (out_inner: WFCString) {
|
||||||
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
||||||
let self_ext_status = pool.get(in_self_ext_status)?;
|
let self_ext_status = pool.get(in_self_ext_status)?;
|
||||||
|
|
||||||
@@ -753,10 +755,10 @@ pub extern "C" fn WFSelfExtStatusGetExt(
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFSelfExtStatusGetDottedExt(
|
pub extern "C" fn WFSelfExtStatusGetDottedExt(
|
||||||
in_self_ext_status: in_param_ty!(Token),
|
in_self_ext_status: in_param_ty!(WFToken),
|
||||||
out_inner: out_param_ty!(CStyleString),
|
out_inner: out_param_ty!(WFCString),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_self_ext_status: Token| -> (out_inner: CStyleString) {
|
cffi_wrapper!(|in_self_ext_status: WFToken| -> (out_inner: WFCString) {
|
||||||
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
let pool = pull_reader!(SELF_EXT_STATUS_POOL)?;
|
||||||
let self_ext_status = pool.get(in_self_ext_status)?;
|
let self_ext_status = pool.get(in_self_ext_status)?;
|
||||||
|
|
||||||
@@ -770,8 +772,8 @@ pub extern "C" fn WFSelfExtStatusGetDottedExt(
|
|||||||
// region: Icon Resource
|
// region: Icon Resource
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFIconRcDestroy(in_icon_rc: in_param_ty!(Token)) -> bool {
|
pub extern "C" fn WFIconRcDestroy(in_icon_rc: in_param_ty!(WFToken)) -> bool {
|
||||||
cffi_wrapper!(|in_icon_rc: Token| {
|
cffi_wrapper!(|in_icon_rc: WFToken| {
|
||||||
let mut pool = pull_writer!(ICON_RC_POOL)?;
|
let mut pool = pull_writer!(ICON_RC_POOL)?;
|
||||||
Ok(pool.free(in_icon_rc)?)
|
Ok(pool.free(in_icon_rc)?)
|
||||||
})
|
})
|
||||||
@@ -779,10 +781,10 @@ pub extern "C" fn WFIconRcDestroy(in_icon_rc: in_param_ty!(Token)) -> bool {
|
|||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub extern "C" fn WFIconRcGetIcon(
|
pub extern "C" fn WFIconRcGetIcon(
|
||||||
in_icon_rc: in_param_ty!(Token),
|
in_icon_rc: in_param_ty!(WFToken),
|
||||||
out_icon: out_param_ty!(HICON),
|
out_icon: out_param_ty!(WFHICON),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
cffi_wrapper!(|in_icon_rc: Token| -> (out_icon: HICON) {
|
cffi_wrapper!(|in_icon_rc: WFToken| -> (out_icon: WFHICON) {
|
||||||
let pool = pull_reader!(ICON_RC_POOL)?;
|
let pool = pull_reader!(ICON_RC_POOL)?;
|
||||||
let icon_rc = pool.get(in_icon_rc)?;
|
let icon_rc = pool.get(in_icon_rc)?;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user