support * as a truncation operator in FTS. NOTE: this will require Postgres 8.4...
authormiker <miker@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Thu, 18 Mar 2010 19:58:48 +0000 (19:58 +0000)
committermiker <miker@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Thu, 18 Mar 2010 19:58:48 +0000 (19:58 +0000)
git-svn-id: svn://svn.open-ils.org/ILS/trunk@15915 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/src/perlmods/OpenILS/Application/Storage/Driver/Pg/QueryParser.pm
Open-ILS/src/perlmods/OpenILS/Application/Storage/QueryParser.pm

index 56c1fc0..16e41de 100644 (file)
@@ -532,7 +532,14 @@ sub buildSQL {
         $sql = $n->{function}."($sql)";
     }
 
-    $sql = "to_tsquery('$classname'," . ($self->prefix ? "\$_$$\$" . $self->prefix . "\$_$$\$||" : '') . "'('||regexp_replace($sql,E'(?:\\\\s+|:)','&','g')||')')";
+    my $prefix = $self->prefix || '';
+    my $suffix = $self->suffix || '';
+
+    $prefix = "'$prefix' ||" if $prefix;
+    my $suffix_op = ":$suffix" if $suffix;
+    my $suffix_after = "|| '$suffix_op'" if $suffix;
+
+    $sql = "to_tsquery('$classname', $prefix '(' || regexp_replace($sql,E'(?:\\\\s+|:)','$suffix_op&','g') $suffix_after || ')')";
 
     return $self->sql($sql);
 }
index 3b7fb33..1be02e8 100755 (executable)
@@ -525,8 +525,9 @@ sub decompose {
 
             my $class_node = $struct->classed_node($current_class);
             my $negator = ($atom =~ s/^-//o) ? '!' : '';
+            my $truncate = ($atom =~ s/\*$//o) ? '*' : '';
 
-            $class_node->add_fts_atom( $atom, prefix => $negator, node => $class_node );
+            $class_node->add_fts_atom( $atom, suffix => $truncate, prefix => $negator, node => $class_node );
             $struct->joiner( '&' );
 
             $_ = $after;
@@ -865,6 +866,12 @@ sub prefix {
     return $self->{prefix};
 }
 
+sub suffix {
+    my $self = shift;
+    return undef unless (ref $self);
+    return $self->{suffix};
+}
+
 #-------------------------------
 package QueryParser::query_plan::filter;