RPN to CQL: always quote resulting terms
authorAdam Dickmeiss <adam@indexdata.dk>
Tue, 20 Dec 2011 13:49:34 +0000 (14:49 +0100)
committerAdam Dickmeiss <adam@indexdata.dk>
Tue, 20 Dec 2011 13:49:34 +0000 (14:49 +0100)
For bizarre reasons, JSTOR's SRU server returns 0 hits on ISSN
searches unless a CQL term is quoted. The rpn2cql family of
functions now always returns quoted CQL terms.

src/rpn2cql.c
test/test_rpn2cql.c

index 9fedba6..43f09ec 100644 (file)
@@ -194,7 +194,6 @@ static int rpn2cql_simple(cql_transform_t ct,
         size_t lterm = 0;
         Odr_int trunc = lookup_truncation(apt->attributes);
         size_t i;
-        int must_quote = 0;
 
         wrbuf_rewind(w);
         ret = rpn2cql_attr(ct, apt->attributes, w);
@@ -222,10 +221,7 @@ static int rpn2cql_simple(cql_transform_t ct,
             for (i = 0 ; i < lterm; i++)
                 if (strchr(" ()=></", sterm[i]))
                     break;
-            if (i < lterm || lterm == 0)
-                must_quote = 1;
-            if (must_quote)
-                wrbuf_puts(w, "\"");
+            wrbuf_puts(w, "\"");
             if (trunc == 2 || trunc == 3)
                 wrbuf_puts(w, "*");
             for (i = 0; i < lterm; i++)
@@ -258,8 +254,7 @@ static int rpn2cql_simple(cql_transform_t ct,
             }
             if (trunc == 1 || trunc == 3)
                 wrbuf_puts(w, "*");
-            if (must_quote)
-                wrbuf_puts(w, "\"");
+            wrbuf_puts(w, "\"");
         }
         else
         {
index fd0e5a6..387cb88 100644 (file)
@@ -56,17 +56,17 @@ static void tst1(void)
 {
     cql_transform_t ct = cql_transform_create();    
 
-    YAZ_CHECK(compare(ct, "abc", "abc"));
+    YAZ_CHECK(compare(ct, "abc", "\"abc\""));
     YAZ_CHECK(compare(ct, "\"a b c\"", "\"a b c\""));
-    YAZ_CHECK(compare(ct, "@and a b", "a and b"));
-    YAZ_CHECK(compare(ct, "@attr 1=field abc", "field=abc"));
+    YAZ_CHECK(compare(ct, "@and a b", "\"a\" and \"b\""));
+    YAZ_CHECK(compare(ct, "@attr 1=field abc", "field=\"abc\""));
     YAZ_CHECK(compare(ct, "@attr 1=4 abc", 0)); /* should fail */
 
     cql_transform_define_pattern(ct, "index.title", "1=4");
-    YAZ_CHECK(compare(ct, "@attr 1=4 abc", "title=abc"));
+    YAZ_CHECK(compare(ct, "@attr 1=4 abc", "title=\"abc\""));
 
     cql_transform_define_pattern(ct, "index.foo", "1=bar");
-    YAZ_CHECK(compare(ct, "@attr 1=bar abc", "foo=abc"));
+    YAZ_CHECK(compare(ct, "@attr 1=bar abc", "foo=\"abc\""));
 
     cql_transform_close(ct);
 }
@@ -84,52 +84,52 @@ static void tst2(void)
     wrbuf_puts(w, "../etc/pqf.properties");
     
     ct = cql_transform_open_fname(wrbuf_cstr(w));
-    YAZ_CHECK(compare(ct, "@attr 1=4 abc", "dc.title=abc"));
-    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 4=108 abc", "dc.title=/exact abc"));
-    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 3=1 @attr 6=1 abc", "dc.title=abc"));
-    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 4=1 @attr 6=1 abc", "dc.title=abc"));
-    YAZ_CHECK(compare(ct, "@attr 1=1016 abc", "abc"));
+    YAZ_CHECK(compare(ct, "@attr 1=4 abc", "dc.title=\"abc\""));
+    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 4=108 abc", "dc.title=/exact \"abc\""));
+    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 3=1 @attr 6=1 abc", "dc.title=\"abc\""));
+    YAZ_CHECK(compare(ct, "@attr 1=4 @attr 4=1 @attr 6=1 abc", "dc.title=\"abc\""));
+    YAZ_CHECK(compare(ct, "@attr 1=1016 abc", "\"abc\""));
     /* Date tests */
-    YAZ_CHECK(compare(ct, "@attr 2=1 @attr 1=30 1980", "dc.date<1980"));
-    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=3 1980", "dc.date=1980"));
-    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=5 1980", "dc.date>1980"));
-    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=2 1980", "dc.date<=1980"));
-    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=4 1980", "dc.date>=1980"));
+    YAZ_CHECK(compare(ct, "@attr 2=1 @attr 1=30 1980", "dc.date<\"1980\""));
+    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=3 1980", "dc.date=\"1980\""));
+    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=5 1980", "dc.date>\"1980\""));
+    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=2 1980", "dc.date<=\"1980\""));
+    YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=4 1980", "dc.date>=\"1980\""));
 
     /* Truncation */
-    YAZ_CHECK(compare(ct, "@attr 5=1 water", "water*"));
-    YAZ_CHECK(compare(ct, "@attr 5=2 water", "*water"));
-    YAZ_CHECK(compare(ct, "@attr 5=3 water", "*water*"));
-    YAZ_CHECK(compare(ct, "@attr 5=100 water", "water"));
-    YAZ_CHECK(compare(ct, "@attr 5=102 water", "water"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 water", "water"));
-
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat.*er", "wat*er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat?er", "wat*er"));
-
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat.er", "wat?er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat#er", "wat?er"));
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat?er", "wat\\?er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat*er", "wat\\*er"));
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat#er", "wat#er"));
+    YAZ_CHECK(compare(ct, "@attr 5=1 water", "\"water*\""));
+    YAZ_CHECK(compare(ct, "@attr 5=2 water", "\"*water\""));
+    YAZ_CHECK(compare(ct, "@attr 5=3 water", "\"*water*\""));
+    YAZ_CHECK(compare(ct, "@attr 5=100 water", "\"water\""));
+    YAZ_CHECK(compare(ct, "@attr 5=102 water", "\"water\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 water", "\"water\""));
+
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat.*er", "\"wat*er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat?er", "\"wat*er\""));
+
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat.er", "\"wat?er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat#er", "\"wat?er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat?er", "\"wat\\?er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat*er", "\"wat\\*er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat#er", "\"wat#er\""));
 
     /* \. is 'eaten' by PQF parser */
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\.er", "wat?er"));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\.er", "\"wat?er\""));
 
     /* Escape sequences */
     /* note: escape sequences that survive after PQF parse below */
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\?er", "wat\\?er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\?er", "wat\\?er"));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\?er", "\"wat\\?er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\?er", "\"wat\\?er\""));
 
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\*er", "wat\\*er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\*er", "wat\\*er"));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\*er", "\"wat\\*er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\*er", "\"wat\\*er\""));
 
-    YAZ_CHECK(compare(ct, "wat\\\\#er", "wat#er"));
-    YAZ_CHECK(compare(ct, "@attr 5=100 wat\\\\#er", "wat#er"));
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\#er", "wat#er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\#er", "wat#er"));
-    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\.er", "wat.er"));
-    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\.er", "wat.er"));
+    YAZ_CHECK(compare(ct, "wat\\\\#er", "\"wat#er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=100 wat\\\\#er", "\"wat#er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\#er", "\"wat#er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\#er", "\"wat#er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=102 wat\\\\.er", "\"wat.er\""));
+    YAZ_CHECK(compare(ct, "@attr 5=104 wat\\\\.er", "\"wat.er\""));
 
     /* Quoting */
     YAZ_CHECK(compare(ct, "@attr 5=100 \"\"", "\"\""));
@@ -144,7 +144,7 @@ static void tst2(void)
     YAZ_CHECK(compare(ct, "@attr 5=3 \"water basket\"", "\"*water basket*\""));
 
     /* Other */
-    YAZ_CHECK(compare(ct, "@attr 2=103 @attr 1=_ALLRECORDS 1", "cql.allRecords=1"));
+    YAZ_CHECK(compare(ct, "@attr 2=103 @attr 1=_ALLRECORDS 1", "cql.allRecords=\"1\""));
     YAZ_CHECK(compare(ct, "@attr 1=500 abc", 0));
     cql_transform_close(ct);
     wrbuf_destroy(w);