/************************************************************************* * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef _XMLSEARCH_QE_QUERY_HXX_ #define _XMLSEARCH_QE_QUERY_HXX_ #include #include #include #include namespace xmlsearch { namespace qe { class Search; class RoleFiller; class QueryHit { public: QueryHit( sal_Int32 nColumns,double penalty,sal_Int32 doc,sal_Int32 begin,sal_Int32 end ) : doc_( doc ), begin_( begin ), end_( end ), matchesL_( 2*nColumns ), matches_( new sal_Int32[ 2*nColumns ] ), penalty_( penalty ) { rtl_zeroMemory( matches_,sizeof( sal_Int32 ) * matchesL_ ); } ~QueryHit() { delete[] matches_; } sal_Int32 getDocument() const { return doc_; } sal_Int32 countOfMatches() const { return matchesL_; } sal_Int32 getBegin() const { return begin_; } sal_Int32 getEnd() const { return end_; } double getPenalty() const { return penalty_; } bool betterThan( const QueryHit* o ) { if( penalty_ != o->penalty_ ) return penalty_ < o->penalty_; else if( begin_ != o->begin_ ) return begin_ < o->begin_; else if( end_ != o->end_ ) return end_ < o->end_; else return false; } bool worseThan( const QueryHit* o ) { if( penalty_ != o->penalty_ ) return penalty_ > o->penalty_; else if( begin_ != o->begin_ ) return begin_ > o->begin_; else if( end_ != o->end_ ) return end_ > o->end_; else return false; } bool worseThan( double penalty,sal_Int32 begin,sal_Int32 end ) { if( penalty_ != penalty ) return penalty_ > penalty; else if( begin_ != begin ) return begin_ > begin; else if( end_ != end ) return end_ > end; else return false; } bool compareTo( const QueryHit* o ) const { if( penalty_ != o->penalty_ ) return penalty_ < o->penalty_; else if( begin_ != o->begin_ ) return begin_ < o->begin_; else if( end_ != o->end_ ) return end_ < o->end_; else return false; } private: sal_Int32 doc_,begin_,end_; sal_Int32 matchesL_; sal_Int32 *matches_; // ...concept, word number, ... double penalty_; }; // end class QueryHit class QueryHitData { public: QueryHitData( double penalty,const rtl::OUString& document,sal_Int32 termsL, rtl::OUString* terms ) : penalty_( penalty ), document_( document ), termsL_( termsL ), terms_( terms ) { } ~QueryHitData() { delete[] terms_; } rtl::OUString getDocument() const { return document_; } double getPenalty() const { return penalty_; } private: double penalty_; const rtl::OUString document_; sal_Int32 termsL_; rtl::OUString* terms_; }; // end class QueryHitData class PrefixTranslator { public: static PrefixTranslator* makePrefixTranslator( const rtl::OUString*,sal_Int32 ) { return 0; } }; } } #endif