summaryrefslogtreecommitdiff
path: root/protocols/MRA/MraRTFMsg.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2012-09-11 19:28:53 +0000
committerGeorge Hazan <george.hazan@gmail.com>2012-09-11 19:28:53 +0000
commit274cffbbffa950ddf286092b52f03f76ec61a301 (patch)
tree5aeb062d27c79d1fbc15eaf033da943630bcbf84 /protocols/MRA/MraRTFMsg.cpp
parent482be69d327aef60a9a654b8cc6a5e6646d095de (diff)
slightly refactored MRA
git-svn-id: http://svn.miranda-ng.org/main/trunk@1564 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/MRA/MraRTFMsg.cpp')
-rw-r--r--protocols/MRA/MraRTFMsg.cpp482
1 files changed, 200 insertions, 282 deletions
diff --git a/protocols/MRA/MraRTFMsg.cpp b/protocols/MRA/MraRTFMsg.cpp
index e0c3a1d67f..02e3a371e4 100644
--- a/protocols/MRA/MraRTFMsg.cpp
+++ b/protocols/MRA/MraRTFMsg.cpp
@@ -2,339 +2,257 @@
#include "MraRTFMsg.h"
-
#define COLORTABLE_COUNT 8
#define RTF_COLORTBLCOLOURS "\\red255\\green0\\blue0;\\red0\\green255\\blue0;\\red0\\green0\\blue255;\\red255\\green0\\blue255;\\red255\\green255\\blue0;\\red0\\green255\\blue255;\\red0\\green0\\blue0;\\red255\\green255\\blue255;"
-static const LPSTR lpszColours[COLORTABLE_COUNT]=
+static const LPSTR lpszColours[COLORTABLE_COUNT] =
{
- "red",
- "green",
- "blue",
- "magenta",
- "yellow",
- "cyan",
- "black",
+ "red",
+ "green",
+ "blue",
+ "magenta",
+ "yellow",
+ "cyan",
+ "black",
"white"
};
-
-
#define CRLF "\r\n"
#define PAR "\\par "
-#define BB_COLOR_TAG "[color="
-#define SIMBOLS_COUNT 19
-static const LPSTR lpszSimbols[SIMBOLS_COUNT]=
+#define BB_COLOR_TAG "[color = "
+#define SYMBOLS_COUNT 19
+static const LPSTR lpszSimbols[SYMBOLS_COUNT] =
{
- "\r\n",
- "\\",
- "{",
- "}",
- "[b]",
- "[/b]",
- "[u]",
- "[/u]",
- "[i]",
- "[/i]",
- "[/color]",
- "[color=red]",
- "[color=green]",
- "[color=blue]",
- "[color=magenta]",
- "[color=yellow]",
- "[color=cyan]",
- "[color=black]",
- "[color=white]",
+ "\r\n",
+ "\\",
+ "{",
+ "}",
+ "[b]",
+ "[/b]",
+ "[u]",
+ "[/u]",
+ "[i]",
+ "[/i]",
+ "[/color]",
+ "[color = red]",
+ "[color = green]",
+ "[color = blue]",
+ "[color = magenta]",
+ "[color = yellow]",
+ "[color = cyan]",
+ "[color = black]",
+ "[color = white]",
};
-static const SIZE_T dwcSimbolsCount[SIMBOLS_COUNT]=
+static const size_t dwcSimbolsCount[SYMBOLS_COUNT] =
{
- 2,
- 1,
- 1,
- 1,
- 3,
- 4,
- 3,
- 4,
- 3,
- 4,
- 8,
- 11,
- 13,
- 12,
- 15,
- 14,
- 12,
- 13,
- 13,
+ 2,
+ 1,
+ 1,
+ 1,
+ 3,
+ 4,
+ 3,
+ 4,
+ 3,
+ 4,
+ 8,
+ 11,
+ 13,
+ 12,
+ 15,
+ 14,
+ 12,
+ 13,
+ 13,
};
-static const LPSTR lpszRTFTags[SIMBOLS_COUNT]=
+static const LPSTR lpszRTFTags[SYMBOLS_COUNT] =
{
- "\\par",
- "\\\\",
- "\\{",
- "\\}",
- "{\\b ",
- "}",
- "{\\ul ",
- "}",
- "{\\i ",
- "}",
- "}",
- "{\\cf2 ",
- "{\\cf3 ",
- "{\\cf4 ",
- "{\\cf5 ",
- "{\\cf6 ",
- "{\\cf7 ",
- "{\\cf8 ",
- "{\\cf9 ",
+ "\\par",
+ "\\\\",
+ "\\{",
+ "\\}",
+ "{\\b ",
+ "}",
+ "{\\ul ",
+ "}",
+ "{\\i ",
+ "}",
+ "}",
+ "{\\cf2 ",
+ "{\\cf3 ",
+ "{\\cf4 ",
+ "{\\cf5 ",
+ "{\\cf6 ",
+ "{\\cf7 ",
+ "{\\cf8 ",
+ "{\\cf9 ",
};
-static const SIZE_T dwcRTFTagsCount[SIMBOLS_COUNT]=
+static const size_t dwcRTFTagsCount[SYMBOLS_COUNT] =
{
- 4,
- 2,
- 2,
- 2,
- 4,
- 1,
- 5,
- 1,
- 4,
- 1,
- 1,
- 6,
- 6,
- 6,
- 6,
- 6,
- 6,
- 6,
- 6,
+ 4, 2, 2, 2, 4, 1, 5, 1, 4, 1, 1, 6, 6, 6, 6, 6, 6, 6, 6
};
+DWORD MraTextToRTFData(LPSTR lpszMessage, size_t dwMessageSize, LPSTR lpszMessageConverted, size_t dwMessageConvertedBuffSize, size_t *pdwMessageConvertedSize);
-DWORD MraTextToRTFData(LPSTR lpszMessage,SIZE_T dwMessageSize,LPSTR lpszMessageConverted,SIZE_T dwMessageConvertedBuffSize,SIZE_T *pdwMessageConvertedSize);
-
-
-BOOL MraIsMessageFlashAnimation(LPWSTR lpwszMessage,SIZE_T dwMessageSize)
+BOOL MraIsMessageFlashAnimation(LPCWSTR lpwszMessage, size_t dwMessageSize)
{
- BOOL bRet=FALSE;
- LPWSTR lpwszFounded;
-
- dwMessageSize*=sizeof(WCHAR);
- lpwszFounded=(LPWSTR)MemoryFind(0,lpwszMessage,dwMessageSize,L"<SMILE>id=flas",28);
- if (lpwszFounded)
- {
- if (MemoryFind(((lpwszFounded-lpwszMessage)+32),lpwszMessage,dwMessageSize,L"'</SMILE>",18)) bRet=TRUE;
- }
-return(bRet);
-}
-
+ dwMessageSize *= sizeof(WCHAR);
+ LPWSTR lpwszFound = (LPWSTR)MemoryFind(0, lpwszMessage, dwMessageSize, L"<SMILE>id = flas", 28);
+ if (lpwszFound)
+ if (MemoryFind(((lpwszFound-lpwszMessage)+32), lpwszMessage, dwMessageSize, L"'</SMILE>", 18))
+ return TRUE;
+ return FALSE;
+}
-DWORD MraTextToRTFData(LPSTR lpszMessage,SIZE_T dwMessageSize,LPSTR lpszMessageConverted,SIZE_T dwMessageConvertedBuffSize,SIZE_T *pdwMessageConvertedSize)
+DWORD MraTextToRTFData(LPSTR lpszMessage, size_t dwMessageSize, LPSTR lpszMessageConverted, size_t dwMessageConvertedBuffSize, size_t *pdwMessageConvertedSize)
{
- DWORD dwRetErrorCode=NO_ERROR;
-
- if (lpszMessage && dwMessageSize && lpszMessageConverted && dwMessageConvertedBuffSize)
- {
- BYTE tm,bCurByte;
- LPSTR lpszMessageConvertedCur,lpszMessageConvertedMax;
- SIZE_T i;
-
- lpszMessageConvertedCur=lpszMessageConverted;
- lpszMessageConvertedMax=(lpszMessageConverted+dwMessageConvertedBuffSize);
- for(i=0;(i<dwMessageSize && (lpszMessageConvertedMax-lpszMessageConvertedCur)>3);i++)
- {
- //lpszMessageConvertedCur+=mir_snprintf(lpszMessageConvertedCur,8,"\\'%x",(*((BYTE*)lpszMessage+i)));
-
- (*((WORD*)lpszMessageConvertedCur))=(*((WORD*)"\\'"));
- bCurByte=(*((BYTE*)lpszMessage+i));
- tm=(bCurByte>>4)&0xf;
- lpszMessageConvertedCur[2]=(tm>9)? ('a'+tm-10):('0'+tm);
-
- tm=bCurByte&0xf;
- lpszMessageConvertedCur[3]=(tm>9)? ('a'+tm-10):('0'+tm);
- lpszMessageConvertedCur+=4;
- (*((BYTE*)lpszMessageConvertedCur))=0;
+ if (lpszMessage && dwMessageSize && lpszMessageConverted && dwMessageConvertedBuffSize) {
+ BYTE tm, bCurByte;
+ LPSTR lpszMessageConvertedCur, lpszMessageConvertedMax;
+ size_t i;
+
+ lpszMessageConvertedCur = lpszMessageConverted;
+ lpszMessageConvertedMax = (lpszMessageConverted+dwMessageConvertedBuffSize);
+ for (i = 0; i < dwMessageSize && lpszMessageConvertedMax-lpszMessageConvertedCur > 3; i++) {
+ *((WORD*)lpszMessageConvertedCur) = *((WORD*)"\\'");
+ bCurByte = (*((BYTE*)lpszMessage+i));
+ tm = (bCurByte>>4)&0xf;
+ lpszMessageConvertedCur[2] = (tm>9)? ('a'+tm-10):('0'+tm);
+
+ tm = bCurByte&0xf;
+ lpszMessageConvertedCur[3] = (tm>9)? ('a'+tm-10):('0'+tm);
+ lpszMessageConvertedCur += 4;
+ (*((BYTE*)lpszMessageConvertedCur)) = 0;
}
- if (pdwMessageConvertedSize) (*pdwMessageConvertedSize)=(lpszMessageConvertedCur-lpszMessageConverted);
- }else{
- if (pdwMessageConvertedSize) (*pdwMessageConvertedSize)=0;
- dwRetErrorCode=ERROR_INVALID_HANDLE;
+ if (pdwMessageConvertedSize)
+ *pdwMessageConvertedSize = lpszMessageConvertedCur - lpszMessageConverted;
+ return NO_ERROR;
}
-return(dwRetErrorCode);
+
+ if (pdwMessageConvertedSize)
+ *pdwMessageConvertedSize = 0;
+ return ERROR_INVALID_HANDLE;
}
-
-DWORD MraSybolsToRTFTags(DWORD dwFlags,LPSTR lpszMessage,SIZE_T dwMessageSize,LPSTR lpszMessageConverted,SIZE_T dwMessageConvertedBuffSize,SIZE_T *pdwMessageConvertedSize)
+DWORD MraSymbolsToRTFTags(DWORD dwFlags, LPSTR lpszMessage, size_t dwMessageSize, LPSTR lpszMessageConverted, size_t dwMessageConvertedBuffSize, size_t *pdwMessageConvertedSize)
{
- DWORD dwRetErrorCode=NO_ERROR;
- LPSTR lpszFounded[SIMBOLS_COUNT],lpszMessageConvertedCur,lpszMessageCur,lpszMessageCurPrev,lpszMessageConvertedMax;
- SIZE_T i,dwFirstFoundedIndex=0,dwFoundedCount=0,dwMemPartToCopy;
-
-#ifdef _DEBUG //check table
- for(i=0;i<SIMBOLS_COUNT;i++)
- {
- if (lstrlenA(lpszSimbols[i])!=dwcSimbolsCount[i]) DebugBreak();
- if (lstrlenA(lpszRTFTags[i])!=dwcRTFTagsCount[i]) DebugBreak();
- }
-#endif
-
- lpszMessageCurPrev=lpszMessage;
- lpszMessageConvertedCur=lpszMessageConverted;
- lpszMessageConvertedMax=(lpszMessageConverted+dwMessageConvertedBuffSize);
- for(i=0;i<SIMBOLS_COUNT;i++)
- {// loking for first time
- lpszFounded[i]=(LPSTR)MemoryFind((lpszMessageCurPrev-lpszMessage),lpszMessage,dwMessageSize,lpszSimbols[i],dwcSimbolsCount[i]);
- if (lpszFounded[i]) dwFoundedCount++;
+ DWORD dwRetErrorCode = NO_ERROR;
+ LPSTR lpszFounded[SYMBOLS_COUNT], lpszMessageConvertedCur, lpszMessageCur, lpszMessageCurPrev, lpszMessageConvertedMax;
+ size_t i, dwFirstFoundIndex = 0, dwFoundCount = 0, dwMemPartToCopy;
+
+ lpszMessageCurPrev = lpszMessage;
+ lpszMessageConvertedCur = lpszMessageConverted;
+ lpszMessageConvertedMax = (lpszMessageConverted+dwMessageConvertedBuffSize);
+ for (i = 0; i < SYMBOLS_COUNT; i++) { // loking for first time
+ lpszFounded[i] = (LPSTR)MemoryFind((lpszMessageCurPrev-lpszMessage), lpszMessage, dwMessageSize, lpszSimbols[i], dwcSimbolsCount[i]);
+ if (lpszFounded[i]) dwFoundCount++;
}
- while(dwFoundedCount)
- {
- for(i=0;i<SIMBOLS_COUNT;i++)
- {// looking for first to replace
- if (lpszFounded[i] && (lpszFounded[i]<lpszFounded[dwFirstFoundedIndex] || lpszFounded[dwFirstFoundedIndex]==NULL)) dwFirstFoundedIndex=i;
- }
-
- if (lpszFounded[dwFirstFoundedIndex])
- {// founded
- dwMemPartToCopy=(lpszFounded[dwFirstFoundedIndex]-lpszMessageCurPrev);
- if (lpszMessageConvertedMax>(lpszMessageConvertedCur+(dwMemPartToCopy+dwcRTFTagsCount[dwFirstFoundedIndex])))
- {
- //memmove(lpszMessageConvertedCur,lpszMessageCurPrev,dwMemPartToCopy);lpszMessageConvertedCur+=dwMemPartToCopy;
- MraTextToRTFData(lpszMessageCurPrev,dwMemPartToCopy,lpszMessageConvertedCur,(lpszMessageConvertedMax-lpszMessageConvertedCur),&i);lpszMessageConvertedCur+=i;
- memmove(lpszMessageConvertedCur,lpszRTFTags[dwFirstFoundedIndex],dwcRTFTagsCount[dwFirstFoundedIndex]);lpszMessageConvertedCur+=dwcRTFTagsCount[dwFirstFoundedIndex];
- lpszMessageCurPrev=(lpszFounded[dwFirstFoundedIndex]+dwcSimbolsCount[dwFirstFoundedIndex]);
-
- for(i=0;i<SIMBOLS_COUNT;i++)
- {// loking for next time
- if (lpszFounded[i] && lpszFounded[i]<lpszMessageCurPrev)
- {
- dwFoundedCount--;// вычитаем тут, чтобы учесть схожие смайлы: "):-(" и ":-("
- lpszFounded[i]=(LPSTR)MemoryFind((lpszMessageCurPrev-lpszMessage),lpszMessage,dwMessageSize,lpszSimbols[i],dwcSimbolsCount[i]);
- if (lpszFounded[i]) dwFoundedCount++;
+ while(dwFoundCount) {
+ for (i = 0;i<SYMBOLS_COUNT;i++)
+ if (lpszFounded[i] && (lpszFounded[i]<lpszFounded[dwFirstFoundIndex] || lpszFounded[dwFirstFoundIndex] == NULL))
+ dwFirstFoundIndex = i;
+
+ if (lpszFounded[dwFirstFoundIndex]) { // found
+ dwMemPartToCopy = (lpszFounded[dwFirstFoundIndex]-lpszMessageCurPrev);
+ if (lpszMessageConvertedMax > (lpszMessageConvertedCur+(dwMemPartToCopy+dwcRTFTagsCount[dwFirstFoundIndex]))) {
+ MraTextToRTFData(lpszMessageCurPrev, dwMemPartToCopy, lpszMessageConvertedCur, (lpszMessageConvertedMax-lpszMessageConvertedCur), &i);lpszMessageConvertedCur += i;
+ memmove(lpszMessageConvertedCur, lpszRTFTags[dwFirstFoundIndex], dwcRTFTagsCount[dwFirstFoundIndex]);lpszMessageConvertedCur += dwcRTFTagsCount[dwFirstFoundIndex];
+ lpszMessageCurPrev = (lpszFounded[dwFirstFoundIndex]+dwcSimbolsCount[dwFirstFoundIndex]);
+
+ for (i = 0;i<SYMBOLS_COUNT;i++) { // looking for the next time
+ if (lpszFounded[i] && lpszFounded[i] < lpszMessageCurPrev) {
+ dwFoundCount--;// вычитаем тут, чтобы учесть схожие смайлы: "):-(" и ":-("
+ lpszFounded[i] = (LPSTR)MemoryFind((lpszMessageCurPrev-lpszMessage), lpszMessage, dwMessageSize, lpszSimbols[i], dwcSimbolsCount[i]);
+ if (lpszFounded[i]) dwFoundCount++;
}
}
- }else{
- dwRetErrorCode=ERROR_BUFFER_OVERFLOW;
+ }
+ else {
+ dwRetErrorCode = ERROR_BUFFER_OVERFLOW;
DebugBreak();
break;
}
- }else{// сюда по идее никогда не попадём, на всякий случай.
- DebugBreak();
- break;
}
}
- lpszMessageCur=(lpszMessage+dwMessageSize);
- //memmove(lpszMessageConvertedCur,lpszMessageCurPrev,(lpszMessageCur-lpszMessageCurPrev));lpszMessageConvertedCur+=(lpszMessageCur-lpszMessageCurPrev);
- MraTextToRTFData(lpszMessageCurPrev,(lpszMessageCur-lpszMessageCurPrev),lpszMessageConvertedCur,(lpszMessageConvertedMax-lpszMessageConvertedCur),&i);lpszMessageConvertedCur+=i;
- (*((WORD*)lpszMessageConvertedCur))=0;
- if (pdwMessageConvertedSize) (*pdwMessageConvertedSize)=(lpszMessageConvertedCur-lpszMessageConverted);
+ lpszMessageCur = (lpszMessage+dwMessageSize);
+ MraTextToRTFData(lpszMessageCurPrev, (lpszMessageCur-lpszMessageCurPrev), lpszMessageConvertedCur, (lpszMessageConvertedMax-lpszMessageConvertedCur), &i);lpszMessageConvertedCur += i;
+ *((WORD*)lpszMessageConvertedCur) = 0;
-return(dwRetErrorCode);
-}
+ if (pdwMessageConvertedSize)
+ *pdwMessageConvertedSize = lpszMessageConvertedCur - lpszMessageConverted;
+ return(dwRetErrorCode);
+}
-DWORD MraConvertToRTFW(LPWSTR lpwszMessage,SIZE_T dwMessageSize,LPSTR lpszMessageRTF,SIZE_T dwMessageRTFBuffSize,SIZE_T *pdwMessageRTFSize)
+DWORD CMraProto::MraConvertToRTFW(LPCWSTR lpwszMessage, size_t dwMessageSize, LPSTR lpszMessageRTF, size_t dwMessageRTFBuffSize, size_t *pdwMessageRTFSize)
{
- DWORD dwRetErrorCode;
-
- if (lpwszMessage && lpszMessageRTF)
- {
- if ((dwMessageSize+1024)<=dwMessageRTFBuffSize)
- {
- LPSTR lpszMessage;
-
- lpszMessage=(LPSTR)MEMALLOC(dwMessageSize+32);
- if (lpszMessage)
- {
- LPSTR lpszMessageRTFCur=lpszMessageRTF;
- SIZE_T dwtm;
- DWORD dwRTFFontColour,dwFontSize;
- LOGFONT lf={0};
-
- WideCharToMultiByte(MRA_CODE_PAGE,0,lpwszMessage,dwMessageSize,lpszMessage,(dwMessageSize+32),NULL,NULL);
-
- dwRTFFontColour=DB_Mra_GetDword(NULL,"RTFFontColour",MRA_DEFAULT_RTF_FONT_COLOUR);
- if (DB_Mra_GetContactSettingBlob(NULL,"RTFFont",&lf,sizeof(LOGFONT),NULL))
- {
- /*HDC hDC=GetDC(NULL);// kegl
- dwFontSize=-MulDiv(lf.lfHeight,72,GetDeviceCaps(hDC,LOGPIXELSY));
- ReleaseDC(NULL,hDC);*/
- }else{
- HDC hDC=GetDC(NULL);// kegl
- lf.lfCharSet=MRA_DEFAULT_RTF_FONT_CHARSET;
- lf.lfHeight=-MulDiv(MRA_DEFAULT_RTF_FONT_SIZE,GetDeviceCaps(hDC,LOGPIXELSY),72);
- lstrcpynW(lf.lfFaceName,MRA_DEFAULT_RTF_FONT_NAME,LF_FACESIZE);
- ReleaseDC(NULL,hDC);
- }
- dwFontSize=((-lf.lfHeight)+(((-lf.lfHeight)+4)/8));
-/* mail agent: привет
-{\rtf1\ansi\ansicpg1251\deff0\deflang1049{\fonttbl{\f0\fnil\fcharset204 Tahoma;}}
-{\colortbl ;\red255\green0\blue0;}
-\viewkind4\uc1\pard\cf1\f0\fs18\'ef\'f0\'e8\'e2\'e5\'f2\par
-}
+ if (!lpwszMessage || !lpszMessageRTF)
+ return ERROR_INVALID_HANDLE;
-{\rtf1\ansi\ansicpg1251\deff0\deflang1049{\fonttbl{\f0\fnil\fcharset204 Tahoma;}}
-{\colortbl ;\red255\green0\blue0;}
-\viewkind4\uc1\pard\cf1\f0\fs18 1\par
-2\par
-3\par
-}
-*/
- lpszMessageRTFCur+=mir_snprintf(lpszMessageRTFCur,(dwMessageRTFBuffSize-((SIZE_T)lpszMessageRTFCur-(SIZE_T)lpszMessageRTF)),"{\\rtf1\\ansi\\ansicpg1251\\deff0\\deflang1049{\\fonttbl{\\f0\\fnil\\fcharset%lu %s;}}\r\n",lf.lfCharSet,lf.lfFaceName);
-
- if (MemoryFind(0,lpszMessage,dwMessageSize,BB_COLOR_TAG,(sizeof(BB_COLOR_TAG)-1)))
- {//BB_COLOR_TAG// добавляем таблицу с цветами, только если текст подкрашен
- lpszMessageRTFCur+=mir_snprintf(lpszMessageRTFCur,(dwMessageRTFBuffSize-((SIZE_T)lpszMessageRTFCur-(SIZE_T)lpszMessageRTF)),"{\\colortbl;\\red%lu\\green%lu\\blue%lu;%s}\r\n",(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtBlue,(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtGreen,(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtRed,RTF_COLORTBLCOLOURS);
- }else{
- lpszMessageRTFCur+=mir_snprintf(lpszMessageRTFCur,(dwMessageRTFBuffSize-((SIZE_T)lpszMessageRTFCur-(SIZE_T)lpszMessageRTF)),"{\\colortbl;\\red%lu\\green%lu\\blue%lu;}\r\n",(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtBlue,(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtGreen,(*((RGBTRIPLE*)&dwRTFFontColour)).rgbtRed);
- }
+ if ((dwMessageSize+1024) > dwMessageRTFBuffSize) {
+ if (pdwMessageRTFSize)
+ *pdwMessageRTFSize = dwMessageSize;
+ return ERROR_BUFFER_OVERFLOW;
+ }
- {
- LPSTR lpszNotfink="",
- lpszBold=((lf.lfWeight==FW_BOLD)? "\\b1":lpszNotfink),
- lpszItalic=(lf.lfItalic? "\\i1":lpszNotfink),
- lpszUnderline=(lf.lfUnderline? "\\ul1":lpszNotfink),
- lpszStrikeOut=(lf.lfStrikeOut? "\\strike1":lpszNotfink);
- lpszMessageRTFCur+=mir_snprintf(lpszMessageRTFCur,(dwMessageRTFBuffSize-((SIZE_T)lpszMessageRTFCur-(SIZE_T)lpszMessageRTF)),"\\viewkind4\\uc1\\pard\\cf1\\f0\\fs%lu%s%s%s%s",dwFontSize,lpszBold,lpszItalic,lpszUnderline,lpszStrikeOut);
- }
+ mir_ptr<CHAR> lpszMessage((LPSTR)mir_calloc(dwMessageSize+32));
+ if (!lpszMessage)
+ return GetLastError();
- if ((dwRetErrorCode=MraSybolsToRTFTags(0,lpszMessage,dwMessageSize,lpszMessageRTFCur,(dwMessageRTFBuffSize-(lpszMessageRTFCur-lpszMessageRTF)),&dwtm))==NO_ERROR)
- {
- lpszMessageRTFCur+=dwtm;
- if ((lpszMessageRTF+dwMessageRTFBuffSize)>=(lpszMessageRTFCur+sizeof(PAR)+sizeof(CRLF)+2))
- {
- memmove(lpszMessageRTFCur,PAR,sizeof(PAR));lpszMessageRTFCur+=(sizeof(PAR)-1);
- memmove(lpszMessageRTFCur,CRLF,sizeof(CRLF));lpszMessageRTFCur+=(sizeof(CRLF)-1);
- memmove(lpszMessageRTFCur,"}",2);lpszMessageRTFCur+=2;
- if (pdwMessageRTFSize) (*pdwMessageRTFSize)=(lpszMessageRTFCur-lpszMessageRTF);
- DebugPrintCRLFA(lpszMessageRTF);
- dwRetErrorCode=NO_ERROR;
- }else{
- if (pdwMessageRTFSize) (*pdwMessageRTFSize)=dwMessageRTFBuffSize+1024;
- dwRetErrorCode=ERROR_BUFFER_OVERFLOW;
- DebugBreak();
- }
- }
- MEMFREE(lpszMessage);
- }
- }else{
- if (pdwMessageRTFSize) (*pdwMessageRTFSize)=dwMessageSize;
- dwRetErrorCode=ERROR_BUFFER_OVERFLOW;
- DebugBreak();
+ LPSTR lpszMessageRTFCur = lpszMessageRTF;
+ size_t dwtm;
+ DWORD dwRTFFontColour, dwFontSize;
+ LOGFONT lf = {0};
+
+ WideCharToMultiByte(MRA_CODE_PAGE, 0, lpwszMessage, dwMessageSize, lpszMessage, (dwMessageSize+32), NULL, NULL);
+
+ dwRTFFontColour = mraGetDword(NULL, "RTFFontColour", MRA_DEFAULT_RTF_FONT_COLOUR);
+ if ( !mraGetContactSettingBlob(NULL, "RTFFont", &lf, sizeof(LOGFONT), NULL)) {
+ HDC hDC = GetDC(NULL);// kegl
+ lf.lfCharSet = MRA_DEFAULT_RTF_FONT_CHARSET;
+ lf.lfHeight = -MulDiv(MRA_DEFAULT_RTF_FONT_SIZE, GetDeviceCaps(hDC, LOGPIXELSY), 72);
+ lstrcpynW(lf.lfFaceName, MRA_DEFAULT_RTF_FONT_NAME, LF_FACESIZE);
+ ReleaseDC(NULL, hDC);
+ }
+ dwFontSize = ((-lf.lfHeight)+(((-lf.lfHeight)+4)/8));
+
+ lpszMessageRTFCur += mir_snprintf(lpszMessageRTFCur, (dwMessageRTFBuffSize-((size_t)lpszMessageRTFCur-(size_t)lpszMessageRTF)), "{\\rtf1\\ansi\\ansicpg1251\\deff0\\deflang1049{\\fonttbl{\\f0\\fnil\\fcharset%lu %s;}}\r\n", lf.lfCharSet, lf.lfFaceName);
+
+ if (MemoryFind(0, lpszMessage, dwMessageSize, BB_COLOR_TAG, (sizeof(BB_COLOR_TAG)-1)))
+ lpszMessageRTFCur += mir_snprintf(lpszMessageRTFCur, (dwMessageRTFBuffSize-((size_t)lpszMessageRTFCur-(size_t)lpszMessageRTF)), "{\\colortbl;\\red%lu\\green%lu\\blue%lu;%s}\r\n", (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtBlue, (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtGreen, (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtRed, RTF_COLORTBLCOLOURS);
+ else
+ lpszMessageRTFCur += mir_snprintf(lpszMessageRTFCur, (dwMessageRTFBuffSize-((size_t)lpszMessageRTFCur-(size_t)lpszMessageRTF)), "{\\colortbl;\\red%lu\\green%lu\\blue%lu;}\r\n", (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtBlue, (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtGreen, (*((RGBTRIPLE*)&dwRTFFontColour)).rgbtRed);
+
+ LPSTR lpszNotfink = "",
+ lpszBold = ((lf.lfWeight == FW_BOLD)? "\\b1":lpszNotfink),
+ lpszItalic = (lf.lfItalic? "\\i1":lpszNotfink),
+ lpszUnderline = (lf.lfUnderline? "\\ul1":lpszNotfink),
+ lpszStrikeOut = (lf.lfStrikeOut? "\\strike1":lpszNotfink);
+ lpszMessageRTFCur += mir_snprintf(lpszMessageRTFCur, (dwMessageRTFBuffSize-((size_t)lpszMessageRTFCur-(size_t)lpszMessageRTF)), "\\viewkind4\\uc1\\pard\\cf1\\f0\\fs%lu%s%s%s%s", dwFontSize, lpszBold, lpszItalic, lpszUnderline, lpszStrikeOut);
+
+ if ( !MraSymbolsToRTFTags(0, lpszMessage, dwMessageSize, lpszMessageRTFCur, (dwMessageRTFBuffSize-(lpszMessageRTFCur-lpszMessageRTF)), &dwtm)) {
+ lpszMessageRTFCur += dwtm;
+ if ((lpszMessageRTF+dwMessageRTFBuffSize) >= (lpszMessageRTFCur+sizeof(PAR)+sizeof(CRLF)+2)) {
+ memmove(lpszMessageRTFCur, PAR, sizeof(PAR));lpszMessageRTFCur += (sizeof(PAR)-1);
+ memmove(lpszMessageRTFCur, CRLF, sizeof(CRLF));lpszMessageRTFCur += (sizeof(CRLF)-1);
+ memmove(lpszMessageRTFCur, "}", 2);lpszMessageRTFCur += 2;
+ if (pdwMessageRTFSize) (*pdwMessageRTFSize) = (lpszMessageRTFCur-lpszMessageRTF);
+ DebugPrintCRLFA(lpszMessageRTF);
+ return NO_ERROR;
}
- }else{
- dwRetErrorCode=ERROR_INVALID_HANDLE;
+
+ if (pdwMessageRTFSize) *pdwMessageRTFSize = dwMessageRTFBuffSize+1024;
+ return ERROR_BUFFER_OVERFLOW;
}
-return(dwRetErrorCode);
+
+ return 0;
}