Textractor_test/extensions/extensionimpl.cpp

34 lines
1.6 KiB
C++
Raw Normal View History

2018-10-11 14:29:11 -04:00
#include "extension.h"
2018-09-22 15:08:31 -04:00
bool ProcessSentence(std::wstring& sentence, SentenceInfo sentenceInfo);
2019-06-29 15:43:26 +05:30
/*
You shouldn't mess with this or even look at it unless you're certain you know what you're doing.
Param sentence: pointer to sentence received by Textractor (UTF-16).
This can be modified. Textractor uses the modified sentence for future processing and display. If empty (starts with null terminator), Textractor will destroy it.
Textractor will display the sentence after all extensions have had a chance to process and/or modify it.
The buffer is allocated using HeapAlloc(). If you want to make it larger, please use HeapReAlloc().
2019-09-04 12:29:48 -04:00
Param sentenceInfo: pointer to array containing misc info about the sentence. End of array is marked with name being nullptr.
2019-06-29 15:43:26 +05:30
Return value: the buffer used for the sentence. Remember to return a new pointer if HeapReAlloc() gave you one.
This function may be run concurrently with itself: please make sure it's thread safe.
It will not be run concurrently with DllMain.
*/
2019-09-04 12:29:48 -04:00
extern "C" __declspec(dllexport) wchar_t* OnNewSentence(wchar_t* sentence, const InfoForExtension* sentenceInfo)
{
try
{
2021-01-31 08:02:10 -07:00
std::wstring sentenceCopy(sentence);
int oldSize = sentenceCopy.size();
if (ProcessSentence(sentenceCopy, SentenceInfo{ sentenceInfo }))
{
2021-01-31 08:02:10 -07:00
if (sentenceCopy.size() > oldSize) sentence = (wchar_t*)HeapReAlloc(GetProcessHeap(), HEAP_GENERATE_EXCEPTIONS, sentence, (sentenceCopy.size() + 1) * sizeof(wchar_t));
wcscpy_s(sentence, sentenceCopy.size() + 1, sentenceCopy.c_str());
}
}
2019-02-18 20:57:10 -05:00
catch (SKIP)
{
*sentence = L'\0';
}
return sentence;
2018-09-22 15:08:31 -04:00
}