Commit 3fb9cc75 authored by Elen.Subbotina's avatar Elen.Subbotina Committed by Alexander Trofimov

RtfFileConverter linux ready for testing

git-svn-id: svn://fileserver/activex/AVS/Sources/TeamlabOffice/trunk/ServerComponents@62132 954022d7-b5bf-4e40-9824-e11837661b57
parent 0e26761c
#include "../RtfFormatLib/source/ConvertationManager.h" 
#include "../RtfFormatLib/source/ConvertationManager.h"
#include "../../../ServerComponents/ASCOfficeUtils/ASCOfficeUtilsLib/OfficeUtils.h"
#include <iostream> #include <iostream>
#include "../version.h" #include "../version.h"
typedef enum tagTConversionDirection
{
TCD_ERROR,
TCD_AUTO,
TCD_RTF2DOCX,
TCD_DOCX2RTF
} TConversionDirection;
static std::wstring utf8_to_unicode(const char *src) static std::wstring utf8_to_unicode(const char *src)
{ {
if (src == NULL) return _T(""); if (src == NULL) return _T("");
...@@ -38,6 +48,50 @@ static std::wstring utf8_to_unicode(const char *src) ...@@ -38,6 +48,50 @@ static std::wstring utf8_to_unicode(const char *src)
return wsEntryName; return wsEntryName;
} }
static const TConversionDirection getConversionDirectionFromExt (const CString &sFile1, const CString &sFile2)
{
TConversionDirection res = TCD_ERROR;
int nExt1Pos = sFile1.ReverseFind(_T('.'));
int nExt2Pos = sFile2.ReverseFind(_T('.'));
// check for directory (zip task)
int nSeparator1Pos = sFile1.ReverseFind(_T('/'));
if (-1 == nSeparator1Pos)
{
nSeparator1Pos = sFile1.ReverseFind(_T('\\'));
}
// check for directory (unzip task)
int nSeparator2Pos = sFile2.ReverseFind(_T('/'));
if (-1 == nSeparator2Pos)
{
nSeparator2Pos = sFile2.ReverseFind(_T('\\'));
}
// there are no directories in paths, both paths are paths to files
if (-1 != nExt1Pos && -1 != nExt2Pos)
{
CString sExt1 = sFile1.Mid(nExt1Pos);
CString sExt2 = sFile2.Mid(nExt2Pos);
sExt1.ToLower();
sExt2.ToLower();
if ((0 == sExt1.CompareNoCase(_T(".rtf"))) && (0 == sExt2.CompareNoCase(_T(".docx"))))
{
res = TCD_RTF2DOCX;
}
else if ((0 == sExt1.CompareNoCase(_T(".docx"))) && (0 == sExt2.CompareNoCase(_T(".rtf"))))
{
res = TCD_DOCX2RTF;
}
}
return res;
}
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
// check arguments // check arguments
...@@ -66,13 +120,48 @@ int main(int argc, char *argv[]) ...@@ -66,13 +120,48 @@ int main(int argc, char *argv[])
CString sXMLOptions = _T(""); CString sXMLOptions = _T("");
{// rtf->docx CString sTempDir = FileSystem::Directory::GetFolderPath(sArg2) + FILE_SEPARATOR_STR + "Temp";
::ConvertationManager rtfFile; FileSystem::Directory::CreateDirectory(string2std_string(sTempDir));
HRESULT hRes = rtfFile.ConvertRtfToOOX(sArg1, sArg2, sXMLOptions); TConversionDirection convDirect = getConversionDirectionFromExt(sArg1, sArg2);
if (hRes != S_OK)return 2; ConvertationManager rtfFile;
rtfFile.m_sTempFolder = sTempDir;
HRESULT hRes = S_FALSE;
switch ( convDirect )
{
case TCD_RTF2DOCX:
{
CString sTempUnpackedDOCX = sTempDir + FILE_SEPARATOR_STR + _T("docx_unpacked");
FileSystem::Directory::CreateDirectory(sTempUnpackedDOCX);
hRes = rtfFile.ConvertRtfToOOX(sArg1, sTempUnpackedDOCX, sXMLOptions);
if (hRes == S_OK)
{
COfficeUtils oCOfficeUtils(NULL);
hRes = oCOfficeUtils.CompressFileOrDirectory (string2std_string(sTempUnpackedDOCX), string2std_string(sArg2), -1);
}
}break;
case TCD_DOCX2RTF:
{
CString sTempUnpackedDOCX = sTempDir + FILE_SEPARATOR_STR + _T("docx_unpacked");
FileSystem::Directory::CreateDirectory(sTempUnpackedDOCX);
COfficeUtils oCOfficeUtils(NULL);
hRes = oCOfficeUtils.ExtractToDirectory(string2std_string(sArg1), string2std_string(sTempUnpackedDOCX), NULL, 0);
if (hRes == S_OK)
{
hRes = rtfFile.ConvertOOXToRtf( sArg2, sTempUnpackedDOCX, sXMLOptions);
}
}break;
} }
// delete temp dir
FileSystem::Directory::DeleteDirectory(string2std_string(sTempDir));
if (hRes != S_OK)return 2;
return 0; return 0;
} }
...@@ -20,6 +20,10 @@ bool OOXShapeReader::Parse2( ReaderParameter oParam , RtfShapePtr& oOutput) ...@@ -20,6 +20,10 @@ bool OOXShapeReader::Parse2( ReaderParameter oParam , RtfShapePtr& oOutput)
oOutput->m_nShapeType = 75; oOutput->m_nShapeType = 75;
CString srId = image_data->m_oId.IsInit() ? image_data->m_oId.get2() : _T("") ; CString srId = image_data->m_oId.IsInit() ? image_data->m_oId.get2() : _T("") ;
if (srId.length() < 1)
srId = image_data->m_rId.IsInit() ? image_data->m_rId->GetValue() : _T("") ;
smart_ptr<OOX::File> oFile = oParam.oDocx->GetDocument()->Find(srId); smart_ptr<OOX::File> oFile = oParam.oDocx->GetDocument()->Find(srId);
if ( oFile.IsInit() && (OOX::FileTypes::Image == oFile->type())) if ( oFile.IsInit() && (OOX::FileTypes::Image == oFile->type()))
......
...@@ -1165,13 +1165,12 @@ public: ...@@ -1165,13 +1165,12 @@ public:
{//заменяем на булеты {//заменяем на булеты
CString sResult; CString sResult;
CStringA sBullet; char cBullet[1]; cBullet[0] = (char)149;
char cBullet = (char)149;
sBullet.AppendChar( cBullet );
CString swBullet;
swBullet = sBullet;
sResult.Append( swBullet ); std::string sBullet = cBullet;
std::wstring swBullet(sBullet.begin(), sBullet.end());
sResult.Append( swBullet.c_str() );
//CString sOOXNumber = GetLevelTextOOX(); //CString sOOXNumber = GetLevelTextOOX();
//for( int i = 0; i < sOOXNumber.GetLength(); i++ ) //for( int i = 0; i < sOOXNumber.GetLength(); i++ )
// if( sOOXNumber[i] == '%' && i != sOOXNumber.GetLength() - 1 ) // if( sOOXNumber[i] == '%' && i != sOOXNumber.GetLength() - 1 )
......
...@@ -311,6 +311,8 @@ public: ...@@ -311,6 +311,8 @@ public:
//todooo расширить до других codepages (щас тока анси) //todooo расширить до других codepages (щас тока анси)
std::string sAnsi(sCharString.GetBuffer()); std::string sAnsi(sCharString.GetBuffer());
std::wstring s(sAnsi.begin(), sAnsi.end()); std::wstring s(sAnsi.begin(), sAnsi.end());
sResult = std_string2string(s);
#endif #endif
//sResult = sKey; //sResult = sKey;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment