1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef ODMA_CONTENTPROPS_HXX
#define ODMA_CONTENTPROPS_HXX
#include "rtl/ref.hxx"
#include "salhelper/simplereferenceobject.hxx"
#include <rtl/ustring.hxx>
#include <com/sun/star/util/DateTime.hpp>
#include <functional>
namespace odma
{
class ContentProperties : public salhelper::SimpleReferenceObject
{
public:
com::sun::star::util::DateTime m_aDateCreated; // when was the document created
com::sun::star::util::DateTime m_aDateModified; // when was the document last modified
::rtl::OUString m_sTitle; // Title
::rtl::OUString m_sContentType; // ContentType
::rtl::OString m_sDocumentId; // the document id given from the DMS
::rtl::OUString m_sDocumentName;// document name
::rtl::OUString m_sFileURL; // the temporary file location
::rtl::OUString m_sAuthor; // the Author of the document
::rtl::OUString m_sSubject; // the subject of the document
::rtl::OUString m_sKeywords; // the keywords of the document
::rtl::OUString m_sSavedAsName; // the name which was used to save it
sal_Bool m_bIsDocument; // IsDocument
sal_Bool m_bIsFolder; // IsFolder
sal_Bool m_bIsOpen; // is true when OpenDoc was called
sal_Bool m_bIsReadOnly; // true when the document is read-only
// @@@ Add other properties supported by your content.
ContentProperties()
:m_bIsDocument( sal_True )
,m_bIsFolder( sal_False )
,m_bIsOpen( sal_False )
,m_bIsReadOnly( sal_False )
{}
inline ::rtl::OUString getTitle() const { return m_sTitle; }
inline ::rtl::OUString getDocumentId() const { return ::rtl::OStringToOUString( m_sDocumentId, RTL_TEXTENCODING_ASCII_US ); }
inline ::rtl::OUString getSavedAsName() const { return m_sSavedAsName; }
};
typedef ::std::binary_function< ::rtl::Reference<ContentProperties>, ::rtl::OUString,bool> TContentPropertiesFunctorBase;
/// binary_function Functor object for class ContentProperties return type is bool
class ContentPropertiesMemberFunctor : public TContentPropertiesFunctorBase
{
::std::const_mem_fun_t< ::rtl::OUString,ContentProperties> m_aFunction;
public:
ContentPropertiesMemberFunctor(const ::std::const_mem_fun_t< ::rtl::OUString,ContentProperties>& _rFunc)
: m_aFunction(_rFunc){}
inline bool operator()(const ::rtl::Reference<ContentProperties>& lhs,const ::rtl::OUString& rhs) const
{
return !!(m_aFunction(lhs.get()) == rhs);
}
};
}
#endif // ODMA_CONTENTPROPS_HXX
|