1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SVTOOLS_SOURCE_CONTNR_CONTENTENUMERATION_HXX
21 #define INCLUDED_SVTOOLS_SOURCE_CONTNR_CONTENTENUMERATION_HXX
23 #include <com/sun/star/ucb/XCommandEnvironment.hpp>
24 #include <com/sun/star/document/XDocumentProperties.hpp>
25 #include <salhelper/thread.hxx>
26 #include <ucbhelper/content.hxx>
27 #include <rtl/ustring.hxx>
28 #include <tools/datetime.hxx>
29 #include <vcl/image.hxx>
31 //........................................................................
34 //........................................................................
36 //====================================================================
38 //====================================================================
39 struct SortingData_Impl
42 OUString maFilename
; // only filename in upper case - for compare purposes
43 OUString maTitle
; // -> be carefull when changing maTitle to update maFilename only when new
44 OUString maLowerTitle
;
51 OUString maDisplayText
;
58 sal_Bool mbIsRemoveable
;
60 sal_Bool mbIsCompactDisc
;
62 inline SortingData_Impl();
63 inline const OUString
& GetTitle() const;
64 inline const OUString
& GetLowerTitle() const;
65 inline const OUString
& GetFileName() const;
66 inline void SetNewTitle( const OUString
& rNewTitle
); // new maTitle is set -> maFilename is set to same!
67 inline void ChangeTitle( const OUString
& rChangedTitle
); // maTitle is changed, maFilename is unchanged!
70 inline void SetTitles( const OUString
& rNewTitle
);
73 inline SortingData_Impl::SortingData_Impl() :
74 maModDate ( DateTime::EMPTY
),
76 mbIsFolder ( sal_False
),
77 mbIsVolume ( sal_False
),
78 mbIsRemote ( sal_False
),
79 mbIsRemoveable ( sal_False
),
80 mbIsFloppy ( sal_False
),
81 mbIsCompactDisc ( sal_False
)
85 inline const OUString
& SortingData_Impl::GetTitle() const
90 inline const OUString
& SortingData_Impl::GetLowerTitle() const
95 inline const OUString
& SortingData_Impl::GetFileName() const
100 inline void SortingData_Impl::SetNewTitle( const OUString
& rNewTitle
)
102 SetTitles( rNewTitle
);
103 maFilename
= rNewTitle
.toAsciiUpperCase();
106 inline void SortingData_Impl::ChangeTitle( const OUString
& rChangedTitle
)
108 SetTitles( rChangedTitle
);
111 inline void SortingData_Impl::SetTitles( const OUString
& rNewTitle
)
114 maLowerTitle
= rNewTitle
.toAsciiLowerCase();
117 //====================================================================
118 //= IContentTitleTranslation
119 //====================================================================
120 class IContentTitleTranslation
123 virtual sal_Bool
GetTranslation( const OUString
& _rOriginalName
, OUString
& _rTranslatedName
) const = 0;
126 ~IContentTitleTranslation() {}
129 //====================================================================
130 //= EnumerationResult
131 //====================================================================
132 enum EnumerationResult
134 SUCCESS
, /// the enumeration was successful
135 ERROR
, /// the enumeration was unsuccessful
136 RUNNING
/// the enumeration is still running, and the maximum wait time has passed
139 //====================================================================
141 //====================================================================
142 struct FolderDescriptor
144 /** a content object describing the folder. Can be <NULL/>, in this case <member>sURL</member>
147 ::ucbhelper::Content aContent
;
148 /** the URL of a folder. Will be ignored if <member>aContent</member> is not <NULL/>.
152 FolderDescriptor() { }
154 FolderDescriptor( const ::ucbhelper::Content
& _rContent
)
155 :aContent( _rContent
)
159 FolderDescriptor( const OUString
& _rURL
)
165 //====================================================================
166 //= IEnumerationResultHandler
167 //====================================================================
168 class IEnumerationResultHandler
171 virtual void enumerationDone( EnumerationResult _eResult
) = 0;
174 ~IEnumerationResultHandler() {}
177 //====================================================================
178 //= FileViewContentEnumerator
179 //====================================================================
180 class FileViewContentEnumerator
: public salhelper::Thread
183 typedef ::std::vector
< SortingData_Impl
* > ContentData
;
186 ContentData
& m_rContent
;
187 ::osl::Mutex
& m_rContentMutex
;
189 mutable ::osl::Mutex m_aMutex
;
191 FolderDescriptor m_aFolder
;
192 ::com::sun::star::uno::Reference
< ::com::sun::star::ucb::XCommandEnvironment
>
194 const IContentTitleTranslation
* m_pTranslator
;
195 IEnumerationResultHandler
* m_pResultHandler
;
198 mutable ::com::sun::star::uno::Reference
<
199 ::com::sun::star::document::XDocumentProperties
>
202 ::com::sun::star::uno::Sequence
< OUString
> m_rBlackList
;
204 sal_Bool
URLOnBlackList ( const OUString
& sRealURL
);
207 /** constructs an enumerator instance
209 @param _rContentToFill
210 the structure which is to be filled with the found content
211 @param _rContentMutex
212 the mutex which protects the access to <arg>_rContentToFill</arg>
214 an instance which should be used to translate content titles. May be <NULL/>
216 FileViewContentEnumerator(
217 const ::com::sun::star::uno::Reference
< ::com::sun::star::ucb::XCommandEnvironment
>& _rxCommandEnv
,
218 ContentData
& _rContentToFill
,
219 ::osl::Mutex
& _rContentMutex
,
220 const IContentTitleTranslation
* _pTranslator
223 /** enumerates the content of a given folder
226 the folder whose content is to be enumerated
228 a filter to apply to the found contents
229 @param _pResultHandler
230 an instance which should handle the results of the enumeration
232 void enumerateFolderContent(
233 const FolderDescriptor
& _rFolder
,
234 IEnumerationResultHandler
* _pResultHandler
237 /** enumerates the content of a given folder synchronously
239 EnumerationResult
enumerateFolderContentSync(
240 const FolderDescriptor
& _rFolder
,
241 const ::com::sun::star::uno::Sequence
< OUString
>& rBlackList
= ::com::sun::star::uno::Sequence
< OUString
>()
244 /** cancels the running operation.
246 Note that "cancel" may mean that the operation is running, but its result
247 is simply disregarded later on.
252 ~FileViewContentEnumerator();
255 EnumerationResult
enumerateFolderContent();
257 // Thread overridables
258 virtual void execute();
261 sal_Bool
implGetDocTitle( const OUString
& _rTargetURL
, OUString
& _rRet
) const;
264 //........................................................................
266 //........................................................................
268 #endif // INCLUDED_SVTOOLS_SOURCE_CONTNR_CONTENTENUMERATION_HXX
270 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */