diff options
Diffstat (limited to 'ucb/source/ucp/tdoc/tdoc_uri.hxx')
-rw-r--r-- | ucb/source/ucp/tdoc/tdoc_uri.hxx | 131 |
1 files changed, 131 insertions, 0 deletions
diff --git a/ucb/source/ucp/tdoc/tdoc_uri.hxx b/ucb/source/ucp/tdoc/tdoc_uri.hxx new file mode 100644 index 000000000000..5f251cc55bee --- /dev/null +++ b/ucb/source/ucp/tdoc/tdoc_uri.hxx @@ -0,0 +1,131 @@ +/************************************************************************* + * + * 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 INCLUDED_TDOC_URI_HXX +#define INCLUDED_TDOC_URI_HXX + +#include "rtl/ustring.hxx" + +namespace tdoc_ucp { + +//========================================================================= + +#define TDOC_URL_SCHEME "vnd.sun.star.tdoc" +#define TDOC_URL_SCHEME_LENGTH 17 + +//========================================================================= + +class Uri +{ + enum State { UNKNOWN, INVALID, VALID }; + + mutable ::rtl::OUString m_aUri; + mutable ::rtl::OUString m_aParentUri; + mutable ::rtl::OUString m_aPath; + mutable ::rtl::OUString m_aDocId; + mutable ::rtl::OUString m_aInternalPath; + mutable ::rtl::OUString m_aName; + mutable ::rtl::OUString m_aDecodedName; + mutable State m_eState; + +private: + void init() const; + +public: + Uri() : m_eState( UNKNOWN ) {} + Uri( const ::rtl::OUString & rUri ) + : m_aUri( rUri ), m_eState( UNKNOWN ) {} + + bool operator== ( const Uri & rOther ) const + { init(); return m_aUri == rOther.m_aUri; } + + bool operator!= ( const Uri & rOther ) const + { return !operator==( rOther ); } + + sal_Bool isValid() const + { init(); return m_eState == VALID; } + + const ::rtl::OUString & getUri() const + { init(); return m_aUri; } + + inline void setUri( const ::rtl::OUString & rUri ); + + const ::rtl::OUString & getParentUri() const + { init(); return m_aParentUri; } + + const ::rtl::OUString & getPath() const + { init(); return m_aPath; } + + const ::rtl::OUString & getDocumentId() const + { init(); return m_aDocId; } + + const ::rtl::OUString & getInternalPath() const + { init(); return m_aInternalPath; } + + const ::rtl::OUString & getName() const + { init(); return m_aName; } + + const ::rtl::OUString & getDecodedName() const + { init(); return m_aDecodedName; } + + inline sal_Bool isRoot() const; + + inline sal_Bool isDocument() const; + + inline sal_Bool isFolder() const; +}; + +inline void Uri::setUri( const ::rtl::OUString & rUri ) +{ + m_eState = UNKNOWN; + m_aUri = rUri; + m_aParentUri = m_aDocId = m_aInternalPath = m_aPath = m_aName + = m_aDecodedName = rtl::OUString(); +} + +inline sal_Bool Uri::isRoot() const +{ + init(); + return ( m_aPath.getLength() == 1 ); +} + +inline sal_Bool Uri::isDocument() const +{ + init(); + return ( ( m_aDocId.getLength() > 0 ) /* not root */ + && ( m_aPath.copy( m_aDocId.getLength() + 1 ).getLength() < 2 ) ); +} + +inline sal_Bool Uri::isFolder() const +{ + init(); + return ( m_aPath.lastIndexOf( '/' ) == m_aPath.getLength() - 1 ); +} + +} // namespace tdoc_ucp + +#endif /* !INCLUDED_TDOC_URI_HXX */ |