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 "../version.h"
typedef enum tagTConversionDirection
{
TCD_ERROR,
TCD_AUTO,
TCD_RTF2DOCX,
TCD_DOCX2RTF
} TConversionDirection;
static std::wstring utf8_to_unicode(const char *src)
{
if (src == NULL) return _T("");
......@@ -38,6 +48,50 @@ static std::wstring utf8_to_unicode(const char *src)
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[])
{
// check arguments
......@@ -66,13 +120,48 @@ int main(int argc, char *argv[])
CString sXMLOptions = _T("");
{// rtf->docx
::ConvertationManager rtfFile;
CString sTempDir = FileSystem::Directory::GetFolderPath(sArg2) + FILE_SEPARATOR_STR + "Temp";
FileSystem::Directory::CreateDirectory(string2std_string(sTempDir));
TConversionDirection convDirect = getConversionDirectionFromExt(sArg1, sArg2);
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);
HRESULT hRes = rtfFile.ConvertRtfToOOX(sArg1, sArg2, 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);
if (hRes != S_OK)return 2;
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;
}
......@@ -20,7 +20,11 @@ bool OOXShapeReader::Parse2( ReaderParameter oParam , RtfShapePtr& oOutput)
oOutput->m_nShapeType = 75;
CString srId = image_data->m_oId.IsInit() ? image_data->m_oId.get2() : _T("") ;
smart_ptr<OOX::File> oFile = oParam.oDocx->GetDocument()->Find(srId);
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);
if ( oFile.IsInit() && (OOX::FileTypes::Image == oFile->type()))
{
......
......@@ -1165,13 +1165,12 @@ public:
{//заменяем на булеты
CString sResult;
CStringA sBullet;
char cBullet = (char)149;
sBullet.AppendChar( cBullet );
CString swBullet;
swBullet = sBullet;
char cBullet[1]; cBullet[0] = (char)149;
sResult.Append( swBullet );
std::string sBullet = cBullet;
std::wstring swBullet(sBullet.begin(), sBullet.end());
sResult.Append( swBullet.c_str() );
//CString sOOXNumber = GetLevelTextOOX();
//for( int i = 0; i < sOOXNumber.GetLength(); i++ )
// if( sOOXNumber[i] == '%' && i != sOOXNumber.GetLength() - 1 )
......
......@@ -311,6 +311,8 @@ public:
//todooo расширить до других codepages (щас тока анси)
std::string sAnsi(sCharString.GetBuffer());
std::wstring s(sAnsi.begin(), sAnsi.end());
sResult = std_string2string(s);
#endif
//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