summaryrefslogtreecommitdiff
path: root/framework/inc/queries.h
diff options
context:
space:
mode:
Diffstat (limited to 'framework/inc/queries.h')
-rw-r--r--framework/inc/queries.h402
1 files changed, 402 insertions, 0 deletions
diff --git a/framework/inc/queries.h b/framework/inc/queries.h
new file mode 100644
index 000000000000..b8d122118abf
--- /dev/null
+++ b/framework/inc/queries.h
@@ -0,0 +1,402 @@
+/*************************************************************************
+ *
+ * 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 __FRAMEWORK_QUERIES_H_
+#define __FRAMEWORK_QUERIES_H_
+
+//_________________________________________________________________________________________________________________
+// own includes
+//_________________________________________________________________________________________________________________
+
+#include <general.h>
+
+//_________________________________________________________________________________________________________________
+// other includes
+//_________________________________________________________________________________________________________________
+#include <com/sun/star/uno/Sequence.hxx>
+#include <rtl/ustring.hxx>
+#include <rtl/ustrbuf.hxx>
+
+//_________________________________________________________________________________________________________________
+// namespace
+//_________________________________________________________________________________________________________________
+
+namespace framework{
+
+//_________________________________________________________________________________________________________________
+// const
+//_________________________________________________________________________________________________________________
+
+/*-************************************************************************************************************//**
+ @short These values describe our supported queries for type, filter ... properties.
+ They are used by our FilterFactory or ouer TypeDetection to return
+ subsets of our cached configuration.
+*//*-*************************************************************************************************************/
+#define BASE_QUERY_ALL DECLARE_ASCII("_query_all" )
+#define BASE_QUERY_WRITER DECLARE_ASCII("_query_Writer" )
+#define BASE_QUERY_WEB DECLARE_ASCII("_query_web" )
+#define BASE_QUERY_GLOBAL DECLARE_ASCII("_query_global" )
+#define BASE_QUERY_CHART DECLARE_ASCII("_query_chart" )
+#define BASE_QUERY_CALC DECLARE_ASCII("_query_calc" )
+#define BASE_QUERY_IMPRESS DECLARE_ASCII("_query_impress" )
+#define BASE_QUERY_DRAW DECLARE_ASCII("_query_draw" )
+#define BASE_QUERY_MATH DECLARE_ASCII("_query_math" )
+#define BASE_QUERY_GRAPHICS DECLARE_ASCII("_query_graphics")
+
+/*-************************************************************************************************************//**
+ @short These parameters can be used in combination with BASE_QUERY_... defines to
+ specialize it.
+ use follow syntax to do so: "<query>[:<param>[=<value>]]"
+ e.g.: "_query_writer:default_first:use_order:sort_prop=uiname"
+
+ argument description default
+ -----------------------------------------------------------------------------------------------
+ iflags=<mask> include filters by given mask 0
+ eflags=<mask> exclude filters by given mask 0
+ sort_prop=<[name,uiname]> sort by internal name or uiname name
+ descending sort descending false
+ use_order use order flag of filters for sorting false
+ default_first set default filter on top of return list false
+ case_sensitive compare "sort_prop" case sensitive false
+*//*-*************************************************************************************************************/
+#define SEPERATOR_QUERYPARAM ((sal_Unicode)':')
+#define SEPERATOR_QUERYPARAMVALUE ((sal_Unicode)'=')
+
+#define QUERYPARAM_IFLAGS DECLARE_ASCII("iflags" )
+#define QUERYPARAM_EFLAGS DECLARE_ASCII("eflags" )
+#define QUERYPARAM_SORT_PROP DECLARE_ASCII("sort_prop" )
+
+#define QUERYPARAM_DESCENDING DECLARE_ASCII("descending" )
+#define QUERYPARAM_USE_ORDER DECLARE_ASCII("use_order" )
+#define QUERYPARAM_DEFAULT_FIRST DECLARE_ASCII("default_first" )
+#define QUERYPARAM_CASE_SENSITIVE DECLARE_ASCII("case_sensitive" )
+
+#define QUERYPARAMVALUE_SORT_PROP_NAME DECLARE_ASCII("name" )
+#define QUERYPARAMVALUE_SORT_PROP_UINAME DECLARE_ASCII("uiname" )
+
+/*-************************************************************************************************************//**
+ @short Helper class to support easy building of a query statements.
+*//*-*************************************************************************************************************/
+class QueryBuilder
+{
+ public:
+ //---------------------------------------------------------------------------------------------------------
+ // start with empty query
+ //---------------------------------------------------------------------------------------------------------
+ QueryBuilder()
+ {
+ resetAll();
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // returns full query as copy of internal set values
+ //---------------------------------------------------------------------------------------------------------
+ ::rtl::OUString getQuery()
+ {
+ ::rtl::OUStringBuffer sCopy( m_sParams );
+ sCopy.insert( 0, m_sBase );
+ return sCopy.makeStringAndClear();
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // set new or change existing base query part
+ //---------------------------------------------------------------------------------------------------------
+ void setBase( const ::rtl::OUString& sBase )
+ {
+ m_sBase = sBase;
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // add new parameter (with optional value) to param list
+ //---------------------------------------------------------------------------------------------------------
+ void addParam( const ::rtl::OUString& sParam, const ::rtl::OUString& sValue = ::rtl::OUString() )
+ {
+ m_sParams.append( SEPERATOR_QUERYPARAM );
+ m_sParams.append( sParam );
+ if( sValue.getLength() > 0 )
+ {
+ m_sParams.append( SEPERATOR_QUERYPARAMVALUE );
+ m_sParams.append( sValue );
+ }
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // forget all setted params and start with empty ones
+ // Attention: base of query isn't changed!
+ //---------------------------------------------------------------------------------------------------------
+ void resetParams()
+ {
+ m_sParams.makeStringAndClear();
+ m_sParams.ensureCapacity( 256 );
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // start with new empty query
+ //---------------------------------------------------------------------------------------------------------
+ void resetAll()
+ {
+ m_sBase = ::rtl::OUString();
+ resetParams();
+ }
+
+ private:
+ ::rtl::OUString m_sBase ;
+ ::rtl::OUStringBuffer m_sParams ;
+
+}; // class QueryBuilder
+
+/*-************************************************************************************************************//**
+ @short Helper class to analyze queries and split into his different parts (base, params and values).
+*//*-*************************************************************************************************************/
+class QueryAnalyzer
+{
+ public:
+
+ //---------------------------------------------------------------------------------------------------------
+ // it's will not perform to compare strings as query type ...
+ // so we convert it into these enum values.
+ // default = E_ALL!
+ //---------------------------------------------------------------------------------------------------------
+ enum EQuery
+ {
+ E_ALL ,
+ E_WRITER ,
+ E_WEB ,
+ E_GLOBAL ,
+ E_CHART ,
+ E_CALC ,
+ E_IMPRESS ,
+ E_DRAW ,
+ E_MATH ,
+ E_GRAPHICS
+ };
+
+ //---------------------------------------------------------------------------------------------------------
+ // these are valid values for param "sort_prop".
+ // other ones are not supported!
+ // default = E_NAME
+ //---------------------------------------------------------------------------------------------------------
+ enum ESortProp
+ {
+ E_NAME ,
+ E_UINAME
+ };
+
+ //---------------------------------------------------------------------------------------------------------
+ // analyze given query and split it into his different parts; <base>:<param1>:<param2=value>...
+ //---------------------------------------------------------------------------------------------------------
+ QueryAnalyzer( const ::rtl::OUString& sQuery )
+ // Don't forget to set default values for non given params!
+ : m_eQuery ( E_ALL ) // return ALL filter ...
+ , m_nIFlags ( 0 ) // which has set ANY flag ... (we remove all entries which match with these mask .. => 0!)
+ , m_nEFlags ( 0 ) // (only used, if nIFlags==0 and himself!=0!)
+ , m_eSortProp ( E_NAME ) // sort it by internal name ...
+ , m_bDescending ( sal_False ) // in ascending order ...
+ , m_bCaseSensitive( sal_False ) // ignore case ...
+ , m_bUseOrder ( sal_False ) // don't use order flag ...
+ , m_bDefaultFirst ( sal_False ) // and don't handle default entries in special case!
+ {
+ // Translate old query format to new one first!
+ ::rtl::OUString sNewQuery( sQuery );
+ if( sQuery == DECLARE_ASCII("_filterquery_textdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_writer:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_webdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_web:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_globaldocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_global:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_chartdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_chart:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_spreadsheetdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_calc:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_presentationdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_impress:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_drawingdocument_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_draw:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_formulaproperties_withdefault") )
+ sNewQuery=DECLARE_ASCII("_query_math:default_first:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_textdocument") )
+ sNewQuery=DECLARE_ASCII("_query_writer:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_webdocument") )
+ sNewQuery=DECLARE_ASCII("_query_web:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_globaldocument") )
+ sNewQuery=DECLARE_ASCII("_query_global:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_chartdocument") )
+ sNewQuery=DECLARE_ASCII("_query_chart:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_spreadsheetdocument") )
+ sNewQuery=DECLARE_ASCII("_query_calc:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_presentationdocument") )
+ sNewQuery=DECLARE_ASCII("_query_impress:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_drawingdocument") )
+ sNewQuery=DECLARE_ASCII("_query_draw:use_order:sort_prop=uiname");
+ else
+ if( sQuery == DECLARE_ASCII("_filterquery_formulaproperties") )
+ sNewQuery=DECLARE_ASCII("_query_math:use_order:sort_prop=uiname");
+
+ // Analyze query ...
+ // Try to find base of it and safe it for faster access as enum value!
+ sal_Int32 nToken = 0;
+ ::rtl::OUString sParam ;
+ ::rtl::OUString sBase = sNewQuery.getToken( 0, SEPERATOR_QUERYPARAM, nToken );
+
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_ALL ) == sal_True ) m_eQuery = E_ALL ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_WRITER ) == sal_True ) m_eQuery = E_WRITER ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_WEB ) == sal_True ) m_eQuery = E_WEB ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_GLOBAL ) == sal_True ) m_eQuery = E_GLOBAL ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_CHART ) == sal_True ) m_eQuery = E_CHART ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_CALC ) == sal_True ) m_eQuery = E_CALC ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_IMPRESS ) == sal_True ) m_eQuery = E_IMPRESS ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_DRAW ) == sal_True ) m_eQuery = E_DRAW ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_MATH ) == sal_True ) m_eQuery = E_MATH ; else
+ if( sBase.equalsIgnoreAsciiCase( BASE_QUERY_GRAPHICS ) == sal_True ) m_eQuery = E_GRAPHICS ;
+
+ // Try to get additional parameters ...
+ while( nToken >= 0 )
+ {
+ sParam = sNewQuery.getToken( 0, SEPERATOR_QUERYPARAM, nToken );
+ // "default_first"
+ if( sParam.compareTo( QUERYPARAM_DEFAULT_FIRST, QUERYPARAM_DEFAULT_FIRST.getLength() ) == 0 )
+ {
+ m_bDefaultFirst = sal_True;
+ }
+ else
+ // "use_order"
+ if( sParam.compareTo( QUERYPARAM_USE_ORDER, QUERYPARAM_USE_ORDER.getLength() ) == 0 )
+ {
+ m_bUseOrder = sal_True;
+ }
+ else
+ // "descending"
+ if( sParam.compareTo( QUERYPARAM_DESCENDING, QUERYPARAM_DESCENDING.getLength() ) == 0 )
+ {
+ m_bDescending = sal_True;
+ }
+ else
+ // "case_sensitive"
+ if( sParam.compareTo( QUERYPARAM_CASE_SENSITIVE, QUERYPARAM_CASE_SENSITIVE.getLength() ) == 0 )
+ {
+ m_bCaseSensitive = sal_True;
+ }
+ else
+ // "iflags=<mask>"
+ if( sParam.compareTo( QUERYPARAM_IFLAGS, QUERYPARAM_IFLAGS.getLength() ) == 0 )
+ {
+ sal_Int32 nSubToken = 0;
+ ::rtl::OUString sParamName = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken );
+ if( nSubToken > 0 )
+ {
+ m_nIFlags = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken ).toInt32();
+ }
+ }
+ else
+ // "eflags=<mask>"
+ if( sParam.compareTo( QUERYPARAM_EFLAGS, QUERYPARAM_EFLAGS.getLength() ) == 0 )
+ {
+ sal_Int32 nSubToken = 0;
+ ::rtl::OUString sParamName = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken );
+ if( nSubToken > 0 )
+ {
+ m_nEFlags = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken ).toInt32();
+ }
+ }
+ else
+ // "sort_prop=<[name,uiname]>"
+ if( sParam.compareTo( QUERYPARAM_SORT_PROP, QUERYPARAM_SORT_PROP.getLength() ) == 0 )
+ {
+ sal_Int32 nSubToken = 0;
+ ::rtl::OUString sParamName = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken );
+ if( nSubToken > 0 )
+ {
+ ::rtl::OUString sParamValue = sParam.getToken( 0, SEPERATOR_QUERYPARAMVALUE, nSubToken );
+ if( sParamValue.compareTo( QUERYPARAMVALUE_SORT_PROP_NAME, QUERYPARAMVALUE_SORT_PROP_NAME.getLength() ) == 0 )
+ m_eSortProp = E_NAME;
+ else
+ if( sParamValue.compareTo( QUERYPARAMVALUE_SORT_PROP_UINAME, QUERYPARAMVALUE_SORT_PROP_UINAME.getLength() ) == 0 )
+ m_eSortProp = E_UINAME;
+ }
+ }
+ }
+ }
+
+ //---------------------------------------------------------------------------------------------------------
+ // return type of query. User can decide then, which action should be started.
+ // For faster work we converted query string into corresponding enum value!
+ //---------------------------------------------------------------------------------------------------------
+ EQuery getQueryType() const { return m_eQuery; }
+
+ //---------------------------------------------------------------------------------------------------------
+ // access to additional parameter values
+ // Methods return default of realy set values!
+ //---------------------------------------------------------------------------------------------------------
+ sal_uInt32 getIFlags () const { return m_nIFlags ; }
+ sal_uInt32 getEFlags () const { return m_nEFlags ; }
+ ESortProp getSortProp () const { return m_eSortProp ; }
+ sal_Bool getDescending () const { return m_bDescending ; }
+ sal_Bool getCaseSensitive() const { return m_bCaseSensitive; }
+ sal_Bool getUseOrder () const { return m_bUseOrder ; }
+ sal_Bool getDefaultFirst () const { return m_bDefaultFirst ; }
+
+ //---------------------------------------------------------------------------------------------------------
+ // this method checks if given string match any supported query.
+ // (ignore additional parameters!)
+ //---------------------------------------------------------------------------------------------------------
+ static sal_Bool isQuery( const ::rtl::OUString& sQuery )
+ {
+ return(
+ ( sQuery.compareToAscii( "_query_" , 7 ) == 0 ) || // new style
+ ( sQuery.compareToAscii( "_filterquery_", 13 ) == 0 ) // old style!
+ );
+ }
+
+ private:
+ EQuery m_eQuery ;
+ sal_uInt32 m_nIFlags ;
+ sal_uInt32 m_nEFlags ;
+ ESortProp m_eSortProp ;
+ sal_Bool m_bDescending ;
+ sal_Bool m_bCaseSensitive ;
+ sal_Bool m_bUseOrder ;
+ sal_Bool m_bDefaultFirst ;
+
+}; // class QueryAnalyzer
+
+} // namespace framework
+
+#endif // #ifndef __FRAMEWORK_QUERIES_H_