ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/proj/trunk/Search/Ranker.hpp
Revision: 360
Committed: 2004-08-19T20:09:52-07:00 (20 years, 10 months ago) by Douglas Thrift
File size: 5461 byte(s)
Log Message:
Did a lot of stuff, including fixing a bug.

File Contents

# User Rev Content
1 douglas 1 /* ============================================================================
2     * Douglas Thrift's Search Engine License
3     *
4 douglas 312 * Copyright (C) 2002-2004, Douglas Thrift. All Rights Reserved.
5 douglas 1 * Redistribution and use in source and binary forms, with or without
6     * modification, are permitted provided that the following conditions are met:
7     *
8     * 1. Redistributions of source code must retain the above copyright notice,
9     * this list of conditions and the following disclaimer.
10     *
11     * 2. Redistributions in binary form must reproduce the above copyright notice,
12     * this list of conditions and the following disclaimer in the documentation
13     * and/or other materials provided with the distribution.
14     *
15     * 3. The end-user documentation included with the redistribution, if any, must
16     * include the following acknowledgment:
17     *
18     * "This product includes software developed by Douglas Thrift
19     * (http://computers.douglasthrift.net/searchengine/)."
20     *
21     * Alternately, this acknowledgment may appear in the software itself, if
22     * and wherever such third-party acknowledgments normally appear.
23     *
24     * 4. The names "Douglas Thrift" and "Douglas Thrift's Search Engine" must not
25     * be used to endorse or promote products derived from this software without
26     * specific prior written permission. For written permission, please visit
27     * http://www.douglasthrift.net/contact.cgi for contact information.
28     *
29     * 5. Products derived from this software may not be called "Douglas Thrift's
30     * Search Engine", nor may "Douglas Thrift's Search Engine" appear in their
31     * name, without prior written permission.
32     *
33     * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
34     * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
35     * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
36     * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
37     * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
38     * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
39     * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
40     * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
41     * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
42     * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
43     * ============================================================================
44     */
45     // Douglas Thrift's Search Engine Ranker
46     //
47     // Douglas Thrift
48     //
49 Douglas Thrift 331 // $Id$
50 douglas 1
51 Douglas Thrift 334 #ifndef _Ranker_hpp_
52     #define _Ranker_hpp_
53 douglas 1
54 Douglas Thrift 334 #include "Search.hpp"
55     #include "Page.hpp"
56 douglas 1
57     class Ranker : public Page
58     {
59     private:
60 Douglas Thrift 360 typedef map<unsigned, unsigned> Map;
61 douglas 1 enum state { all, title, url, text };
62 Douglas Thrift 340 enum { sampleMax = 160 };
63 douglas 1 string sample;
64 Douglas Thrift 360 Map occurrencesTitle;
65     Map occurrencesDescription;
66     Map occurrencesText;
67 douglas 1 unsigned value;
68     vector<string> required;
69     vector<string> excluded;
70     vector<string> eitherOr;
71     unsigned requiredValue;
72     unsigned excludedValue;
73     unsigned eitherOrValue;
74     string site;
75     state allIn;
76     string lowerURL;
77     string lowerAddress;
78     string lowerTitle;
79     string lowerText;
80     void rank();
81     void checkRequired();
82     void checkExcluded();
83     void checkEitherOr();
84 douglas 15 unsigned find(string word, const string& where);
85 Douglas Thrift 360 unsigned find(string word, const string& where, Map& occurrences);
86 douglas 15 unsigned phrase(const string& phrase, const string& where);
87 Douglas Thrift 360 unsigned phrase(const string& phrase, const string& where,
88     Map& occurrences);
89     unsigned phrase(const vector<string>& words, unsigned word,
90     unsigned& begin, bool start, const string& where);
91     unsigned phrase(const vector<string>& words, unsigned word,
92     unsigned& begin, bool start, const string& where, Map& occurrences);
93 douglas 1 unsigned evaluate(vector<unsigned>& ins);
94     void decrap(string& crap);
95     public:
96 Douglas Thrift 349 Ranker(Page& page) : Page(page), value(0), requiredValue(0),
97     excludedValue(0), eitherOrValue(0), allIn(all) {}
98 douglas 1 ~Ranker() {}
99     void rank(vector<string> query);
100     void setSample();
101     string getTitle();
102     string getDescription();
103 Douglas Thrift 338 string& getSample() { return sample; }
104 douglas 1 bool operator==(const unsigned number) const;
105     bool operator==(const Ranker& ranker) const;
106     bool operator!=(const unsigned number) const;
107     bool operator!=(const Ranker& ranker) const;
108     bool operator<(const unsigned number) const;
109     bool operator<(const Ranker& ranker) const;
110     bool operator>(const unsigned number) const;
111     bool operator>(const Ranker& ranker) const;
112     bool operator<=(const unsigned number) const
113     {
114     return *this == number || *this < number;
115     }
116     bool operator<=(const Ranker& ranker) const
117     {
118     return *this == ranker || *this < ranker;
119     }
120     bool operator>=(const unsigned number) const
121     {
122     return *this == number || *this > number;
123     }
124     bool operator>=(const Ranker& ranker) const
125     {
126     return *this == ranker || *this > ranker;
127     }
128     // friends:
129     friend bool operator==(const unsigned number, const Ranker& ranker)
130     {
131     return ranker == number;
132     }
133     friend bool operator!=(const unsigned number, const Ranker& ranker)
134     {
135     return ranker != number;
136     }
137     friend bool operator>(const unsigned number, const Ranker& ranker)
138     {
139     return ranker < number;
140     }
141     friend bool operator<(const unsigned number, const Ranker& ranker)
142     {
143     return ranker > number;
144     }
145     friend bool operator>=(const unsigned number, const Ranker& ranker)
146     {
147     return ranker <= number;
148     }
149     friend bool operator<=(const unsigned number, const Ranker& ranker)
150     {
151     return ranker >= number;
152     }
153     };
154    
155     #endif // _Ranker_h_

Properties

Name Value
svn:eol-style native
svn:keywords Id