mirror of
https://github.com/ONLYOFFICE/core.git
synced 2026-04-07 13:55:33 +08:00
XlsFormat - небольшой рефакторинг
This commit is contained in:
committed by
Alexander Trofimov
parent
c685af368b
commit
73077249ce
@ -1,95 +1,43 @@
|
||||
// ASCOfficeXlsFileTest.cpp : Defines the entry point for the console application.
|
||||
//
|
||||
|
||||
#include "stdafx.h"
|
||||
#include <boost/timer.hpp>
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
|
||||
#import "../win32/x64/Debug/ASCOfficeXlsFile2.dll" rename_namespace("ASCOfficeXlsFile"), raw_interfaces_only
|
||||
#include "../../Common/DocxFormat/Source/Base/Base.h"
|
||||
#include "../../Common/DocxFormat/Source/SystemUtility/FileSystem/Directory.h"
|
||||
|
||||
#define HR_RET(HR) if FAILED(hr = (HR)) { _ASSERTE(false); return -1; }
|
||||
#include "../source/XlsXlsxConverter/ConvertXls2Xlsx.h"
|
||||
#include "../source/XlsXlsxConverter/progressCallback.h"
|
||||
|
||||
class CCallback : public ASCOfficeXlsFile::_IAVSOfficeFileTemplateEvents
|
||||
{
|
||||
public:
|
||||
#include "../Common/XmlUtils.h"
|
||||
|
||||
CCallback(){m_cnt=0;}
|
||||
virtual ~CCallback(){}
|
||||
STDMETHOD(GetTypeInfoCount)(UINT*) { return E_NOTIMPL; }
|
||||
STDMETHOD(GetTypeInfo)(UINT, LCID, ITypeInfo**) { return E_NOTIMPL; }
|
||||
STDMETHOD(GetIDsOfNames)(REFIID, LPOLESTR*, UINT, LCID, DISPID*) { return E_NOTIMPL; }
|
||||
#include "../../OfficeUtils/src/OfficeUtils.h"
|
||||
|
||||
STDMETHOD(Invoke)(
|
||||
DISPID dispIdMember,
|
||||
REFIID riid,
|
||||
LCID lcid,
|
||||
WORD wFlags,
|
||||
DISPPARAMS* pDispParams,
|
||||
VARIANT* pVarResult,
|
||||
EXCEPINFO* pExcepInfo,
|
||||
UINT* puArgErr)
|
||||
{
|
||||
switch(dispIdMember)
|
||||
{
|
||||
case 1:
|
||||
std::cout << "\nPercent : " << pDispParams->rgvarg[0].lVal / 10000. << "%\n";
|
||||
return(S_OK);
|
||||
break;
|
||||
default:
|
||||
return(E_NOTIMPL);
|
||||
}
|
||||
}
|
||||
|
||||
STDMETHOD(QueryInterface)(REFIID iid, LPVOID* ppv)
|
||||
{
|
||||
if ((iid == __uuidof(ASCOfficeXlsFile::_IAVSOfficeFileTemplateEvents)) ||
|
||||
(iid == __uuidof(IDispatch)) ||
|
||||
(iid == __uuidof(IUnknown)))
|
||||
*ppv = this;
|
||||
else {
|
||||
*ppv = 0;
|
||||
return E_NOINTERFACE;
|
||||
}
|
||||
AddRef();
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
STDMETHOD_(ULONG,AddRef)() {
|
||||
return InterlockedIncrement(&m_cnt);
|
||||
}
|
||||
|
||||
STDMETHOD_(ULONG,Release)() {
|
||||
InterlockedDecrement(&m_cnt);
|
||||
if (m_cnt!=0) return m_cnt;
|
||||
delete this;
|
||||
return 0;
|
||||
}
|
||||
protected:
|
||||
LONG m_cnt;
|
||||
private:
|
||||
};
|
||||
|
||||
|
||||
|
||||
int ConvertSingle(int argc, _TCHAR* argv[])
|
||||
{
|
||||
ATL::CComPtr<ASCOfficeXlsFile::IAVSOfficeFileTemplate> officeXlsFile;
|
||||
HRESULT hr;
|
||||
HR_RET(officeXlsFile.CoCreateInstance(__uuidof(ASCOfficeXlsFile::COfficeXlsFile)));
|
||||
|
||||
boost::timer t1;
|
||||
officeXlsFile->LoadFromFile(ATL::CComBSTR(argv[1]), ATL::CComBSTR(argv[2]), NULL);
|
||||
std::cout << "\n\nTime : " << t1.elapsed() << "\n";
|
||||
return 0;
|
||||
}
|
||||
|
||||
int _tmain(int argc, _TCHAR* argv[])
|
||||
{
|
||||
CoInitialize(NULL);
|
||||
HRESULT hr = S_OK;
|
||||
boost::timer t1;
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
std::wstring srcFileName = argv[1];
|
||||
std::wstring dstPath = argv[2];
|
||||
std::wstring outputDir = FileSystem::Directory::GetFolderPath(dstPath);
|
||||
|
||||
std::wstring dstTempPath = FileSystem::Directory::CreateDirectoryWithUniqueName(outputDir);
|
||||
|
||||
hr = ConvertXls2Xlsx(srcFileName, dstTempPath, NULL);
|
||||
|
||||
if (hr != S_OK) return hr;
|
||||
|
||||
return ConvertSingle(argc, argv);
|
||||
|
||||
COfficeUtils oCOfficeUtils(NULL);
|
||||
if (S_OK != oCOfficeUtils.CompressFileOrDirectory(dstTempPath.c_str(), dstPath.c_str(), -1))
|
||||
return hr;
|
||||
|
||||
FileSystem::Directory::DeleteDirectory(dstTempPath);
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
std::cout << "\n\nTime : " << t1.elapsed() << "\n";
|
||||
return 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user