aboutsummaryrefslogtreecommitdiff
path: root/addons/library.xbmc.addon
diff options
context:
space:
mode:
authorLars Op den Kamp <lars@opdenkamp.eu>2012-11-09 01:29:12 +0100
committerLars Op den Kamp <lars@opdenkamp.eu>2012-11-10 01:15:07 +0100
commit2c7ac24c76a72977b0e819fe8f3838be6d3e0ec0 (patch)
tree7391e363466dcf826baaf3c3ba415b92cc95919b /addons/library.xbmc.addon
parent42f6b3e6a4f9d2321afbc47209a88d1455a27820 (diff)
[pvr] added FreeString()
Diffstat (limited to 'addons/library.xbmc.addon')
-rw-r--r--addons/library.xbmc.addon/libXBMC_addon.h20
1 files changed, 17 insertions, 3 deletions
diff --git a/addons/library.xbmc.addon/libXBMC_addon.h b/addons/library.xbmc.addon/libXBMC_addon.h
index 42fcee2a4e..f805263c8d 100644
--- a/addons/library.xbmc.addon/libXBMC_addon.h
+++ b/addons/library.xbmc.addon/libXBMC_addon.h
@@ -166,6 +166,10 @@ namespace ADDON
dlsym(m_libXBMC_addon, "XBMC_get_localized_string");
if (XBMC_get_localized_string == NULL) { fprintf(stderr, "Unable to assign function %s\n", dlerror()); return false; }
+ XBMC_free_string = (void (*)(void* HANDLE, void* CB, char* str))
+ dlsym(m_libXBMC_addon, "XBMC_free_string");
+ if (XBMC_free_string == NULL) { fprintf(stderr, "Unable to assign function %s\n", dlerror()); return false; }
+
XBMC_get_dvd_menu_language = (char* (*)(void* HANDLE, void* CB))
dlsym(m_libXBMC_addon, "XBMC_get_dvd_menu_language");
if (XBMC_get_dvd_menu_language == NULL) { fprintf(stderr, "Unable to assign function %s\n", dlerror()); return false; }
@@ -294,7 +298,7 @@ namespace ADDON
/*!
* @brief Translate a string with an unknown encoding to UTF8.
* @param str The string to translate.
- * @return The string translated to UTF8. Must be freed when done.
+ * @return The string translated to UTF8. Must be freed by calling FreeString() when done.
*/
char* UnknownToUTF8(const char* str)
{
@@ -304,7 +308,7 @@ namespace ADDON
/*!
* @brief Get a localised message.
* @param dwCode The code of the message to get.
- * @return The message. Needs to be freed when done.
+ * @return The message. Must be freed by calling FreeString() when done.
*/
char* GetLocalizedString(int dwCode)
{
@@ -314,7 +318,7 @@ namespace ADDON
/*!
* @brief Get the DVD menu language.
- * @return The language. Needs to be freed when done.
+ * @return The language. Must be freed by calling FreeString() when done.
*/
char* GetDVDMenuLanguage()
{
@@ -322,6 +326,15 @@ namespace ADDON
}
/*!
+ * @brief Free the memory used by str
+ * @param str The string to free
+ */
+ void FreeString(char* str)
+ {
+ return XBMC_free_string(m_Handle, m_Callbacks, str);
+ }
+
+ /*!
* @brief Open the file with filename via XBMC's CFile. Needs to be closed by calling CloseFile() when done.
* @param strFileName The filename to open.
* @param flags The flags to pass. Documented in XBMC's File.h
@@ -531,6 +544,7 @@ namespace ADDON
char* (*XBMC_unknown_to_utf8)(void *HANDLE, void* CB, const char* str);
char* (*XBMC_get_localized_string)(void *HANDLE, void* CB, int dwCode);
char* (*XBMC_get_dvd_menu_language)(void *HANDLE, void* CB);
+ void (*XBMC_free_string)(void *HANDLE, void* CB, char* str);
void* (*XBMC_open_file)(void *HANDLE, void* CB, const char* strFileName, unsigned int flags);
void* (*XBMC_open_file_for_write)(void *HANDLE, void* CB, const char* strFileName, bool bOverWrite);
unsigned int (*XBMC_read_file)(void *HANDLE, void* CB, void* file, void* lpBuf, int64_t uiBufSize);