summaryrefslogtreecommitdiff
path: root/darwin/query.class
diff options
context:
space:
mode:
authorChristian Schneider2006-10-26 13:35:12 +0000
committerChristian Schneider2006-10-26 13:35:12 +0000
commita5a19fd672bc0b8113d620669b557f17dccd343a (patch)
tree876ba4fec8362ac2e9374f61b9b7f67fcd2b8e59 /darwin/query.class
downloaditools-a5a19fd672bc0b8113d620669b557f17dccd343a.tar.gz
itools-a5a19fd672bc0b8113d620669b557f17dccd343a.tar.bz2
itools-a5a19fd672bc0b8113d620669b557f17dccd343a.zip
Moved itools to live branch
Diffstat (limited to 'darwin/query.class')
-rw-r--r--darwin/query.class95
1 files changed, 95 insertions, 0 deletions
diff --git a/darwin/query.class b/darwin/query.class
new file mode 100644
index 0000000..f0a5b7e
--- /dev/null
+++ b/darwin/query.class
@@ -0,0 +1,95 @@
+<?php
+/*
+** $Id$
+**
+** itools/darwin/query.class - Query the UltraDarwin 3000 Search Engine
+**
+** Requires: global $it_text object to determine result language
+**
+** $Log$
+** Revision 1.4 2000/05/08 16:01:21 cschneid
+** Removed need to global $it_text object
+**
+** Revision 1.3 2000/05/08 15:44:18 cschneid
+** Allow absolute http:// url to search binary
+**
+** Revision 1.2 2000/01/16 22:46:02 weber
+** Renamed query to result to avoid confusion
+**
+** Revision 1.1 2000/01/12 02:26:21 weber
+** Added darwin query class
+**
+**
+*/
+
+class it_darwin_query
+{
+ /* Public Result information (read only) */
+ var $totalresults; /* Total number of results found */
+ var $firstresult; /* first fetched result */
+ var $lastresult; /* last fetched result */
+
+ /* Parameters (read only) */
+ var $service; /* Service identifier for query URL */
+ var $resultsperpage; /* Number of results to show per page */
+
+ /* Private */
+ var $result; /* Raw query result array */
+ var $resptr; /* Result array pointer */
+
+ /* Constructor */
+ function it_darwin_query($service, $resultsperpage=10)
+ {
+ if (!ereg('^http://', $service))
+ $service = "http://ultrasearch.relog.ch/$service/Search";
+
+ $this->service = $service;
+ $this->resultsperpage = $resultsperpage;
+ $this->totalresults = $this->firstresult = $this->lastresult = 0;
+ }
+
+
+ /*
+ ** Perform a query for $q starting at $rank. Return true on success,
+ ** false on error (no results is not an error)
+ */
+ function query($q, $rank=0)
+ {
+ global $it_text;
+
+ if (is_object($it_text))
+ $lang = "&lang=" . $it_text->get_language();
+
+ $url = $this->service . "?q=" . urlencode($q) . "$lang&rank=$rank&n=" . $this->resultsperpage;
+
+ /* debug("it_darwin::query(\"$url\",$rank)"); */
+
+ if ($this->result = file($url))
+ {
+ $this->totalresults = trim($this->result[2]);
+ $this->firstresult = trim($this->result[3]);
+ $this->lastresult = trim($this->result[4]);
+ $this->resptr = $this->firstresult;
+ return 1;
+ }
+ return 0;
+ }
+
+ /* Fetch a result as an array "url", "title", "description", "size", "date" */
+ function fetch_array($number="XX")
+ {
+ /* debug("fetch_array($number), resptr==$this->resptr"); */
+ if ($number != "XX")
+ $this->resptr = $number;
+
+ if (($this->resptr >= $this->firstresult) && ($this->resptr <= $this->lastresult))
+ {
+ $n = 5+($this->resptr-$this->firstresult)*5; /* start of result record */
+ $this->resptr+=1; /* Spinn ich?? ++ geht nicht !! */
+ return array("url" => trim($this->result[$n]), "title" => trim($this->result[$n+1]), "description" => trim($this->result[$n+2]), "size" => trim($this->result[$n+3])*1024, "date" => trim($this->result[$n+4]));
+ }
+ else return 0; /* Out of bounds */
+
+ }
+} /* End class it_darwin_query */
+?>