Opened 17 years ago

Closed 16 years ago

#254 closed defect (fixed)

Setting QueryParser default_op to OP_NEAR doesn't set an explicit window size

Reported by: Kevin Duraj Owned by: Olly Betts
Priority: normal Milestone: 1.1.2
Component: QueryParser Version: 1.0.7
Severity: normal Keywords:
Cc: Blocked By:
Blocking: Operating System: All

Description

When searching with more then 2 parameters on Boolean operator NEAR it throws and error: Exception: Can't use NEAR/PHRASE with a subexpression containing NEAR or PHRASE

Test case: http://myhealthcare.com/cgi-bin/search?q=american+actor+kevin&bool=near

-Kevin Duraj

Change History (9)

comment:1 by Kevin Duraj, 17 years ago

Component: OtherQueryParser

comment:2 by Olly Betts, 17 years ago

Operating System: LinuxAll
Owner: changed from New Bugs to Olly Betts

A test case on a website isn't much use. I can't fire it up in the debugger to find out why something happens, nor use it to verify that a fix works.

Am I right in thinking this arises when using code something like:

queryparser.set_default_op(Xapian::Query::OP_NEAR);

comment:3 by Kevin Duraj, 17 years ago

Yes, this is the exact code used.

$qp = Search::Xapian::QueryParser->new(); $qp->set_default_op(OP_NEAR); $enq = $db->enquire($qp->parse_query($terms));

comment:4 by Olly Betts, 17 years ago

Keywords: NEAR removed
Milestone: 1.0.71.0.8
Status: newassigned
Summary: Boolean operator NEAR does not accept more than 2 paramsSetting QueryParser default_op to OP_NEAR doesn't set an explicit window size
Version: 1.0.61.0.7

This will work in 1.0.7 for multiple terms as well as it does for just two terms in 1.0.6.

But that's not actually very well - the window size for the OP_NEAR isn't set explicitly, so the default of the number of terms is used. I think it would make more sense to default_op of OP_NEAR to work much like an explicit a NEAR b NEAR c. So I'm going to keep this bug open for this remaining issue, but retitle appropriately.

comment:5 by Olly Betts, 16 years ago

Milestone: 1.0.81.1.0

Pushing back to 1.1.0.

comment:6 by Olly Betts, 16 years ago

Milestone: 1.1.01.1.1

Not an ABI breaking change, so bumping to 1.1.1.

comment:7 by Olly Betts, 16 years ago

Milestone: 1.1.11.1.7

Triaging milestone:1.1.1 bugs.

comment:8 by Olly Betts, 16 years ago

Version: 1.0.71.0.2

Fixed in r13005.

comment:9 by Olly Betts, 16 years ago

Milestone: 1.1.71.1.2
Resolution: fixed
Status: assignedclosed
Version: 1.0.21.0.7

Oops, changed version not milestone, and failed to mark as fixed...

Note: See TracTickets for help on using tickets.