xref: /trunk/main/shell/source/win32/shlxthandler/ooofilt/ooofilt.cxx (revision fff73a02105133bddf756e68809d7ed9031aa468)
1f8e2c85aSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3f8e2c85aSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4f8e2c85aSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5f8e2c85aSAndrew Rist  * distributed with this work for additional information
6f8e2c85aSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7f8e2c85aSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8f8e2c85aSAndrew Rist  * "License"); you may not use this file except in compliance
9f8e2c85aSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11f8e2c85aSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13f8e2c85aSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14f8e2c85aSAndrew Rist  * software distributed under the License is distributed on an
15f8e2c85aSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16f8e2c85aSAndrew Rist  * KIND, either express or implied.  See the License for the
17f8e2c85aSAndrew Rist  * specific language governing permissions and limitations
18f8e2c85aSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20f8e2c85aSAndrew Rist  *************************************************************/
21f8e2c85aSAndrew Rist 
22f8e2c85aSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_shell.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir //--------------------------------------------------------------------------
28cdf0e10cSrcweir //  File:       ooofilt.cxx
29cdf0e10cSrcweir //
30*fff73a02Smseidel //  Contents:   Filter Implementation for OpenOffice Document using
31cdf0e10cSrcweir //              Indexing Service
32cdf0e10cSrcweir //
33*fff73a02Smseidel //  Summary:    The OpenOffice filter reads OpenOffice.org XML and
34*fff73a02Smseidel //              OpenDocument (ODF) files and extracts their content,
35*fff73a02Smseidel //              author, keywords, subject, comments and title to be
36*fff73a02Smseidel //              filtered.
37cdf0e10cSrcweir //
38cdf0e10cSrcweir //  Platform:   Windows 2000, Windows XP
39cdf0e10cSrcweir //
40cdf0e10cSrcweir //--------------------------------------------------------------------------
41cdf0e10cSrcweir #include "internal/contentreader.hxx"
42cdf0e10cSrcweir #include "internal/metainforeader.hxx"
43cdf0e10cSrcweir //#include "internal/utilities.hxx"
44cdf0e10cSrcweir #include "internal/registry.hxx"
45cdf0e10cSrcweir #include "internal/fileextensions.hxx"
46cdf0e10cSrcweir 
47cdf0e10cSrcweir //--------------------------------------------------------------------------
48cdf0e10cSrcweir //
49cdf0e10cSrcweir //  Include file    Purpose
50cdf0e10cSrcweir //
51cdf0e10cSrcweir //  windows.h       Win32 declarations
52cdf0e10cSrcweir //  string.h        string wstring declarations
53cdf0e10cSrcweir //  filter.h        IFilter interface declarations
54cdf0e10cSrcweir //  filterr.h       FACILITY_ITF error definitions for IFilter
55cdf0e10cSrcweir //  ntquery.h       Indexing Service declarations
56cdf0e10cSrcweir //  assert.h        assertion function.
57*fff73a02Smseidel //  ooofilt.hxx     OpenOffice filter declarations
58cdf0e10cSrcweir //  propspec.hxx    PROPSPEC
59cdf0e10cSrcweir //
60cdf0e10cSrcweir //--------------------------------------------------------------------------
61cdf0e10cSrcweir 
62cdf0e10cSrcweir #if defined _MSC_VER
63cdf0e10cSrcweir #pragma warning(push, 1)
64cdf0e10cSrcweir #endif
65cdf0e10cSrcweir #include <windows.h>
66cdf0e10cSrcweir #if defined _MSC_VER
67cdf0e10cSrcweir #pragma warning(pop)
68cdf0e10cSrcweir #endif
69cdf0e10cSrcweir #include <string.h>
70cdf0e10cSrcweir #include <filter.h>
71cdf0e10cSrcweir #include <filterr.h>
72cdf0e10cSrcweir #include <ntquery.h>
73cdf0e10cSrcweir #include "assert.h"
74cdf0e10cSrcweir #include "ooofilt.hxx"
75cdf0e10cSrcweir #include <objidl.h>
76cdf0e10cSrcweir #include <stdio.h>
77cdf0e10cSrcweir #include "propspec.hxx"
78cdf0e10cSrcweir #ifdef __MINGW32__
79cdf0e10cSrcweir #include <algorithm>
80cdf0e10cSrcweir using ::std::min;
81cdf0e10cSrcweir #endif
82cdf0e10cSrcweir 
83cdf0e10cSrcweir #include "internal/stream_helper.hxx"
84cdf0e10cSrcweir 
85cdf0e10cSrcweir //C-------------------------------------------------------------------------
86cdf0e10cSrcweir //
87cdf0e10cSrcweir //  Class:      COooFilter
88cdf0e10cSrcweir //
89*fff73a02Smseidel //  Summary:    Implements OpenOffice filter class
90cdf0e10cSrcweir //
91cdf0e10cSrcweir //--------------------------------------------------------------------------
92cdf0e10cSrcweir //M-------------------------------------------------------------------------
93cdf0e10cSrcweir //
94cdf0e10cSrcweir //  Method:     COooFilter::COooFilter
95cdf0e10cSrcweir //
96cdf0e10cSrcweir //  Summary:    Class constructor
97cdf0e10cSrcweir //
98cdf0e10cSrcweir //  Arguments:  void
99cdf0e10cSrcweir //
100cdf0e10cSrcweir //  Purpose:    Manages global instance count
101cdf0e10cSrcweir //
102cdf0e10cSrcweir //--------------------------------------------------------------------------
COooFilter()103cdf0e10cSrcweir COooFilter::COooFilter() :
104cdf0e10cSrcweir     m_lRefs(1),
105cdf0e10cSrcweir     m_pContentReader(NULL),
106cdf0e10cSrcweir     m_pMetaInfoReader(NULL),
107cdf0e10cSrcweir     m_eState(FilteringContent),
108cdf0e10cSrcweir     m_ulUnicodeBufferLen(0),
109cdf0e10cSrcweir     m_ulUnicodeCharsRead(0),
110cdf0e10cSrcweir     m_ulPropertyNum(0),
111cdf0e10cSrcweir     m_ulCurrentPropertyNum(0),
112cdf0e10cSrcweir     m_ulChunkID(1),
113cdf0e10cSrcweir     m_fContents(FALSE),
114cdf0e10cSrcweir     m_fEof(FALSE),
115cdf0e10cSrcweir     m_ChunkPosition(0),
116cdf0e10cSrcweir     m_cAttributes(0),
117cdf0e10cSrcweir     m_pAttributes(0),
118cdf0e10cSrcweir     m_pStream(NULL)
119cdf0e10cSrcweir 
120cdf0e10cSrcweir {
121cdf0e10cSrcweir     InterlockedIncrement( &g_lInstances );
122cdf0e10cSrcweir }
123cdf0e10cSrcweir //M-------------------------------------------------------------------------
124cdf0e10cSrcweir //
125cdf0e10cSrcweir //  Method:     COooFilter::~COooFilter
126cdf0e10cSrcweir //
127cdf0e10cSrcweir //  Summary:    Class destructor
128cdf0e10cSrcweir //
129cdf0e10cSrcweir //  Arguments:  void
130cdf0e10cSrcweir //
131cdf0e10cSrcweir //  Purpose:    Manages global instance count and file handle
132cdf0e10cSrcweir //
133cdf0e10cSrcweir //--------------------------------------------------------------------------
~COooFilter()134cdf0e10cSrcweir COooFilter::~COooFilter()
135cdf0e10cSrcweir {
136cdf0e10cSrcweir     delete [] m_pAttributes;
137cdf0e10cSrcweir 
138cdf0e10cSrcweir     if (m_pContentReader)
139cdf0e10cSrcweir         delete m_pContentReader;
140cdf0e10cSrcweir     if (m_pMetaInfoReader)
141cdf0e10cSrcweir         delete m_pMetaInfoReader;
142cdf0e10cSrcweir 
143cdf0e10cSrcweir     InterlockedDecrement( &g_lInstances );
144cdf0e10cSrcweir }
145cdf0e10cSrcweir 
146cdf0e10cSrcweir //M-------------------------------------------------------------------------
147cdf0e10cSrcweir //
148cdf0e10cSrcweir //  Method:     COooFilter::QueryInterface      (IUnknown::QueryInterface)
149cdf0e10cSrcweir //
150cdf0e10cSrcweir //  Summary:    Queries for requested interface
151cdf0e10cSrcweir //
152cdf0e10cSrcweir //  Arguments:  riid
153cdf0e10cSrcweir //              [in] Reference IID of requested interface
154cdf0e10cSrcweir //              ppvObject
155cdf0e10cSrcweir //              [out] Address that receives requested interface pointer
156cdf0e10cSrcweir //
157cdf0e10cSrcweir //  Returns:    S_OK
158cdf0e10cSrcweir //              Interface is supported
159cdf0e10cSrcweir //              E_NOINTERFACE
160cdf0e10cSrcweir //              Interface is not supported
161cdf0e10cSrcweir //
162cdf0e10cSrcweir //--------------------------------------------------------------------------
QueryInterface(REFIID riid,void ** ppvObject)163cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::QueryInterface(
164cdf0e10cSrcweir     REFIID riid,
165cdf0e10cSrcweir     void  ** ppvObject)
166cdf0e10cSrcweir {
167cdf0e10cSrcweir     IUnknown *pUnkTemp = 0;
168cdf0e10cSrcweir     if ( IID_IFilter == riid )
169cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IFilter *)this;
170cdf0e10cSrcweir     else if ( IID_IPersistFile == riid )
171cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IPersistFile *)this;
172cdf0e10cSrcweir     else if ( IID_IPersist == riid )
173cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IPersist *)(IPersistFile *)this;
174cdf0e10cSrcweir     else if (IID_IPersistStream == riid)
175cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IPersistStream *)this;
176cdf0e10cSrcweir     else if ( IID_IUnknown == riid )
177cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IPersist *)(IPersistFile *)this;
178cdf0e10cSrcweir     else
179cdf0e10cSrcweir     {
180cdf0e10cSrcweir         *ppvObject = NULL;
181cdf0e10cSrcweir         return E_NOINTERFACE;
182cdf0e10cSrcweir     }
183cdf0e10cSrcweir     *ppvObject = (void  *)pUnkTemp;
184cdf0e10cSrcweir     pUnkTemp->AddRef();
185cdf0e10cSrcweir     return S_OK;
186cdf0e10cSrcweir }
187cdf0e10cSrcweir //M-------------------------------------------------------------------------
188cdf0e10cSrcweir //
189cdf0e10cSrcweir //  Method:     COooFilter::AddRef              (IUnknown::AddRef)
190cdf0e10cSrcweir //
191cdf0e10cSrcweir //  Summary:    Increments interface refcount
192cdf0e10cSrcweir //
193cdf0e10cSrcweir //  Arguments:  void
194cdf0e10cSrcweir //
195cdf0e10cSrcweir //  Returns:    Value of incremented interface refcount
196cdf0e10cSrcweir //
197cdf0e10cSrcweir //--------------------------------------------------------------------------
AddRef()198cdf0e10cSrcweir ULONG STDMETHODCALLTYPE COooFilter::AddRef()
199cdf0e10cSrcweir {
200cdf0e10cSrcweir     return InterlockedIncrement( &m_lRefs );
201cdf0e10cSrcweir }
202cdf0e10cSrcweir //M-------------------------------------------------------------------------
203cdf0e10cSrcweir //
204cdf0e10cSrcweir //  Method:     COooFilter::Release             (IUnknown::Release)
205cdf0e10cSrcweir //
206cdf0e10cSrcweir //  Summary:    Decrements interface refcount, deleting if unreferenced
207cdf0e10cSrcweir //
208cdf0e10cSrcweir //  Arguments:  void
209cdf0e10cSrcweir //
210cdf0e10cSrcweir //  Returns:    Value of decremented interface refcount
211cdf0e10cSrcweir //
212cdf0e10cSrcweir //--------------------------------------------------------------------------
Release()213cdf0e10cSrcweir ULONG STDMETHODCALLTYPE COooFilter::Release()
214cdf0e10cSrcweir {
215cdf0e10cSrcweir     ULONG ulTmp = InterlockedDecrement( &m_lRefs );
216cdf0e10cSrcweir 
217cdf0e10cSrcweir     if ( 0 == ulTmp )
218cdf0e10cSrcweir         delete this;
219cdf0e10cSrcweir     return ulTmp;
220cdf0e10cSrcweir }
221cdf0e10cSrcweir //M-------------------------------------------------------------------------
222cdf0e10cSrcweir //
223cdf0e10cSrcweir //  Method:     COooFilter::Init                (IFilter::Init)
224cdf0e10cSrcweir //
225*fff73a02Smseidel //  Summary:    Initializes OpenOffice filter instance
226cdf0e10cSrcweir //
227cdf0e10cSrcweir //  Arguments:  grfFlags
228cdf0e10cSrcweir //                  [in] Flags for filter behavior
229cdf0e10cSrcweir //              cAttributes
230cdf0e10cSrcweir //                  [in] Number attributes in array aAttributes
231cdf0e10cSrcweir //              aAttributes
232cdf0e10cSrcweir //                  [in] Array of requested attribute strings
233cdf0e10cSrcweir //              pFlags
234cdf0e10cSrcweir //                  [out] Pointer to return flags for additional properties
235cdf0e10cSrcweir //
236cdf0e10cSrcweir //  Returns:    S_OK
237cdf0e10cSrcweir //                  Initialization succeeded
238cdf0e10cSrcweir //              E_FAIL
239cdf0e10cSrcweir //                  File not previously loaded
240cdf0e10cSrcweir //              E_INVALIDARG
241cdf0e10cSrcweir //                  Count and contents of attributes do not agree
242cdf0e10cSrcweir //              FILTER_E_ACCESS
243cdf0e10cSrcweir //                  Unable to access file to be filtered
244cdf0e10cSrcweir //              FILTER_E_PASSWORD
245cdf0e10cSrcweir //                  (not implemented)
246cdf0e10cSrcweir //
247cdf0e10cSrcweir //--------------------------------------------------------------------------
248cdf0e10cSrcweir const int COUNT_ATTRIBUTES = 5;
249cdf0e10cSrcweir 
Init(ULONG grfFlags,ULONG cAttributes,FULLPROPSPEC const * aAttributes,ULONG * pFlags)250cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::Init(
251cdf0e10cSrcweir     ULONG grfFlags,
252cdf0e10cSrcweir     ULONG cAttributes,
253cdf0e10cSrcweir     FULLPROPSPEC const * aAttributes,
254cdf0e10cSrcweir     ULONG * pFlags)
255cdf0e10cSrcweir {
256cdf0e10cSrcweir     // Enumerate OLE properties, since any NTFS file can have them
257cdf0e10cSrcweir     *pFlags = IFILTER_FLAGS_OLE_PROPERTIES;
258cdf0e10cSrcweir     try
259cdf0e10cSrcweir     {
260cdf0e10cSrcweir         m_fContents = FALSE;
261cdf0e10cSrcweir         m_ulPropertyNum = 0;
262cdf0e10cSrcweir         m_ulCurrentPropertyNum = 0;
263cdf0e10cSrcweir         if ( m_cAttributes > 0 )
264cdf0e10cSrcweir         {
265cdf0e10cSrcweir             delete[] m_pAttributes;
266cdf0e10cSrcweir             m_pAttributes = 0;
267cdf0e10cSrcweir             m_cAttributes = 0;
268cdf0e10cSrcweir         }
269cdf0e10cSrcweir         if( 0 < cAttributes )
270cdf0e10cSrcweir         {
271cdf0e10cSrcweir             // Filter properties specified in aAttributes
272cdf0e10cSrcweir             if ( 0 == aAttributes )
273cdf0e10cSrcweir                 return E_INVALIDARG;
274cdf0e10cSrcweir             m_pAttributes = new CFullPropSpec[cAttributes];
275cdf0e10cSrcweir             m_cAttributes = cAttributes;
276cdf0e10cSrcweir             // Is caller want to filter contents?
277cdf0e10cSrcweir             CFullPropSpec *pAttrib = (CFullPropSpec *) aAttributes;
278cdf0e10cSrcweir             ULONG ulNumAttr;
279cdf0e10cSrcweir             for ( ulNumAttr = 0 ; ulNumAttr < cAttributes; ulNumAttr++ )
280cdf0e10cSrcweir             {
281cdf0e10cSrcweir                 if ( pAttrib[ulNumAttr].IsPropertyPropid() &&
282cdf0e10cSrcweir                      pAttrib[ulNumAttr].GetPropertyPropid() == PID_STG_CONTENTS &&
283cdf0e10cSrcweir                      pAttrib[ulNumAttr].GetPropSet() == guidStorage )
284cdf0e10cSrcweir                 {
285cdf0e10cSrcweir                     m_fContents = TRUE;
286cdf0e10cSrcweir                 }
287cdf0e10cSrcweir                 // save the requested properties.
288cdf0e10cSrcweir                 m_pAttributes[ulNumAttr] = pAttrib[ulNumAttr];
289cdf0e10cSrcweir             }
290cdf0e10cSrcweir         }
291cdf0e10cSrcweir         else if ( grfFlags & IFILTER_INIT_APPLY_INDEX_ATTRIBUTES )
292cdf0e10cSrcweir         {
293cdf0e10cSrcweir             // Filter contents and all pseudo-properties
294cdf0e10cSrcweir             m_fContents = TRUE;
295cdf0e10cSrcweir 
296cdf0e10cSrcweir             m_pAttributes = new CFullPropSpec[COUNT_ATTRIBUTES];
297cdf0e10cSrcweir             m_cAttributes = COUNT_ATTRIBUTES;
298cdf0e10cSrcweir             m_pAttributes[0].SetPropSet( FMTID_SummaryInformation );
299cdf0e10cSrcweir             m_pAttributes[0].SetProperty( PIDSI_AUTHOR );
300cdf0e10cSrcweir             m_pAttributes[1].SetPropSet( FMTID_SummaryInformation );
301cdf0e10cSrcweir             m_pAttributes[1].SetProperty( PIDSI_TITLE );
302cdf0e10cSrcweir             m_pAttributes[2].SetPropSet( FMTID_SummaryInformation );
303cdf0e10cSrcweir             m_pAttributes[2].SetProperty( PIDSI_SUBJECT );
304cdf0e10cSrcweir             m_pAttributes[3].SetPropSet( FMTID_SummaryInformation );
305cdf0e10cSrcweir             m_pAttributes[3].SetProperty( PIDSI_KEYWORDS );
306cdf0e10cSrcweir             m_pAttributes[4].SetPropSet( FMTID_SummaryInformation );
307cdf0e10cSrcweir             m_pAttributes[4].SetProperty( PIDSI_COMMENTS );
308cdf0e10cSrcweir         }
309cdf0e10cSrcweir         else if ( 0 == grfFlags )
310cdf0e10cSrcweir         {
311cdf0e10cSrcweir             // Filter only contents
312cdf0e10cSrcweir             m_fContents = TRUE;
313cdf0e10cSrcweir         }
314cdf0e10cSrcweir         else
315cdf0e10cSrcweir             m_fContents = FALSE;
316cdf0e10cSrcweir         // Re-initialize
317cdf0e10cSrcweir         if ( m_fContents )
318cdf0e10cSrcweir         {
319cdf0e10cSrcweir             m_fEof = FALSE;
320cdf0e10cSrcweir             m_eState = FilteringContent;
321cdf0e10cSrcweir             m_ulUnicodeCharsRead = 0;
322cdf0e10cSrcweir             m_ChunkPosition = 0;
323cdf0e10cSrcweir         }
324cdf0e10cSrcweir         else
325cdf0e10cSrcweir         {
326cdf0e10cSrcweir             m_fEof = TRUE;
327cdf0e10cSrcweir             m_eState = FilteringProperty;
328cdf0e10cSrcweir         }
329cdf0e10cSrcweir         m_ulChunkID = 1;
330cdf0e10cSrcweir     }
331cdf0e10cSrcweir     catch (const std::exception&)
332cdf0e10cSrcweir     {
333cdf0e10cSrcweir         return E_FAIL;
334cdf0e10cSrcweir     }
335cdf0e10cSrcweir 
336cdf0e10cSrcweir     return S_OK;
337cdf0e10cSrcweir }
338cdf0e10cSrcweir //M-------------------------------------------------------------------------
339cdf0e10cSrcweir //
340cdf0e10cSrcweir //  Method:     COooFilter::GetChunk            (IFilter::GetChunk)
341cdf0e10cSrcweir //
342cdf0e10cSrcweir //  Summary:    Gets the next chunk
343cdf0e10cSrcweir //
344cdf0e10cSrcweir //  Arguments:  ppStat
345cdf0e10cSrcweir //                  [out] Pointer to description of current chunk
346cdf0e10cSrcweir //  Returns:    S_OK
347cdf0e10cSrcweir //                  Chunk was successfully retrieved
348cdf0e10cSrcweir //              E_FAIL
349cdf0e10cSrcweir //                  Character conversion failed
350cdf0e10cSrcweir //              FILTER_E_ACCESS
351cdf0e10cSrcweir //                  General access failure occurred
352cdf0e10cSrcweir //              FILTER_E_END_OF_CHUNKS
353cdf0e10cSrcweir //                  Previous chunk was the last chunk
354cdf0e10cSrcweir //              FILTER_E_EMBEDDING_UNAVAILABLE
355cdf0e10cSrcweir //                  (not implemented)
356cdf0e10cSrcweir //              FILTER_E_LINK_UNAVAILABLE
357cdf0e10cSrcweir //                  (not implemented)
358cdf0e10cSrcweir //              FILTER_E_PASSWORD
359cdf0e10cSrcweir //                  (not implemented)
360cdf0e10cSrcweir //
361cdf0e10cSrcweir //--------------------------------------------------------------------------
GetChunk(STAT_CHUNK * pStat)362cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetChunk(STAT_CHUNK * pStat)
363cdf0e10cSrcweir {
364cdf0e10cSrcweir     for(;;)
365cdf0e10cSrcweir     {
366cdf0e10cSrcweir         switch ( m_eState )
367cdf0e10cSrcweir         {
368cdf0e10cSrcweir         case FilteringContent:
369cdf0e10cSrcweir         {
370*fff73a02Smseidel             // Read Unicode from buffer.
371cdf0e10cSrcweir             if( m_ChunkPosition == m_pContentReader ->getChunkBuffer().size() )
372cdf0e10cSrcweir             {
373cdf0e10cSrcweir                 m_ulUnicodeBufferLen=0;
374cdf0e10cSrcweir                 m_fEof = TRUE;
375cdf0e10cSrcweir             }
376cdf0e10cSrcweir 
377cdf0e10cSrcweir             if ( !m_fContents || m_fEof )
378cdf0e10cSrcweir             {
379cdf0e10cSrcweir                 m_eState = FilteringProperty;
380cdf0e10cSrcweir                 continue;
381cdf0e10cSrcweir             }
382cdf0e10cSrcweir             m_pwsBuffer = m_pContentReader -> getChunkBuffer()[m_ChunkPosition].second;
383cdf0e10cSrcweir             m_ulUnicodeBufferLen = m_pwsBuffer.length();
384cdf0e10cSrcweir             DWORD ChunkLCID = LocaleSetToLCID( m_pContentReader -> getChunkBuffer()[m_ChunkPosition].first );
385cdf0e10cSrcweir             // Set chunk description
386cdf0e10cSrcweir             pStat->idChunk   = m_ulChunkID;
387cdf0e10cSrcweir             pStat->breakType = CHUNK_NO_BREAK;
388cdf0e10cSrcweir             pStat->flags     = CHUNK_TEXT;
389cdf0e10cSrcweir             pStat->locale    = ChunkLCID;
390cdf0e10cSrcweir             pStat->attribute.guidPropSet       = guidStorage;
391cdf0e10cSrcweir             pStat->attribute.psProperty.ulKind = PRSPEC_PROPID;
392cdf0e10cSrcweir             pStat->attribute.psProperty.propid = PID_STG_CONTENTS;
393cdf0e10cSrcweir             pStat->idChunkSource  = m_ulChunkID;
394cdf0e10cSrcweir             pStat->cwcStartSource = 0;
395cdf0e10cSrcweir             pStat->cwcLenSource   = 0;
396cdf0e10cSrcweir             m_ulUnicodeCharsRead = 0;
397cdf0e10cSrcweir             m_ulChunkID++;
398cdf0e10cSrcweir             m_ChunkPosition++;
399cdf0e10cSrcweir             return S_OK;
400cdf0e10cSrcweir         }
401cdf0e10cSrcweir         case FilteringProperty:
402cdf0e10cSrcweir         {
403cdf0e10cSrcweir             if ( m_cAttributes == 0 )
404cdf0e10cSrcweir                 return FILTER_E_END_OF_CHUNKS;
405cdf0e10cSrcweir             while(  !( ( m_pAttributes[m_ulPropertyNum].IsPropertyPropid() ) &&
406cdf0e10cSrcweir                        ( m_pAttributes[m_ulPropertyNum].GetPropSet() == FMTID_SummaryInformation ) )||
407cdf0e10cSrcweir                      ( ( m_pAttributes[m_ulPropertyNum].GetPropertyPropid() != PIDSI_AUTHOR ) &&
408cdf0e10cSrcweir                        ( m_pAttributes[m_ulPropertyNum].GetPropertyPropid() != PIDSI_TITLE ) &&
409cdf0e10cSrcweir                        ( m_pAttributes[m_ulPropertyNum].GetPropertyPropid() != PIDSI_SUBJECT ) &&
410cdf0e10cSrcweir                        ( m_pAttributes[m_ulPropertyNum].GetPropertyPropid() != PIDSI_KEYWORDS ) &&
411cdf0e10cSrcweir                        ( m_pAttributes[m_ulPropertyNum].GetPropertyPropid() != PIDSI_COMMENTS ) ) )
412cdf0e10cSrcweir             {
413cdf0e10cSrcweir                 if ( m_ulPropertyNum < m_cAttributes )
414cdf0e10cSrcweir                     m_ulPropertyNum++;
415cdf0e10cSrcweir                 else
416cdf0e10cSrcweir                     break;
417cdf0e10cSrcweir             }
418cdf0e10cSrcweir             if ( m_ulPropertyNum == m_cAttributes)
419cdf0e10cSrcweir                 return FILTER_E_END_OF_CHUNKS;
420cdf0e10cSrcweir             else
421cdf0e10cSrcweir             {
422cdf0e10cSrcweir                 // Set chunk description
423cdf0e10cSrcweir                 pStat->idChunk = m_ulChunkID;
424cdf0e10cSrcweir                 pStat->breakType = CHUNK_EOS;
425cdf0e10cSrcweir                 pStat->flags = CHUNK_VALUE;
426cdf0e10cSrcweir                 pStat->locale = GetSystemDefaultLCID();
427cdf0e10cSrcweir                 pStat->attribute.guidPropSet = FMTID_SummaryInformation;
428cdf0e10cSrcweir                 pStat->attribute.psProperty.ulKind = PRSPEC_PROPID;
429cdf0e10cSrcweir                 pStat->attribute.psProperty.propid = m_pAttributes[m_ulPropertyNum].GetPropertyPropid();
430cdf0e10cSrcweir                 pStat->idChunkSource = m_ulChunkID;
431cdf0e10cSrcweir                 pStat->cwcStartSource = 0;
432cdf0e10cSrcweir                 pStat->cwcLenSource = 0;
433cdf0e10cSrcweir                 m_ulCurrentPropertyNum = m_ulPropertyNum;
434cdf0e10cSrcweir                 m_ulPropertyNum++;
435cdf0e10cSrcweir                 m_ulChunkID++;
436cdf0e10cSrcweir                 return S_OK;
437cdf0e10cSrcweir             }
438cdf0e10cSrcweir         }
439cdf0e10cSrcweir         default:
440cdf0e10cSrcweir             return E_FAIL;
441cdf0e10cSrcweir         }//switch(...)
442cdf0e10cSrcweir     }//for(;;)
443cdf0e10cSrcweir }
444cdf0e10cSrcweir //M-------------------------------------------------------------------------
445cdf0e10cSrcweir //
446cdf0e10cSrcweir //  Method:     COooFilter::GetText             (IFilter::GetText)
447cdf0e10cSrcweir //
448cdf0e10cSrcweir //  Summary:    Retrieves UNICODE text for index
449cdf0e10cSrcweir //
450cdf0e10cSrcweir //  Arguments:  pcwcBuffer
451cdf0e10cSrcweir //                  [in] Pointer to size of UNICODE buffer
452cdf0e10cSrcweir //                  [out] Pointer to count of UNICODE characters returned
453cdf0e10cSrcweir //              awcBuffer
454cdf0e10cSrcweir //                  [out] Pointer to buffer to receive UNICODE text
455cdf0e10cSrcweir //
456cdf0e10cSrcweir //  Returns:    S_OK
457cdf0e10cSrcweir //                  Text successfully retrieved, but text remains in chunk
458cdf0e10cSrcweir //              FILTER_E_NO_MORE_TEXT
459cdf0e10cSrcweir //                  All of the text in the current chunk has been returned
460cdf0e10cSrcweir //              FILTER_S_LAST_TEXT
461cdf0e10cSrcweir //                  Next call to GetText will return FILTER_E_NO_MORE_TEXT
462cdf0e10cSrcweir //
463cdf0e10cSrcweir //--------------------------------------------------------------------------
GetText(ULONG * pcwcBuffer,WCHAR * awcBuffer)464cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetText(ULONG * pcwcBuffer, WCHAR * awcBuffer)
465cdf0e10cSrcweir {
466cdf0e10cSrcweir     switch ( m_eState )
467cdf0e10cSrcweir     {
468cdf0e10cSrcweir     case FilteringProperty:
469cdf0e10cSrcweir         return FILTER_E_NO_TEXT;
470cdf0e10cSrcweir     case FilteringContent:
471cdf0e10cSrcweir     {
472cdf0e10cSrcweir         if ( !m_fContents || 0 == m_ulUnicodeBufferLen )
473cdf0e10cSrcweir         {
474cdf0e10cSrcweir             *pcwcBuffer = 0;
475cdf0e10cSrcweir             return FILTER_E_NO_MORE_TEXT;
476cdf0e10cSrcweir         }
477cdf0e10cSrcweir         // Copy UNICODE characters in chunk buffer to output UNICODE buffer
478cdf0e10cSrcweir         ULONG ulToCopy = min( *pcwcBuffer, m_ulUnicodeBufferLen - m_ulUnicodeCharsRead );
479cdf0e10cSrcweir         ZeroMemory(awcBuffer, sizeof(awcBuffer));
480cdf0e10cSrcweir         wmemcpy( awcBuffer, m_pwsBuffer.c_str() + m_ulUnicodeCharsRead, ulToCopy );
481cdf0e10cSrcweir         m_ulUnicodeCharsRead += ulToCopy;
482cdf0e10cSrcweir         *pcwcBuffer = ulToCopy;
483cdf0e10cSrcweir         if ( m_ulUnicodeBufferLen == m_ulUnicodeCharsRead )
484cdf0e10cSrcweir         {
485cdf0e10cSrcweir             m_ulUnicodeCharsRead = 0;
486cdf0e10cSrcweir             m_ulUnicodeBufferLen = 0;
487cdf0e10cSrcweir             return FILTER_S_LAST_TEXT;
488cdf0e10cSrcweir         }
489cdf0e10cSrcweir         return S_OK;
490cdf0e10cSrcweir     }
491cdf0e10cSrcweir     default:
492cdf0e10cSrcweir         return E_FAIL;
493cdf0e10cSrcweir     }
494cdf0e10cSrcweir }
495cdf0e10cSrcweir //M-------------------------------------------------------------------------
496cdf0e10cSrcweir //
497cdf0e10cSrcweir //  Method:     GetMetaInfoNameFromPropertyId
498cdf0e10cSrcweir //
499cdf0e10cSrcweir //  Summary:    helper function to convert PropertyID into respective
500cdf0e10cSrcweir //              MetaInfo names.
501cdf0e10cSrcweir //
502cdf0e10cSrcweir //  Arguments:  ulPropID
503cdf0e10cSrcweir //                  [in] property ID
504cdf0e10cSrcweir //
505cdf0e10cSrcweir //  Returns:    corresponding metainfo names.
506cdf0e10cSrcweir //
507cdf0e10cSrcweir //--------------------------------------------------------------------------
508cdf0e10cSrcweir 
GetMetaInfoNameFromPropertyId(ULONG ulPropID)509cdf0e10cSrcweir ::std::wstring GetMetaInfoNameFromPropertyId( ULONG ulPropID )
510cdf0e10cSrcweir {
511cdf0e10cSrcweir     switch ( ulPropID )
512cdf0e10cSrcweir     {
513cdf0e10cSrcweir         case PIDSI_AUTHOR:   return META_INFO_AUTHOR;
514cdf0e10cSrcweir         case PIDSI_TITLE:    return META_INFO_TITLE;
515cdf0e10cSrcweir         case PIDSI_SUBJECT:  return META_INFO_SUBJECT;
516cdf0e10cSrcweir         case PIDSI_KEYWORDS: return META_INFO_KEYWORDS;
517cdf0e10cSrcweir         case PIDSI_COMMENTS: return META_INFO_DESCRIPTION;
518cdf0e10cSrcweir         default:             return EMPTY_STRING;
519cdf0e10cSrcweir     }
520cdf0e10cSrcweir }
521cdf0e10cSrcweir //M-------------------------------------------------------------------------
522cdf0e10cSrcweir //
523cdf0e10cSrcweir //  Method:     COooFilter::GetValue            (IFilter::GetValue)
524cdf0e10cSrcweir //
525*fff73a02Smseidel //  Summary:    Retrieves properties for index
526cdf0e10cSrcweir //
527cdf0e10cSrcweir //  Arguments:  ppPropValue
528cdf0e10cSrcweir //                  [out] Address that receives pointer to property value
529cdf0e10cSrcweir //
530cdf0e10cSrcweir //  Returns:    FILTER_E_NO_VALUES
531cdf0e10cSrcweir //                  Always
532cdf0e10cSrcweir //              FILTER_E_NO_MORE_VALUES
533cdf0e10cSrcweir //                  (not implemented)
534cdf0e10cSrcweir //
535cdf0e10cSrcweir //--------------------------------------------------------------------------
536cdf0e10cSrcweir 
GetValue(PROPVARIANT ** ppPropValue)537cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetValue(PROPVARIANT ** ppPropValue)
538cdf0e10cSrcweir {
539cdf0e10cSrcweir     if (m_eState == FilteringContent)
540cdf0e10cSrcweir         return FILTER_E_NO_VALUES;
541cdf0e10cSrcweir     else if (m_eState == FilteringProperty)
542cdf0e10cSrcweir     {
543cdf0e10cSrcweir         if ( m_cAttributes == 0 || ( m_ulCurrentPropertyNum == m_ulPropertyNum ) )
544cdf0e10cSrcweir             return FILTER_E_NO_MORE_VALUES;
545cdf0e10cSrcweir         PROPVARIANT *pPropVar = (PROPVARIANT *) CoTaskMemAlloc( sizeof (PROPVARIANT) );
546cdf0e10cSrcweir         if ( pPropVar == 0 )
547cdf0e10cSrcweir             return E_OUTOFMEMORY;
548cdf0e10cSrcweir         ::std::wstring wsTagName= GetMetaInfoNameFromPropertyId( m_pAttributes[m_ulCurrentPropertyNum].GetPropertyPropid() );
549cdf0e10cSrcweir         if ( wsTagName == EMPTY_STRING )
550cdf0e10cSrcweir             return FILTER_E_NO_VALUES;
551cdf0e10cSrcweir         ::std::wstring wsTagData = m_pMetaInfoReader->getTagData(wsTagName);
552cdf0e10cSrcweir         pPropVar->vt = VT_LPWSTR;
553cdf0e10cSrcweir         size_t cw = wsTagData.length() + 1; // reserve one for the '\0'
554cdf0e10cSrcweir         pPropVar->pwszVal = static_cast<WCHAR*>( CoTaskMemAlloc(cw*sizeof(WCHAR)) );
555cdf0e10cSrcweir         if (pPropVar->pwszVal == 0)
556cdf0e10cSrcweir         {
557cdf0e10cSrcweir             CoTaskMemFree(pPropVar);
558cdf0e10cSrcweir             return E_OUTOFMEMORY;
559cdf0e10cSrcweir         }
560cdf0e10cSrcweir         wmemcpy(pPropVar->pwszVal, wsTagData.c_str(), cw);
561cdf0e10cSrcweir         *ppPropValue = pPropVar;
562cdf0e10cSrcweir         m_ulCurrentPropertyNum = m_ulPropertyNum;
563cdf0e10cSrcweir         return S_OK;
564cdf0e10cSrcweir     }
565cdf0e10cSrcweir     else
566cdf0e10cSrcweir         return E_FAIL;
567cdf0e10cSrcweir }
568cdf0e10cSrcweir //M-------------------------------------------------------------------------
569cdf0e10cSrcweir //
570cdf0e10cSrcweir //  Method:     COooFilter::BindRegion          (IFilter::BindRegion)
571cdf0e10cSrcweir //
572cdf0e10cSrcweir //  Summary:    Creates moniker or other interface for indicated text
573cdf0e10cSrcweir //
574cdf0e10cSrcweir //  Arguments:  origPos
575cdf0e10cSrcweir //                  [in] Description of text location and extent
576cdf0e10cSrcweir //              riid
577cdf0e10cSrcweir //                  [in] Reference IID of specified interface
578cdf0e10cSrcweir //              ppunk
579cdf0e10cSrcweir //                  [out] Address that receives requested interface pointer
580cdf0e10cSrcweir //
581cdf0e10cSrcweir //  Returns:    E_NOTIMPL
582cdf0e10cSrcweir //                  Always
583cdf0e10cSrcweir //              FILTER_W_REGION_CLIPPED
584cdf0e10cSrcweir //                  (not implemented)
585cdf0e10cSrcweir //
586cdf0e10cSrcweir //--------------------------------------------------------------------------
587cdf0e10cSrcweir 
BindRegion(FILTERREGION,REFIID,void **)588cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::BindRegion(
589cdf0e10cSrcweir     FILTERREGION /*origPos*/,
590cdf0e10cSrcweir     REFIID /*riid*/,
591cdf0e10cSrcweir     void ** /*ppunk*/)
592cdf0e10cSrcweir {
593cdf0e10cSrcweir     // BindRegion is currently reserved for future use
594cdf0e10cSrcweir     return E_NOTIMPL;
595cdf0e10cSrcweir }
596cdf0e10cSrcweir //M-------------------------------------------------------------------------
597cdf0e10cSrcweir //
598cdf0e10cSrcweir //  Method:     COooFilter::GetClassID          (IPersist::GetClassID)
599cdf0e10cSrcweir //
600cdf0e10cSrcweir //  Summary:    Retrieves the class id of the filter class
601cdf0e10cSrcweir //
602cdf0e10cSrcweir //  Arguments:  pClassID
603cdf0e10cSrcweir //                  [out] Pointer to the class ID of the filter
604cdf0e10cSrcweir //
605cdf0e10cSrcweir //  Returns:    S_OK
606cdf0e10cSrcweir //                  Always
607cdf0e10cSrcweir //              E_FAIL
608cdf0e10cSrcweir //                  (not implemented)
609cdf0e10cSrcweir //--------------------------------------------------------------------------
GetClassID(CLSID * pClassID)610cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetClassID(CLSID * pClassID)
611cdf0e10cSrcweir {
612cdf0e10cSrcweir     *pClassID = CLSID_COooFilter;
613cdf0e10cSrcweir     return S_OK;
614cdf0e10cSrcweir }
615cdf0e10cSrcweir //M-------------------------------------------------------------------------
616cdf0e10cSrcweir //
617cdf0e10cSrcweir //  Method:     COooFilter::IsDirty             (IPersistFile::IsDirty)
618cdf0e10cSrcweir //
619cdf0e10cSrcweir //  Summary:    Checks whether file has changed since last save
620cdf0e10cSrcweir //
621cdf0e10cSrcweir //  Arguments:  void
622cdf0e10cSrcweir //
623cdf0e10cSrcweir //  Returns:    S_FALSE
624cdf0e10cSrcweir //                  Always
625cdf0e10cSrcweir //              S_OK
626cdf0e10cSrcweir //                  (not implemented)
627cdf0e10cSrcweir //
628cdf0e10cSrcweir //--------------------------------------------------------------------------
IsDirty()629cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::IsDirty()
630cdf0e10cSrcweir {
631cdf0e10cSrcweir     // File is opened read-only and never changes
632cdf0e10cSrcweir     return S_FALSE;
633cdf0e10cSrcweir }
634cdf0e10cSrcweir //M-------------------------------------------------------------------------
635cdf0e10cSrcweir //
636cdf0e10cSrcweir //  Method:     COooFilter::Load                (IPersistFile::Load)
637cdf0e10cSrcweir //
638cdf0e10cSrcweir //  Summary:    Opens and initializes the specified file
639cdf0e10cSrcweir //
640cdf0e10cSrcweir //  Arguments:  pszFileName
641cdf0e10cSrcweir //                  [in] Pointer to zero-terminated string
642cdf0e10cSrcweir //                       of absolute path of file to open
643cdf0e10cSrcweir //              dwMode
644cdf0e10cSrcweir //                  [in] Access mode to open the file
645cdf0e10cSrcweir //
646cdf0e10cSrcweir //  Returns:    S_OK
647cdf0e10cSrcweir //                  File was successfully loaded
648cdf0e10cSrcweir //              E_OUTOFMEMORY
649cdf0e10cSrcweir //                  File could not be loaded due to insufficient memory
650cdf0e10cSrcweir //              E_FAIL
651cdf0e10cSrcweir //                  (not implemented)
652cdf0e10cSrcweir //
653cdf0e10cSrcweir //--------------------------------------------------------------------------
Load(LPCWSTR pszFileName,DWORD)654cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::Load(LPCWSTR pszFileName, DWORD /*dwMode*/)
655cdf0e10cSrcweir {
656cdf0e10cSrcweir     // Load just sets the filename for GetChunk to read and ignores the mode
657cdf0e10cSrcweir     m_pwszFileName = getShortPathName( pszFileName );
658cdf0e10cSrcweir 
659cdf0e10cSrcweir     // Open the file previously specified in call to IPersistFile::Load and get content.
660cdf0e10cSrcweir     try
661cdf0e10cSrcweir     {
662cdf0e10cSrcweir         if (m_pMetaInfoReader)
663cdf0e10cSrcweir             delete m_pMetaInfoReader;
664cdf0e10cSrcweir         m_pMetaInfoReader = new CMetaInfoReader(WStringToString(m_pwszFileName));
665cdf0e10cSrcweir 
666cdf0e10cSrcweir         if (m_pContentReader)
667cdf0e10cSrcweir     delete m_pContentReader;
668cdf0e10cSrcweir         m_pContentReader = new CContentReader(WStringToString(m_pwszFileName), m_pMetaInfoReader->getDefaultLocale());
669cdf0e10cSrcweir     }
670cdf0e10cSrcweir     catch (const std::exception&)
671cdf0e10cSrcweir     {
672cdf0e10cSrcweir         return E_FAIL;
673cdf0e10cSrcweir     }
674cdf0e10cSrcweir     return S_OK;
675cdf0e10cSrcweir }
676cdf0e10cSrcweir //M-------------------------------------------------------------------------
677cdf0e10cSrcweir //
678cdf0e10cSrcweir //  Method:     COooFilter::Save                (IPersistFile::Save)
679cdf0e10cSrcweir //
680cdf0e10cSrcweir //  Summary:    Saves a copy of the current file being filtered
681cdf0e10cSrcweir //
682cdf0e10cSrcweir //  Arguments:  pszFileName
683cdf0e10cSrcweir //                  [in] Pointer to zero-terminated string of
684cdf0e10cSrcweir //                       absolute path of where to save file
685cdf0e10cSrcweir //              fRemember
686cdf0e10cSrcweir //                  [in] Whether the saved copy is made the current file
687cdf0e10cSrcweir //
688cdf0e10cSrcweir //  Returns:    E_FAIL
689cdf0e10cSrcweir //                  Always
690cdf0e10cSrcweir //              S_OK
691cdf0e10cSrcweir //                  (not implemented)
692cdf0e10cSrcweir //
693cdf0e10cSrcweir //--------------------------------------------------------------------------
Save(LPCWSTR,BOOL)694cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::Save(LPCWSTR /*pszFileName*/, BOOL /*fRemember*/)
695cdf0e10cSrcweir {
696cdf0e10cSrcweir     // File is opened read-only; saving it is an error
697cdf0e10cSrcweir     return E_FAIL;
698cdf0e10cSrcweir }
699cdf0e10cSrcweir //M-------------------------------------------------------------------------
700cdf0e10cSrcweir //
701cdf0e10cSrcweir //  Method:     COooFilter::SaveCompleted      (IPersistFile::SaveCompleted)
702cdf0e10cSrcweir //
703cdf0e10cSrcweir //  Summary:    Determines whether a file save is completed
704cdf0e10cSrcweir //
705cdf0e10cSrcweir //  Arguments:  pszFileName
706cdf0e10cSrcweir //                  [in] Pointer to zero-terminated string of
707cdf0e10cSrcweir //                       absolute path where file was previously saved
708cdf0e10cSrcweir //
709cdf0e10cSrcweir //  Returns:    S_OK
710cdf0e10cSrcweir //                  Always
711cdf0e10cSrcweir //
712cdf0e10cSrcweir //--------------------------------------------------------------------------
SaveCompleted(LPCWSTR)713cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::SaveCompleted(LPCWSTR /*pszFileName*/)
714cdf0e10cSrcweir {
715cdf0e10cSrcweir     // File is opened read-only, so "save" is always finished
716cdf0e10cSrcweir     return S_OK;
717cdf0e10cSrcweir }
718cdf0e10cSrcweir 
719cdf0e10cSrcweir //M-------------------------------------------------------------------------
720cdf0e10cSrcweir //
721cdf0e10cSrcweir //  Method:     COooFilter::Load      (IPersistStream::Load)
722cdf0e10cSrcweir //
723cdf0e10cSrcweir //  Summary:    Initializes an object from the stream where it was previously saved
724cdf0e10cSrcweir //
725cdf0e10cSrcweir //  Arguments:  pStm
726cdf0e10cSrcweir //                  [in] Pointer to stream from which object should be loaded
727cdf0e10cSrcweir //
728cdf0e10cSrcweir //
729cdf0e10cSrcweir //  Returns:    S_OK
730cdf0e10cSrcweir //              E_OUTOFMEMORY
731cdf0e10cSrcweir //              E_FAIL
732cdf0e10cSrcweir //
733cdf0e10cSrcweir //
734cdf0e10cSrcweir //--------------------------------------------------------------------------
Load(IStream * pStm)735cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::Load(IStream *pStm)
736cdf0e10cSrcweir {
737cdf0e10cSrcweir     zlib_filefunc_def z_filefunc;
738cdf0e10cSrcweir 
739cdf0e10cSrcweir     m_pStream = PrepareIStream( pStm, z_filefunc );
740cdf0e10cSrcweir 
741cdf0e10cSrcweir     try
742cdf0e10cSrcweir     {
743cdf0e10cSrcweir         if (m_pMetaInfoReader)
744cdf0e10cSrcweir             delete m_pMetaInfoReader;
745cdf0e10cSrcweir         m_pMetaInfoReader = new CMetaInfoReader((void*)m_pStream, &z_filefunc);
746cdf0e10cSrcweir 
747cdf0e10cSrcweir         if (m_pContentReader)
748cdf0e10cSrcweir             delete m_pContentReader;
749cdf0e10cSrcweir         m_pContentReader = new CContentReader((void*)m_pStream, m_pMetaInfoReader->getDefaultLocale(), &z_filefunc);
750cdf0e10cSrcweir     }
751cdf0e10cSrcweir     catch (const std::exception&)
752cdf0e10cSrcweir     {
753cdf0e10cSrcweir         return E_FAIL;
754cdf0e10cSrcweir     }
755cdf0e10cSrcweir     return S_OK;
756cdf0e10cSrcweir }
757cdf0e10cSrcweir 
758cdf0e10cSrcweir //M-------------------------------------------------------------------------
759cdf0e10cSrcweir //
760cdf0e10cSrcweir //  Method:     COooFilter::GetSizeMax      (IPersistStream::GetSizeMax)
761cdf0e10cSrcweir //
762*fff73a02Smseidel //  Summary:    Returns the size in bytes of the stream needed to save the object.
763cdf0e10cSrcweir //
764cdf0e10cSrcweir //  Arguments:  pcbSize
765cdf0e10cSrcweir //                  [out] Pointer to a 64 bit unsigned int indicating the size needed
766cdf0e10cSrcweir //
767cdf0e10cSrcweir //  Returns:    E_NOTIMPL
768cdf0e10cSrcweir //
769cdf0e10cSrcweir //
770cdf0e10cSrcweir //--------------------------------------------------------------------------
GetSizeMax(ULARGE_INTEGER *)771cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetSizeMax(ULARGE_INTEGER * /*pcbSize*/)
772cdf0e10cSrcweir {
773cdf0e10cSrcweir     //
774cdf0e10cSrcweir     return E_NOTIMPL;
775cdf0e10cSrcweir }
776cdf0e10cSrcweir 
777cdf0e10cSrcweir //M-------------------------------------------------------------------------
778cdf0e10cSrcweir //
779cdf0e10cSrcweir //  Method:     COooFilter::Save      (IPersistStream::Save)
780cdf0e10cSrcweir //
781cdf0e10cSrcweir //  Summary:    Save object to specified stream
782cdf0e10cSrcweir //
783cdf0e10cSrcweir //  Arguments:  pStm
784cdf0e10cSrcweir //                  [in] Pointer to stream
785cdf0e10cSrcweir //
786cdf0e10cSrcweir //              fClearDirty
787cdf0e10cSrcweir //                  [in] Indicates whether to clear dirty flag
788cdf0e10cSrcweir //
789cdf0e10cSrcweir //  Returns:    E_NOTIMPL
790cdf0e10cSrcweir //
791cdf0e10cSrcweir //
792cdf0e10cSrcweir //--------------------------------------------------------------------------
Save(IStream *,BOOL)793cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::Save(IStream * /*pStm*/, BOOL )
794cdf0e10cSrcweir {
795cdf0e10cSrcweir     //
796cdf0e10cSrcweir     return E_NOTIMPL;
797cdf0e10cSrcweir }
798cdf0e10cSrcweir 
799cdf0e10cSrcweir //M-------------------------------------------------------------------------
800cdf0e10cSrcweir //
801cdf0e10cSrcweir //  Method:     COooFilter::GetCurFile          (IPersistFile::GetCurFile)
802cdf0e10cSrcweir //
803cdf0e10cSrcweir //  Summary:    Returns a copy of the current file name
804cdf0e10cSrcweir //
805cdf0e10cSrcweir //  Arguments:  ppszFileName
806cdf0e10cSrcweir //                  [out] Address to receive pointer to zero-terminated
807cdf0e10cSrcweir //                        string for absolute path to current file
808cdf0e10cSrcweir //
809cdf0e10cSrcweir //  Returns:    S_OK
810cdf0e10cSrcweir //                  A valid absolute path was successfully returned
811cdf0e10cSrcweir //              S_FALSE
812cdf0e10cSrcweir //                  (not implemented)
813cdf0e10cSrcweir //              E_OUTOFMEMORY
814cdf0e10cSrcweir //                  Operation failed due to insufficient memory
815cdf0e10cSrcweir //              E_FAIL
816cdf0e10cSrcweir //                  Operation failed due to some reason
817cdf0e10cSrcweir //                  other than insufficient memory
818cdf0e10cSrcweir //
819cdf0e10cSrcweir //-------------------------------------------------------------------------
GetCurFile(LPWSTR * ppszFileName)820cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilter::GetCurFile(LPWSTR * ppszFileName)
821cdf0e10cSrcweir {
822cdf0e10cSrcweir     if ( EMPTY_STRING == m_pwszFileName )
823cdf0e10cSrcweir         return E_FAIL;
824cdf0e10cSrcweir     else
825cdf0e10cSrcweir         *ppszFileName = (LPWSTR)m_pwszFileName.c_str();
826cdf0e10cSrcweir     return S_OK;
827cdf0e10cSrcweir }
828cdf0e10cSrcweir 
829cdf0e10cSrcweir //M-------------------------------------------------------------------------
830cdf0e10cSrcweir //
831cdf0e10cSrcweir //  Method:     COooFilterCF::COooFilterCF
832cdf0e10cSrcweir //
833cdf0e10cSrcweir //  Summary:    Class factory constructor
834cdf0e10cSrcweir //
835cdf0e10cSrcweir //  Arguments:  void
836cdf0e10cSrcweir //
837cdf0e10cSrcweir //  Purpose:    Manages global instance count
838cdf0e10cSrcweir //
839cdf0e10cSrcweir //--------------------------------------------------------------------------
COooFilterCF()840cdf0e10cSrcweir COooFilterCF::COooFilterCF() :
841cdf0e10cSrcweir     m_lRefs(1)
842cdf0e10cSrcweir {
843cdf0e10cSrcweir     InterlockedIncrement( &g_lInstances );
844cdf0e10cSrcweir }
845cdf0e10cSrcweir //M-------------------------------------------------------------------------
846cdf0e10cSrcweir //
847cdf0e10cSrcweir //  Method:     COooFilterCF::~COooFilterCF
848cdf0e10cSrcweir //
849cdf0e10cSrcweir //  Summary:    Class factory destructor
850cdf0e10cSrcweir //
851cdf0e10cSrcweir //  Arguments:  void
852cdf0e10cSrcweir //
853cdf0e10cSrcweir //  Purpose:    Manages global instance count
854cdf0e10cSrcweir //
855cdf0e10cSrcweir //--------------------------------------------------------------------------
~COooFilterCF()856cdf0e10cSrcweir COooFilterCF::~COooFilterCF()
857cdf0e10cSrcweir {
858cdf0e10cSrcweir     InterlockedDecrement( &g_lInstances );
859cdf0e10cSrcweir }
860cdf0e10cSrcweir //M-------------------------------------------------------------------------
861cdf0e10cSrcweir //
862cdf0e10cSrcweir //  Method:     COooFilterCF::QueryInterface    (IUnknown::QueryInterface)
863cdf0e10cSrcweir //
864cdf0e10cSrcweir //  Summary:    Queries for requested interface
865cdf0e10cSrcweir //
866cdf0e10cSrcweir //  Arguments:  riid
867cdf0e10cSrcweir //                  [in] Reference IID of requested interface
868cdf0e10cSrcweir //              ppvObject
869cdf0e10cSrcweir //                  [out] Address that receives requested interface pointer
870cdf0e10cSrcweir //
871cdf0e10cSrcweir //  Returns:    S_OK
872cdf0e10cSrcweir //                  Interface is supported
873cdf0e10cSrcweir //              E_NOINTERFACE
874cdf0e10cSrcweir //                  Interface is not supported
875cdf0e10cSrcweir //
876cdf0e10cSrcweir //--------------------------------------------------------------------------
QueryInterface(REFIID riid,void ** ppvObject)877cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilterCF::QueryInterface(REFIID riid, void  ** ppvObject)
878cdf0e10cSrcweir {
879cdf0e10cSrcweir     IUnknown *pUnkTemp;
880cdf0e10cSrcweir 
881cdf0e10cSrcweir     if ( IID_IClassFactory == riid )
882cdf0e10cSrcweir         pUnkTemp = (IUnknown *)(IClassFactory *)this;
883cdf0e10cSrcweir     else if ( IID_IUnknown == riid )
884cdf0e10cSrcweir         pUnkTemp = (IUnknown *)this;
885cdf0e10cSrcweir     else
886cdf0e10cSrcweir     {
887cdf0e10cSrcweir         *ppvObject = NULL;
888cdf0e10cSrcweir         return E_NOINTERFACE;
889cdf0e10cSrcweir     }
890cdf0e10cSrcweir     *ppvObject = (void  *)pUnkTemp;
891cdf0e10cSrcweir     pUnkTemp->AddRef();
892cdf0e10cSrcweir     return S_OK;
893cdf0e10cSrcweir }
894cdf0e10cSrcweir //M-------------------------------------------------------------------------
895cdf0e10cSrcweir //
896*fff73a02Smseidel //  Method:     COooFilterCF::AddRef            (IUnknown::AddRef)
897cdf0e10cSrcweir //
898cdf0e10cSrcweir //  Summary:    Increments interface refcount
899cdf0e10cSrcweir //
900cdf0e10cSrcweir //  Arguments:  void
901cdf0e10cSrcweir //
902cdf0e10cSrcweir //  Returns:    Value of incremented interface refcount
903cdf0e10cSrcweir //
904cdf0e10cSrcweir //-------------------------------------------------------------------------
AddRef()905cdf0e10cSrcweir ULONG STDMETHODCALLTYPE COooFilterCF::AddRef()
906cdf0e10cSrcweir {
907cdf0e10cSrcweir     return InterlockedIncrement( &m_lRefs );
908cdf0e10cSrcweir }
909cdf0e10cSrcweir //M-------------------------------------------------------------------------
910cdf0e10cSrcweir //
911cdf0e10cSrcweir //  Method:     COooFilterCF::Release           (IUnknown::Release)
912cdf0e10cSrcweir //
913cdf0e10cSrcweir //  Summary:    Decrements interface refcount, deleting if unreferenced
914cdf0e10cSrcweir //
915cdf0e10cSrcweir //  Arguments:  void
916cdf0e10cSrcweir //
917cdf0e10cSrcweir //  Returns:    Value of decremented refcount
918cdf0e10cSrcweir //
919cdf0e10cSrcweir //--------------------------------------------------------------------------
Release()920cdf0e10cSrcweir ULONG STDMETHODCALLTYPE COooFilterCF::Release()
921cdf0e10cSrcweir {
922cdf0e10cSrcweir     ULONG ulTmp = InterlockedDecrement( &m_lRefs );
923cdf0e10cSrcweir 
924cdf0e10cSrcweir     if ( 0 == ulTmp )
925cdf0e10cSrcweir         delete this;
926cdf0e10cSrcweir     return ulTmp;
927cdf0e10cSrcweir }
928cdf0e10cSrcweir //M-------------------------------------------------------------------------
929cdf0e10cSrcweir //
930cdf0e10cSrcweir //  Method:     COooFilterCF::CreateInstance (IClassFactory::CreateInstance)
931cdf0e10cSrcweir //
932*fff73a02Smseidel //  Summary:    Creates new OpenOffice filter object
933cdf0e10cSrcweir //
934cdf0e10cSrcweir //  Arguments:  pUnkOuter
935cdf0e10cSrcweir //                  [in] Pointer to IUnknown interface of aggregating object
936cdf0e10cSrcweir //              riid
937cdf0e10cSrcweir //                  [in] Reference IID of requested interface
938cdf0e10cSrcweir //              ppvObject
939cdf0e10cSrcweir //                  [out] Address that receives requested interface pointer
940cdf0e10cSrcweir //
941cdf0e10cSrcweir //  Returns:    S_OK
942*fff73a02Smseidel //                  OpenOffice filter object was successfully created
943cdf0e10cSrcweir //              CLASS_E_NOAGGREGATION
944cdf0e10cSrcweir //                  pUnkOuter parameter was non-NULL
945cdf0e10cSrcweir //              E_NOINTERFACE
946cdf0e10cSrcweir //                  (not implemented)
947cdf0e10cSrcweir //              E_OUTOFMEMORY
948*fff73a02Smseidel //                  OpenOffice filter object could not be created
949cdf0e10cSrcweir //                  due to insufficient memory
950cdf0e10cSrcweir //              E_UNEXPECTED
951cdf0e10cSrcweir //                  Unsuccessful due to an unexpected condition
952cdf0e10cSrcweir //
953cdf0e10cSrcweir //--------------------------------------------------------------------------
CreateInstance(IUnknown * pUnkOuter,REFIID riid,void ** ppvObject)954cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilterCF::CreateInstance(
955cdf0e10cSrcweir     IUnknown * pUnkOuter,
956cdf0e10cSrcweir     REFIID riid,
957cdf0e10cSrcweir     void  * * ppvObject)
958cdf0e10cSrcweir {
959cdf0e10cSrcweir     COooFilter *pIUnk = 0;
960cdf0e10cSrcweir     if ( 0 != pUnkOuter )
961cdf0e10cSrcweir         return CLASS_E_NOAGGREGATION;
962cdf0e10cSrcweir     pIUnk = new COooFilter();
963cdf0e10cSrcweir     if ( 0 != pIUnk )
964cdf0e10cSrcweir     {
965cdf0e10cSrcweir         if ( SUCCEEDED( pIUnk->QueryInterface( riid , ppvObject ) ) )
966cdf0e10cSrcweir         {
967cdf0e10cSrcweir             // Release extra refcount from QueryInterface
968cdf0e10cSrcweir             pIUnk->Release();
969cdf0e10cSrcweir         }
970cdf0e10cSrcweir         else
971cdf0e10cSrcweir         {
972cdf0e10cSrcweir             delete pIUnk;
973cdf0e10cSrcweir             return E_UNEXPECTED;
974cdf0e10cSrcweir         }
975cdf0e10cSrcweir     }
976cdf0e10cSrcweir     else
977cdf0e10cSrcweir         return E_OUTOFMEMORY;
978cdf0e10cSrcweir     return S_OK;
979cdf0e10cSrcweir }
980cdf0e10cSrcweir 
981cdf0e10cSrcweir //M-------------------------------------------------------------------------
982cdf0e10cSrcweir //
983cdf0e10cSrcweir //  Method:     COooFilterCF::LockServer        (IClassFactory::LockServer)
984cdf0e10cSrcweir //
985cdf0e10cSrcweir //  Summary:    Forces/allows filter class to remain loaded/be unloaded
986cdf0e10cSrcweir //
987cdf0e10cSrcweir //  Arguments:  fLock
988cdf0e10cSrcweir //                  [in] TRUE to lock, FALSE to unlock
989cdf0e10cSrcweir //
990cdf0e10cSrcweir //  Returns:    S_OK
991cdf0e10cSrcweir //                  Always
992cdf0e10cSrcweir //              E_FAIL
993cdf0e10cSrcweir //                  (not implemented)
994cdf0e10cSrcweir //              E_OUTOFMEMORY
995cdf0e10cSrcweir //                  (not implemented)
996cdf0e10cSrcweir //              E_UNEXPECTED
997cdf0e10cSrcweir //                  (not implemented)
998cdf0e10cSrcweir //
999cdf0e10cSrcweir //--------------------------------------------------------------------------
LockServer(BOOL fLock)1000cdf0e10cSrcweir SCODE STDMETHODCALLTYPE COooFilterCF::LockServer(BOOL fLock)
1001cdf0e10cSrcweir {
1002cdf0e10cSrcweir     if( fLock )
1003cdf0e10cSrcweir         InterlockedIncrement( &g_lInstances );
1004cdf0e10cSrcweir     else
1005cdf0e10cSrcweir         InterlockedDecrement( &g_lInstances );
1006cdf0e10cSrcweir     return S_OK;
1007cdf0e10cSrcweir }
1008cdf0e10cSrcweir //+-------------------------------------------------------------------------
1009cdf0e10cSrcweir //
1010cdf0e10cSrcweir //  DLL:        ooofilt.dll
1011cdf0e10cSrcweir //
1012*fff73a02Smseidel //  Summary:    Implements Dynamic Link Library functions for OpenOffice filter
1013cdf0e10cSrcweir //
1014cdf0e10cSrcweir //--------------------------------------------------------------------------
1015cdf0e10cSrcweir //F-------------------------------------------------------------------------
1016cdf0e10cSrcweir //
1017cdf0e10cSrcweir //  Function:   DllMain
1018cdf0e10cSrcweir //
1019cdf0e10cSrcweir //  Summary:    Called from C-Runtime on process/thread attach/detach
1020cdf0e10cSrcweir //
1021cdf0e10cSrcweir //  Arguments:  hInstance
1022cdf0e10cSrcweir //                  [in] Handle to the DLL
1023cdf0e10cSrcweir //              fdwReason
1024cdf0e10cSrcweir //                  [in] Reason for calling DLL entry point
1025cdf0e10cSrcweir //              lpReserve
1026cdf0e10cSrcweir //                  [in] Details of DLL initialization and cleanup
1027cdf0e10cSrcweir //
1028cdf0e10cSrcweir //  Returns:    TRUE
1029cdf0e10cSrcweir //                  Always
1030cdf0e10cSrcweir //
1031cdf0e10cSrcweir //--------------------------------------------------------------------------
DllMain(HINSTANCE hInstance,DWORD fdwReason,LPVOID)1032cdf0e10cSrcweir extern "C" BOOL WINAPI DllMain(
1033cdf0e10cSrcweir     HINSTANCE hInstance,
1034cdf0e10cSrcweir     DWORD     fdwReason,
1035cdf0e10cSrcweir     LPVOID    /*lpvReserved*/
1036cdf0e10cSrcweir )
1037cdf0e10cSrcweir {
1038cdf0e10cSrcweir     if ( DLL_PROCESS_ATTACH == fdwReason )
1039cdf0e10cSrcweir         DisableThreadLibraryCalls( hInstance );
1040cdf0e10cSrcweir     return TRUE;
1041cdf0e10cSrcweir }
1042cdf0e10cSrcweir //F-------------------------------------------------------------------------
1043cdf0e10cSrcweir //
1044cdf0e10cSrcweir //  Function:   DllGetClassObject
1045cdf0e10cSrcweir //
1046*fff73a02Smseidel //  Summary:    Create OpenOffice filter class factory object
1047cdf0e10cSrcweir //
1048cdf0e10cSrcweir //  Arguments:  cid
1049cdf0e10cSrcweir //                  [in] Class ID of class that class factory creates
1050cdf0e10cSrcweir //              iid
1051cdf0e10cSrcweir //                  [in] Reference IID of requested class factory interface
1052cdf0e10cSrcweir //              ppvObj
1053cdf0e10cSrcweir //                  [out] Address that receives requested interface pointer
1054cdf0e10cSrcweir //
1055cdf0e10cSrcweir //  Returns:    S_OK
1056cdf0e10cSrcweir //                  Class factory object was created successfully
1057cdf0e10cSrcweir //              CLASS_E_CLASSNOTAVAILABLE
1058cdf0e10cSrcweir //                  DLL does not support the requested class
1059cdf0e10cSrcweir //              E_INVALIDARG
1060cdf0e10cSrcweir //                  (not implemented
1061cdf0e10cSrcweir //              E_OUTOFMEMORY
1062cdf0e10cSrcweir //                  Insufficient memory to create the class factory object
1063cdf0e10cSrcweir //              E_UNEXPECTED
1064cdf0e10cSrcweir //                  Unsuccessful due to an unexpected condition
1065cdf0e10cSrcweir //
1066cdf0e10cSrcweir //-------------------------------------------------------------------------
DllGetClassObject(REFCLSID cid,REFIID iid,void ** ppvObj)1067cdf0e10cSrcweir extern "C" SCODE STDMETHODCALLTYPE DllGetClassObject(
1068cdf0e10cSrcweir     REFCLSID   cid,
1069cdf0e10cSrcweir     REFIID     iid,
1070cdf0e10cSrcweir     void **    ppvObj
1071cdf0e10cSrcweir )
1072cdf0e10cSrcweir {
1073cdf0e10cSrcweir     IUnknown *pResult = 0;
1074cdf0e10cSrcweir 
1075cdf0e10cSrcweir     if ( CLSID_COooFilter == cid )
1076cdf0e10cSrcweir         pResult = (IUnknown *) new COooFilterCF;
1077cdf0e10cSrcweir     else
1078cdf0e10cSrcweir         return CLASS_E_CLASSNOTAVAILABLE;
1079cdf0e10cSrcweir     if ( 0 != pResult )
1080cdf0e10cSrcweir     {
1081cdf0e10cSrcweir         if( SUCCEEDED( pResult->QueryInterface( iid, ppvObj ) ) )
1082cdf0e10cSrcweir             // Release extra refcount from QueryInterface
1083cdf0e10cSrcweir             pResult->Release();
1084cdf0e10cSrcweir         else
1085cdf0e10cSrcweir         {
1086cdf0e10cSrcweir             delete pResult;
1087cdf0e10cSrcweir             return E_UNEXPECTED;
1088cdf0e10cSrcweir         }
1089cdf0e10cSrcweir     }
1090cdf0e10cSrcweir     else
1091cdf0e10cSrcweir         return E_OUTOFMEMORY;
1092cdf0e10cSrcweir     return S_OK;
1093cdf0e10cSrcweir }
1094cdf0e10cSrcweir //F-------------------------------------------------------------------------
1095cdf0e10cSrcweir //
1096cdf0e10cSrcweir //  Function:   DllCanUnloadNow
1097cdf0e10cSrcweir //
1098cdf0e10cSrcweir //  Summary:    Indicates whether it is possible to unload DLL
1099cdf0e10cSrcweir //
1100cdf0e10cSrcweir //  Arguments:  void
1101cdf0e10cSrcweir //
1102cdf0e10cSrcweir //  Returns:    S_OK
1103cdf0e10cSrcweir //                  DLL can be unloaded now
1104cdf0e10cSrcweir //              S_FALSE
1105cdf0e10cSrcweir //                  DLL must remain loaded
1106cdf0e10cSrcweir //
1107cdf0e10cSrcweir //--------------------------------------------------------------------------
DllCanUnloadNow()1108cdf0e10cSrcweir extern "C" SCODE STDMETHODCALLTYPE DllCanUnloadNow()
1109cdf0e10cSrcweir {
1110cdf0e10cSrcweir     if ( 0 >= g_lInstances )
1111cdf0e10cSrcweir         return S_OK;
1112cdf0e10cSrcweir     else
1113cdf0e10cSrcweir         return S_FALSE;
1114cdf0e10cSrcweir }
1115cdf0e10cSrcweir //F-------------------------------------------------------------------------
1116cdf0e10cSrcweir //
1117cdf0e10cSrcweir //  Function:   DllRegisterServer
1118cdf0e10cSrcweir //              DllUnregisterServer
1119cdf0e10cSrcweir //
1120cdf0e10cSrcweir //  Summary:    Registers and unregisters DLL server
1121cdf0e10cSrcweir //
1122cdf0e10cSrcweir //  Returns:    DllRegisterServer
1123cdf0e10cSrcweir //                  S_OK
1124cdf0e10cSrcweir //                      Registration was successful
1125cdf0e10cSrcweir //                  SELFREG_E_CLASS
1126cdf0e10cSrcweir //                      Registration was unsuccessful
1127cdf0e10cSrcweir //                  SELFREG_E_TYPELIB
1128cdf0e10cSrcweir //                      (not implemented)
1129cdf0e10cSrcweir //                  E_OUTOFMEMORY
1130cdf0e10cSrcweir //                      (not implemented)
1131cdf0e10cSrcweir //                  E_UNEXPECTED
1132cdf0e10cSrcweir //                      (not implemented)
1133cdf0e10cSrcweir //              DllUnregisterServer
1134cdf0e10cSrcweir //                  S_OK
1135cdf0e10cSrcweir //                      Unregistration was successful
1136cdf0e10cSrcweir //                  S_FALSE
1137cdf0e10cSrcweir //                      Unregistration was successful, but other
1138cdf0e10cSrcweir //                      entries still exist for the DLL's classes
1139cdf0e10cSrcweir //                  SELFREG_E_CLASS
1140cdf0e10cSrcweir //                      (not implemented)
1141cdf0e10cSrcweir //                  SELFREG_E_TYPELIB
1142cdf0e10cSrcweir //                      (not implemented)
1143cdf0e10cSrcweir //                  E_OUTOFMEMORY
1144cdf0e10cSrcweir //                      (not implemented)
1145cdf0e10cSrcweir //                  E_UNEXPECTED
1146cdf0e10cSrcweir //                      (not implemented)
1147cdf0e10cSrcweir //
1148cdf0e10cSrcweir //--------------------------------------------------------------------------
1149cdf0e10cSrcweir 
1150cdf0e10cSrcweir 
1151cdf0e10cSrcweir //F-------------------------------------------------------------------------
1152cdf0e10cSrcweir //
1153cdf0e10cSrcweir //  helper functions to register the Indexing Service.
1154cdf0e10cSrcweir //
1155cdf0e10cSrcweir //--------------------------------------------------------------------------
1156cdf0e10cSrcweir 
1157cdf0e10cSrcweir namespace /* private */
1158cdf0e10cSrcweir {
1159cdf0e10cSrcweir     const char* GUID_PLACEHOLDER         = "{GUID}";
1160cdf0e10cSrcweir     const char* GUID_PERSIST_PLACEHOLDER = "{GUIDPERSIST}";
1161cdf0e10cSrcweir     const char* EXTENSION_PLACEHOLDER    = "{EXT}";
1162cdf0e10cSrcweir     const char* FORWARDKEY_PLACEHOLDER   = "{FWDKEY}";
1163cdf0e10cSrcweir 
1164cdf0e10cSrcweir     const char* CLSID_GUID_INPROC_ENTRY             = "CLSID\\{GUID}\\InProcServer32";
1165cdf0e10cSrcweir     const char* CLSID_GUID_ENTRY                    = "CLSID\\{GUID}";
1166cdf0e10cSrcweir     const char* CLSID_GUID_PERSIST_ADDIN_ENTRY      = "CLSID\\{GUID}\\PersistentAddinsRegistered\\{GUIDPERSIST}";
1167cdf0e10cSrcweir     const char* CLSID_PERSIST_ENTRY                 = "CLSID\\{GUID}\\PersistentHandler";
1168cdf0e10cSrcweir     const char* EXT_PERSIST_ENTRY                   = "{EXT}\\PersistentHandler";
1169cdf0e10cSrcweir 
1170cdf0e10cSrcweir     const char* INDEXING_FILTER_DLLSTOREGISTER      = "SYSTEM\\CurrentControlSet\\Control\\ContentIndex";
1171cdf0e10cSrcweir 
1172cdf0e10cSrcweir     //---------------------------
1173cdf0e10cSrcweir     // "String Placeholder" ->
1174cdf0e10cSrcweir     // "String Replacement"
1175cdf0e10cSrcweir     //---------------------------
1176cdf0e10cSrcweir 
SubstitutePlaceholder(std::string & String,const std::string & Placeholder,const std::string & Replacement)1177cdf0e10cSrcweir     void SubstitutePlaceholder(std::string& String, const std::string& Placeholder, const std::string& Replacement)
1178cdf0e10cSrcweir     {
1179cdf0e10cSrcweir         std::string::size_type idx = String.find(Placeholder);
1180cdf0e10cSrcweir         std::string::size_type len = Placeholder.length();
1181cdf0e10cSrcweir 
1182cdf0e10cSrcweir         while (std::string::npos != idx)
1183cdf0e10cSrcweir         {
1184cdf0e10cSrcweir             String.replace(idx, len, Replacement);
1185cdf0e10cSrcweir             idx = String.find(Placeholder);
1186cdf0e10cSrcweir         }
1187cdf0e10cSrcweir     }
1188cdf0e10cSrcweir 
1189cdf0e10cSrcweir     //----------------------------------------------
1190cdf0e10cSrcweir     // Make the registry entry and set Filter Handler
1191*fff73a02Smseidel     // HKCR\CLSID\{7BC0E710-5703-45be-A29D-5D46D8B39262} = OpenDocument Format Filter
1192*fff73a02Smseidel     //                              InProcServer32 (x86) = Path\ooofilt.dll
1193*fff73a02Smseidel     //                              InProcServer32 (x64) = Path\ooofilt_x64.dll
1194cdf0e10cSrcweir     //                                    ThreadingModel = Both
1195cdf0e10cSrcweir     //----------------------------------------------
1196cdf0e10cSrcweir 
RegisterFilterHandler(const char * FilePath,const CLSID & FilterGuid)1197cdf0e10cSrcweir     HRESULT RegisterFilterHandler(const char* FilePath, const CLSID& FilterGuid)
1198cdf0e10cSrcweir     {
1199cdf0e10cSrcweir         std::string ClsidEntry = CLSID_GUID_ENTRY;
1200cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry, GUID_PLACEHOLDER, ClsidToString(FilterGuid));
1201cdf0e10cSrcweir 
1202*fff73a02Smseidel         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry.c_str(), "", "OpenDocument Format Filter"))
1203cdf0e10cSrcweir             return E_FAIL;
1204cdf0e10cSrcweir 
1205cdf0e10cSrcweir         ClsidEntry = CLSID_GUID_INPROC_ENTRY;
1206cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry, GUID_PLACEHOLDER, ClsidToString(FilterGuid));
1207cdf0e10cSrcweir 
1208cdf0e10cSrcweir         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry.c_str(), "", FilePath))
1209cdf0e10cSrcweir             return E_FAIL;
1210cdf0e10cSrcweir 
1211cdf0e10cSrcweir         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry.c_str(), "ThreadingModel", "Both"))
1212cdf0e10cSrcweir             return E_FAIL;
1213cdf0e10cSrcweir 
1214cdf0e10cSrcweir         return S_OK;
1215cdf0e10cSrcweir     }
1216cdf0e10cSrcweir 
1217cdf0e10cSrcweir     //----------------------------------------------
1218cdf0e10cSrcweir     // Make the registry entry and set Persistent Handler
1219*fff73a02Smseidel     // HKCR\CLSID\{7BC0E713-5703-45be-A29D-5D46D8B39262} = OpenDocument Format Persistent Handler
1220cdf0e10cSrcweir     //      PersistentAddinsRegistered
1221cdf0e10cSrcweir     //            {89BCB740-6119-101A-BCB7-00DD010655AF} = {7BC0E710-5703-45be-A29D-5D46D8B39262}
1222cdf0e10cSrcweir     //----------------------------------------------
1223cdf0e10cSrcweir 
RegisterPersistentHandler(const CLSID & FilterGuid,const CLSID & PersistentGuid)1224cdf0e10cSrcweir     HRESULT RegisterPersistentHandler(const CLSID& FilterGuid, const CLSID& PersistentGuid)
1225cdf0e10cSrcweir     {
1226cdf0e10cSrcweir         std::string ClsidEntry_Persist = CLSID_GUID_ENTRY;
1227cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry_Persist, GUID_PLACEHOLDER, ClsidToString(PersistentGuid));
1228cdf0e10cSrcweir 
1229cdf0e10cSrcweir 
1230*fff73a02Smseidel         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry_Persist.c_str(), "", "OpenDocument Format Persistent Handler"))
1231cdf0e10cSrcweir             return E_FAIL;
1232cdf0e10cSrcweir 
1233cdf0e10cSrcweir         // Add missing entry
1234cdf0e10cSrcweir         std::string ClsidEntry_Persist_Entry = CLSID_PERSIST_ENTRY;
1235cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry_Persist_Entry,
1236cdf0e10cSrcweir                               GUID_PLACEHOLDER,
1237cdf0e10cSrcweir                               ClsidToString(PersistentGuid));
1238cdf0e10cSrcweir 
1239cdf0e10cSrcweir         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry_Persist_Entry.c_str(), "", ClsidToString(PersistentGuid).c_str()))
1240cdf0e10cSrcweir             return E_FAIL;
1241cdf0e10cSrcweir 
1242cdf0e10cSrcweir         std::string ClsidEntry_Persist_Addin = CLSID_GUID_PERSIST_ADDIN_ENTRY;
1243cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry_Persist_Addin,
1244cdf0e10cSrcweir                               GUID_PLACEHOLDER,
1245cdf0e10cSrcweir                               ClsidToString(PersistentGuid));
1246cdf0e10cSrcweir         SubstitutePlaceholder(ClsidEntry_Persist_Addin,
1247cdf0e10cSrcweir                               GUID_PERSIST_PLACEHOLDER,
1248cdf0e10cSrcweir                               ClsidToString(CLSID_PERSISTENT_HANDLER_ADDIN));
1249cdf0e10cSrcweir 
1250cdf0e10cSrcweir         if (!SetRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry_Persist_Addin.c_str(), "", ClsidToString(FilterGuid).c_str() ))
1251cdf0e10cSrcweir             return E_FAIL;
1252cdf0e10cSrcweir 
1253cdf0e10cSrcweir         return S_OK;
1254cdf0e10cSrcweir     }
1255cdf0e10cSrcweir 
1256cdf0e10cSrcweir     //---------------------------
1257cdf0e10cSrcweir     // Unregister Filter Handler or persistent handler
1258cdf0e10cSrcweir     //---------------------------
1259cdf0e10cSrcweir 
UnregisterHandler(const CLSID & Guid)1260cdf0e10cSrcweir     HRESULT UnregisterHandler(const CLSID& Guid)
1261cdf0e10cSrcweir     {
1262cdf0e10cSrcweir         std::string tmp = "CLSID\\";
1263cdf0e10cSrcweir         tmp += ClsidToString(Guid);
1264cdf0e10cSrcweir         return DeleteRegistryKey(HKEY_CLASSES_ROOT, tmp.c_str()) ? S_OK : E_FAIL;
1265cdf0e10cSrcweir     }
1266cdf0e10cSrcweir 
1267cdf0e10cSrcweir     //---------------------------
1268cdf0e10cSrcweir     // Register Indexing Service ext and class.
1269cdf0e10cSrcweir     // HKCR\{EXT}\PersistentHandler = {7BC0E713-5703-45be-A29D-5D46D8B39262}
1270cdf0e10cSrcweir     // HKCR\{GUID\PersistentHandler = {7BC0E713-5703-45be-A29D-5D46D8B39262}
1271cdf0e10cSrcweir     //---------------------------
1272cdf0e10cSrcweir 
RegisterSearchHandler(const char * ModuleFileName)1273cdf0e10cSrcweir     HRESULT RegisterSearchHandler(const char* ModuleFileName)
1274cdf0e10cSrcweir     {
1275cdf0e10cSrcweir         if (FAILED(RegisterFilterHandler(ModuleFileName, CLSID_FILTER_HANDLER)))
1276cdf0e10cSrcweir             return E_FAIL;
1277cdf0e10cSrcweir 
1278cdf0e10cSrcweir         if (FAILED(RegisterPersistentHandler(CLSID_FILTER_HANDLER, CLSID_PERSISTENT_HANDLER )))
1279cdf0e10cSrcweir             return E_FAIL;
1280cdf0e10cSrcweir 
1281cdf0e10cSrcweir         std::string sExtPersistEntry;
1282cdf0e10cSrcweir 
1283cdf0e10cSrcweir         for(size_t i = 0; i < OOFileExtensionTableSize; i++)
1284cdf0e10cSrcweir         {
1285cdf0e10cSrcweir             // first, register extension.
1286cdf0e10cSrcweir             sExtPersistEntry = EXT_PERSIST_ENTRY;
1287cdf0e10cSrcweir             SubstitutePlaceholder(sExtPersistEntry, EXTENSION_PLACEHOLDER, OOFileExtensionTable[i].ExtensionAnsi);
1288cdf0e10cSrcweir             if (!SetRegistryKey(HKEY_CLASSES_ROOT,
1289cdf0e10cSrcweir                                 sExtPersistEntry.c_str(),
1290cdf0e10cSrcweir                                 "",
1291cdf0e10cSrcweir                                 ClsidToString(CLSID_PERSISTENT_HANDLER).c_str()))
1292cdf0e10cSrcweir                 return E_FAIL;
1293cdf0e10cSrcweir 
1294cdf0e10cSrcweir             // second, register class.
1295cdf0e10cSrcweir             char extClassName[MAX_PATH];
1296cdf0e10cSrcweir             if (QueryRegistryKey(HKEY_CLASSES_ROOT, OOFileExtensionTable[i].ExtensionAnsi, "", extClassName,MAX_PATH))
1297cdf0e10cSrcweir             {
1298cdf0e10cSrcweir                 ::std::string extCLSIDName( extClassName );
1299cdf0e10cSrcweir                 extCLSIDName += "\\CLSID";
1300cdf0e10cSrcweir                 char extCLSID[MAX_PATH];
1301cdf0e10cSrcweir 
1302cdf0e10cSrcweir                 if (QueryRegistryKey( HKEY_CLASSES_ROOT, extCLSIDName.c_str(), "", extCLSID, MAX_PATH))
1303cdf0e10cSrcweir                 {
1304cdf0e10cSrcweir                     std::string ClsidEntry_CLSID_Persist = CLSID_PERSIST_ENTRY;
1305cdf0e10cSrcweir                     SubstitutePlaceholder(ClsidEntry_CLSID_Persist,
1306cdf0e10cSrcweir                                         GUID_PLACEHOLDER,
1307cdf0e10cSrcweir                                         extCLSID);
1308cdf0e10cSrcweir 
1309cdf0e10cSrcweir                     if (!SetRegistryKey(HKEY_CLASSES_ROOT,
1310cdf0e10cSrcweir                                         ClsidEntry_CLSID_Persist.c_str(),
1311cdf0e10cSrcweir                                         "",
1312cdf0e10cSrcweir                                         ClsidToString(CLSID_PERSISTENT_HANDLER).c_str() ))
1313cdf0e10cSrcweir                         return E_FAIL;
1314cdf0e10cSrcweir                 }
1315cdf0e10cSrcweir             }
1316cdf0e10cSrcweir         }
1317cdf0e10cSrcweir 
1318cdf0e10cSrcweir         return S_OK;
1319cdf0e10cSrcweir     }
1320cdf0e10cSrcweir 
1321cdf0e10cSrcweir     // Register Indexing Service ext and class.
UnregisterSearchHandler()1322cdf0e10cSrcweir     HRESULT UnregisterSearchHandler()
1323cdf0e10cSrcweir     {
1324cdf0e10cSrcweir         std::string sExtPersistEntry;
1325cdf0e10cSrcweir 
1326cdf0e10cSrcweir         for (size_t i = 0; i < OOFileExtensionTableSize; i++)
1327cdf0e10cSrcweir         {
1328cdf0e10cSrcweir             // first, unregister extension
1329cdf0e10cSrcweir             sExtPersistEntry = EXT_PERSIST_ENTRY;
1330cdf0e10cSrcweir             SubstitutePlaceholder(sExtPersistEntry, EXTENSION_PLACEHOLDER, OOFileExtensionTable[i].ExtensionAnsi);
1331cdf0e10cSrcweir             DeleteRegistryKey(HKEY_CLASSES_ROOT, sExtPersistEntry.c_str());
1332cdf0e10cSrcweir 
1333cdf0e10cSrcweir             // second, unregister class
1334cdf0e10cSrcweir             char extClassName[MAX_PATH];
1335cdf0e10cSrcweir             if (QueryRegistryKey(HKEY_CLASSES_ROOT, OOFileExtensionTable[i].ExtensionAnsi, "", extClassName,MAX_PATH))
1336cdf0e10cSrcweir             {
1337cdf0e10cSrcweir                 ::std::string extCLSIDName( extClassName );
1338cdf0e10cSrcweir                 extCLSIDName += "\\CLSID";
1339cdf0e10cSrcweir                 char extCLSID[MAX_PATH];
1340cdf0e10cSrcweir 
1341cdf0e10cSrcweir                 if (QueryRegistryKey( HKEY_CLASSES_ROOT, extCLSIDName.c_str(), "", extCLSID, MAX_PATH))
1342cdf0e10cSrcweir                 {
1343cdf0e10cSrcweir                     std::string ClsidEntry_CLSID_Persist = CLSID_PERSIST_ENTRY;
1344cdf0e10cSrcweir                     SubstitutePlaceholder(ClsidEntry_CLSID_Persist,
1345cdf0e10cSrcweir                                         GUID_PLACEHOLDER,
1346cdf0e10cSrcweir                                         extCLSID);
1347cdf0e10cSrcweir 
1348cdf0e10cSrcweir                     DeleteRegistryKey(HKEY_CLASSES_ROOT, ClsidEntry_CLSID_Persist.c_str());
1349cdf0e10cSrcweir                 }
1350cdf0e10cSrcweir             }
1351cdf0e10cSrcweir         }
1352cdf0e10cSrcweir 
1353cdf0e10cSrcweir         return ((UnregisterHandler(CLSID_FILTER_HANDLER)==S_OK) && (UnregisterHandler(CLSID_PERSISTENT_HANDLER)==S_OK))?S_OK:E_FAIL;
1354cdf0e10cSrcweir     }
1355cdf0e10cSrcweir 
1356cdf0e10cSrcweir     //---------------------------
1357cdf0e10cSrcweir     //    add or remove an entry to DllsToRegister entry of Indexing
1358cdf0e10cSrcweir     //    Filter to let Indexing Service register our filter automatically
1359cdf0e10cSrcweir     //    each time.
1360cdf0e10cSrcweir     //---------------------------
AddOrRemoveDllsToRegisterList(const::std::string & DllPath,bool isAdd)1361cdf0e10cSrcweir     HRESULT AddOrRemoveDllsToRegisterList( const ::std::string & DllPath, bool isAdd )
1362cdf0e10cSrcweir     {
1363cdf0e10cSrcweir         char DllsToRegisterList[4096];
1364cdf0e10cSrcweir         if (QueryRegistryKey(HKEY_LOCAL_MACHINE,
1365cdf0e10cSrcweir                              INDEXING_FILTER_DLLSTOREGISTER,
1366cdf0e10cSrcweir                              "DLLsToRegister",
1367cdf0e10cSrcweir                              DllsToRegisterList,
1368cdf0e10cSrcweir                              4096))
1369cdf0e10cSrcweir         {
1370cdf0e10cSrcweir             char * pChar = DllsToRegisterList;
1371cdf0e10cSrcweir             for ( ; *pChar != '\0' || *(pChar +1) != '\0'; pChar++)
1372cdf0e10cSrcweir                 if ( *pChar == '\0')
1373cdf0e10cSrcweir                     *pChar = ';';
1374cdf0e10cSrcweir             *pChar = ';';
1375cdf0e10cSrcweir             *(pChar+1) = '\0';
1376cdf0e10cSrcweir 
1377cdf0e10cSrcweir             ::std::string DllList(DllsToRegisterList);
1378cdf0e10cSrcweir             if ( ( isAdd )&&( DllList.find( DllPath ) == ::std::string::npos ) )
1379cdf0e10cSrcweir                 DllList.append( DllPath );
1380cdf0e10cSrcweir             else if ( ( !isAdd )&&( DllList.find( DllPath ) != ::std::string::npos ) )
1381cdf0e10cSrcweir                 DllList.erase( DllList.find( DllPath )-1, DllPath.length()+1 );
1382cdf0e10cSrcweir             else
1383cdf0e10cSrcweir                 return S_OK;
1384cdf0e10cSrcweir 
1385cdf0e10cSrcweir             pChar = DllsToRegisterList;
1386cdf0e10cSrcweir             for ( size_t nChar = 0; nChar < DllList.length(); pChar++,nChar++)
1387cdf0e10cSrcweir             {
1388cdf0e10cSrcweir                 if ( DllList[nChar] == ';')
1389cdf0e10cSrcweir                     *pChar = '\0';
1390cdf0e10cSrcweir                 else
1391cdf0e10cSrcweir                     *pChar = DllList[nChar];
1392cdf0e10cSrcweir             }
1393cdf0e10cSrcweir             *pChar = *( pChar+1 ) ='\0';
1394cdf0e10cSrcweir 
1395cdf0e10cSrcweir             HKEY hSubKey;
1396cdf0e10cSrcweir             int rc = RegCreateKeyExA(HKEY_LOCAL_MACHINE,
1397cdf0e10cSrcweir                                     INDEXING_FILTER_DLLSTOREGISTER,
1398cdf0e10cSrcweir                                     0,
1399cdf0e10cSrcweir                                     "",
1400cdf0e10cSrcweir                                     REG_OPTION_NON_VOLATILE,
1401cdf0e10cSrcweir                                     KEY_WRITE,
1402cdf0e10cSrcweir                                     0,
1403cdf0e10cSrcweir                                     &hSubKey,
1404cdf0e10cSrcweir                                     0);
1405cdf0e10cSrcweir 
1406cdf0e10cSrcweir             if (ERROR_SUCCESS == rc)
1407cdf0e10cSrcweir             {
1408cdf0e10cSrcweir                 rc = RegSetValueExA( hSubKey,
1409cdf0e10cSrcweir                                     "DLLsToRegister",
1410cdf0e10cSrcweir                                     0,
1411cdf0e10cSrcweir                                     REG_MULTI_SZ,
1412cdf0e10cSrcweir                                     reinterpret_cast<const BYTE*>(DllsToRegisterList),
1413cdf0e10cSrcweir                                     DllList.length() + 2);
1414cdf0e10cSrcweir 
1415cdf0e10cSrcweir                 RegCloseKey(hSubKey);
1416cdf0e10cSrcweir             }
1417cdf0e10cSrcweir 
1418cdf0e10cSrcweir             return (ERROR_SUCCESS == rc)?S_OK:E_FAIL;
1419cdf0e10cSrcweir         }
1420cdf0e10cSrcweir 
1421cdf0e10cSrcweir         return S_OK;
1422cdf0e10cSrcweir     }
1423cdf0e10cSrcweir 
1424cdf0e10cSrcweir } // namespace /* private */
1425cdf0e10cSrcweir 
DllRegisterServer()1426cdf0e10cSrcweir STDAPI DllRegisterServer()
1427cdf0e10cSrcweir {
1428cdf0e10cSrcweir     /*
1429cdf0e10cSrcweir     TCHAR ModuleFileName[MAX_PATH];
1430cdf0e10cSrcweir 
1431cdf0e10cSrcweir     GetModuleFileName(
1432cdf0e10cSrcweir         GetModuleHandle(MODULE_NAME_FILTER),
1433cdf0e10cSrcweir         ModuleFileName,
1434cdf0e10cSrcweir         sizeof(ModuleFileName));
1435cdf0e10cSrcweir 
1436cdf0e10cSrcweir     HRESULT hr = S_OK;
1437cdf0e10cSrcweir 
1438cdf0e10cSrcweir 
1439cdf0e10cSrcweir // register search handler
1440cdf0e10cSrcweir #ifdef UNICODE
1441cdf0e10cSrcweir     if (FAILED(RegisterSearchHandler(WStringToString(ModuleFileName).c_str())))
1442cdf0e10cSrcweir         hr = E_FAIL;
1443cdf0e10cSrcweir     if (FAILED(AddOrRemoveDllsToRegisterList(WStringToString(ModuleFileName).c_str(), true)))
1444cdf0e10cSrcweir         hr = E_FAIL;
1445cdf0e10cSrcweir #else
1446cdf0e10cSrcweir     if (FAILED(RegisterSearchHandler(ModuleFileName)))
1447cdf0e10cSrcweir         hr = E_FAIL;
1448cdf0e10cSrcweir     if (FAILED(AddOrRemoveDllsToRegisterList(ModuleFileName, true)))
1449cdf0e10cSrcweir         hr = E_FAIL;
1450cdf0e10cSrcweir #endif
1451cdf0e10cSrcweir 
1452cdf0e10cSrcweir 
1453cdf0e10cSrcweir     return hr;
1454cdf0e10cSrcweir     */
1455cdf0e10cSrcweir     return S_OK;
1456cdf0e10cSrcweir }
1457cdf0e10cSrcweir 
1458cdf0e10cSrcweir //---------------------------
1459cdf0e10cSrcweir //
1460cdf0e10cSrcweir //---------------------------
1461cdf0e10cSrcweir 
DllUnregisterServer()1462cdf0e10cSrcweir STDAPI DllUnregisterServer()
1463cdf0e10cSrcweir {
1464cdf0e10cSrcweir     /*
1465cdf0e10cSrcweir     TCHAR ModuleFileName[MAX_PATH];
1466cdf0e10cSrcweir 
1467cdf0e10cSrcweir     GetModuleFileName(
1468cdf0e10cSrcweir         GetModuleHandle(MODULE_NAME_FILTER),
1469cdf0e10cSrcweir         ModuleFileName,
1470cdf0e10cSrcweir         sizeof(ModuleFileName));
1471cdf0e10cSrcweir 
1472cdf0e10cSrcweir     HRESULT hr = S_OK;
1473cdf0e10cSrcweir 
1474cdf0e10cSrcweir     // unregister search handler
1475cdf0e10cSrcweir     if (FAILED(UnregisterSearchHandler()))
1476cdf0e10cSrcweir         hr = E_FAIL;
1477cdf0e10cSrcweir 
1478cdf0e10cSrcweir #ifdef UNICODE
1479cdf0e10cSrcweir     if (FAILED(AddOrRemoveDllsToRegisterList(WStringToString(ModuleFileName).c_str(),false)))
1480cdf0e10cSrcweir         hr = E_FAIL;
1481cdf0e10cSrcweir #else
1482cdf0e10cSrcweir     if (FAILED(AddOrRemoveDllsToRegisterList(ModuleFileName, false)))
1483cdf0e10cSrcweir         hr = E_FAIL;
1484cdf0e10cSrcweir #endif
1485cdf0e10cSrcweir 
1486cdf0e10cSrcweir     return hr;
1487cdf0e10cSrcweir     */
1488cdf0e10cSrcweir     return S_OK;
1489cdf0e10cSrcweir }
1490*fff73a02Smseidel 
1491*fff73a02Smseidel /* vim: set noet sw=4 ts=4: */
1492