summaryrefslogtreecommitdiff
path: root/secureim/rtfconv.cpp
diff options
context:
space:
mode:
authorwatcherhd <watcherhd@e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb>2011-04-21 14:14:52 +0000
committerwatcherhd <watcherhd@e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb>2011-04-21 14:14:52 +0000
commitcb4a46e7fbe62d788e66ed6121c717a2d22a4d7c (patch)
tree30df260fdc5a1b5a7049c2f8cac8b7ef17513d6d /secureim/rtfconv.cpp
parent19b6f534d2e784a1e120bf52c4aa07004798f473 (diff)
svn.miranda.im is moving to a new home!
git-svn-id: http://miranda-plugins.googlecode.com/svn/trunk@7 e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb
Diffstat (limited to 'secureim/rtfconv.cpp')
-rw-r--r--secureim/rtfconv.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/secureim/rtfconv.cpp b/secureim/rtfconv.cpp
new file mode 100644
index 0000000..271e62a
--- /dev/null
+++ b/secureim/rtfconv.cpp
@@ -0,0 +1,46 @@
+#include "commonheaders.h"
+
+
+HINSTANCE hRtfconv = NULL;
+RTFCONVSTRING pRtfconvString = NULL;
+
+
+BOOL load_rtfconv () {
+
+ hRtfconv = LoadLibrary( "rtfconv.dll" ) ;
+ if ( hRtfconv == NULL ) {
+ hRtfconv = LoadLibrary( "plugins\\rtfconv.dll" ) ;
+ if ( hRtfconv == NULL )
+ return FALSE;
+ }
+
+ pRtfconvString = (RTFCONVSTRING) GetProcAddress( hRtfconv, "RtfconvString" ) ;
+ if ( pRtfconvString == NULL ) {
+ FreeLibrary( hRtfconv ) ;
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+void free_rtfconv () {
+
+ if ( hRtfconv )
+ FreeLibrary( hRtfconv ) ;
+ pRtfconvString = NULL;
+ hRtfconv = NULL;
+}
+
+
+void rtfconvA(LPCSTR rtf, LPWSTR plain) {
+
+ pRtfconvString( rtf, plain, 0, 1200, CONVMODE_USE_SYSTEM_TABLE, (strlen(rtf)+1)*sizeof(WCHAR) );
+}
+
+
+void rtfconvW(LPCWSTR rtf, LPWSTR plain) {
+
+ pRtfconvString( rtf, plain, 0, 1200, CONVMODE_USE_SYSTEM_TABLE, (wcslen(rtf)+1)*sizeof(WCHAR) );
+}
+
+// EOF