update credits
[LibreOffice.git] / svtools / source / contnr / contentenumeration.hxx
blob95da38a71bfec5fd0132e02dcf9a894deb64df00
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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 SVTOOLS_SOURCE_CONTNR_CONTENTENUMERATION_HXX
21 #define 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 <tools/string.hxx>
30 #include <vcl/image.hxx>
32 //........................................................................
33 namespace svt
35 //........................................................................
37 //====================================================================
38 //= SortingData_Impl
39 //====================================================================
40 struct SortingData_Impl
42 private:
43 OUString maFilename; // only filename in upper case - for compare purposes
44 OUString maTitle; // -> be carefull when changing maTitle to update maFilename only when new
45 OUString maLowerTitle;
48 public:
49 OUString maType;
50 OUString maTargetURL;
51 OUString maImageURL;
52 OUString maDisplayText;
53 DateTime maModDate;
54 Image maImage;
55 sal_Int64 maSize;
56 sal_Bool mbIsFolder;
57 sal_Bool mbIsVolume;
58 sal_Bool mbIsRemote;
59 sal_Bool mbIsRemoveable;
60 sal_Bool mbIsFloppy;
61 sal_Bool mbIsCompactDisc;
63 inline SortingData_Impl();
64 inline const OUString& GetTitle() const;
65 inline const OUString& GetLowerTitle() const;
66 inline const OUString& GetFileName() const;
67 inline void SetNewTitle( const OUString& rNewTitle ); // new maTitle is set -> maFilename is set to same!
68 inline void ChangeTitle( const OUString& rChangedTitle ); // maTitle is changed, maFilename is unchanged!
70 private:
71 inline void SetTitles( const OUString& rNewTitle );
74 inline SortingData_Impl::SortingData_Impl() :
75 maModDate ( DateTime::EMPTY ),
76 maSize ( 0 ),
77 mbIsFolder ( sal_False ),
78 mbIsVolume ( sal_False ),
79 mbIsRemote ( sal_False ),
80 mbIsRemoveable ( sal_False ),
81 mbIsFloppy ( sal_False ),
82 mbIsCompactDisc ( sal_False )
86 inline const OUString& SortingData_Impl::GetTitle() const
88 return maTitle;
91 inline const OUString& SortingData_Impl::GetLowerTitle() const
93 return maLowerTitle;
96 inline const OUString& SortingData_Impl::GetFileName() const
98 return maFilename;
101 inline void SortingData_Impl::SetNewTitle( const OUString& rNewTitle )
103 SetTitles( rNewTitle );
104 maFilename = rNewTitle.toAsciiUpperCase();
107 inline void SortingData_Impl::ChangeTitle( const OUString& rChangedTitle )
109 SetTitles( rChangedTitle );
112 inline void SortingData_Impl::SetTitles( const OUString& rNewTitle )
114 maTitle = rNewTitle;
115 maLowerTitle = rNewTitle.toAsciiLowerCase();
118 //====================================================================
119 //= IContentTitleTranslation
120 //====================================================================
121 class IContentTitleTranslation
123 public:
124 virtual sal_Bool GetTranslation( const OUString& _rOriginalName, OUString& _rTranslatedName ) const = 0;
126 protected:
127 ~IContentTitleTranslation() {}
130 //====================================================================
131 //= EnumerationResult
132 //====================================================================
133 enum EnumerationResult
135 SUCCESS, /// the enumeration was successful
136 ERROR, /// the enumeration was unsuccessful
137 RUNNING /// the enumeration is still running, and the maximum wait time has passed
140 //====================================================================
141 //= FolderDescriptor
142 //====================================================================
143 struct FolderDescriptor
145 /** a content object describing the folder. Can be <NULL/>, in this case <member>sURL</member>
146 is relevant.
148 ::ucbhelper::Content aContent;
149 /** the URL of a folder. Will be ignored if <member>aContent</member> is not <NULL/>.
151 String sURL;
153 FolderDescriptor() { }
155 FolderDescriptor( const ::ucbhelper::Content& _rContent )
156 :aContent( _rContent )
160 FolderDescriptor( const String& _rURL )
161 :sURL( _rURL )
166 //====================================================================
167 //= IEnumerationResultHandler
168 //====================================================================
169 class IEnumerationResultHandler
171 public:
172 virtual void enumerationDone( EnumerationResult _eResult ) = 0;
174 protected:
175 ~IEnumerationResultHandler() {}
178 //====================================================================
179 //= FileViewContentEnumerator
180 //====================================================================
181 class FileViewContentEnumerator: public salhelper::Thread
183 public:
184 typedef ::std::vector< SortingData_Impl* > ContentData;
186 private:
187 ContentData& m_rContent;
188 ::osl::Mutex& m_rContentMutex;
190 mutable ::osl::Mutex m_aMutex;
192 FolderDescriptor m_aFolder;
193 ::com::sun::star::uno::Reference< ::com::sun::star::ucb::XCommandEnvironment >
194 m_xCommandEnv;
195 const IContentTitleTranslation* m_pTranslator;
196 IEnumerationResultHandler* m_pResultHandler;
197 bool m_bCancelled;
199 mutable ::com::sun::star::uno::Reference<
200 ::com::sun::star::document::XDocumentProperties>
201 m_xDocProps;
203 ::com::sun::star::uno::Sequence< OUString > m_rBlackList;
205 sal_Bool URLOnBlackList ( const OUString& sRealURL );
207 public:
208 /** constructs an enumerator instance
210 @param _rContentToFill
211 the structure which is to be filled with the found content
212 @param _rContentMutex
213 the mutex which protects the access to <arg>_rContentToFill</arg>
214 @param _pTranslator
215 an instance which should be used to translate content titles. May be <NULL/>
217 FileViewContentEnumerator(
218 const ::com::sun::star::uno::Reference< ::com::sun::star::ucb::XCommandEnvironment >& _rxCommandEnv,
219 ContentData& _rContentToFill,
220 ::osl::Mutex& _rContentMutex,
221 const IContentTitleTranslation* _pTranslator
224 /** enumerates the content of a given folder
226 @param _rFolder
227 the folder whose content is to be enumerated
228 @param _pFilter
229 a filter to apply to the found contents
230 @param _pResultHandler
231 an instance which should handle the results of the enumeration
233 void enumerateFolderContent(
234 const FolderDescriptor& _rFolder,
235 IEnumerationResultHandler* _pResultHandler
238 /** enumerates the content of a given folder synchronously
240 EnumerationResult enumerateFolderContentSync(
241 const FolderDescriptor& _rFolder,
242 const ::com::sun::star::uno::Sequence< OUString >& rBlackList = ::com::sun::star::uno::Sequence< OUString >()
245 /** cancels the running operation.
247 Note that "cancel" may mean that the operation is running, but its result
248 is simply disregarded later on.
250 void cancel();
252 protected:
253 ~FileViewContentEnumerator();
255 private:
256 EnumerationResult enumerateFolderContent();
258 // Thread overridables
259 virtual void execute();
261 private:
262 sal_Bool implGetDocTitle( const OUString& _rTargetURL, OUString& _rRet ) const;
265 //........................................................................
266 } // namespace svt
267 //........................................................................
269 #endif // SVTOOLS_SOURCE_CONTNR_CONTENTENUMERATION_HXX
271 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */