The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
# $Id: pqf.properties,v 1.18 2007/03/29 17:14:13 mike Exp $
#
# Properties file to drive the YAZ CQL-to-PQF converter for Zebra.
# This specifies the interpretation of various CQL indexes, relations,
# etc. in terms of Type-1 query attributes.

# Identifiers for prefixes used in this file. (index.*)
set.cql		= info:srw/cql-context-set/1/cql-v1.1
set.rec		= info:srw/cql-context-set/2/rec-1.1
set.net		= info:srw/cql-context-set/2/net-1.0
set.dc		= info:srw/cql-context-set/1/dc-v1.1
set.zeerex      = info:srw/cql-context-set/2/zeerex-1.1

# The default set when an index doesn't specify one: Net
set		= info:srw/cql-context-set/2/net-1.0

# The default index when none is specified by the query
index.cql.serverChoice			= 1=cql:anywhere

index.cql.anywhere			= 1=cql:anywhere
index.cql.allRecords			= 1=_ALLRECORDS 2=103
index.rec.id				= 1=rec:id 4=104
index.net.protocol			= 1=net:protocol
index.net.version			= 1=net:version 4=3
index.net.method			= 1=net:method
index.net.host				= 1=net:host 4=3
index.net.port				= 1=net:port 4=3
index.net.path				= 1=net:path 4=3
index.dc.title				= 1=dc:title
index.dc.creator			= 1=dc:creator
index.dc.description			= 1=dc:description
index.zeerex.numberOfRecords		= 1=zeerex:numberOfRecords
index.zeerex.set			= 1=zeerex:set
index.zeerex.index			= 1=zeerex:index
index.zeerex.attributeType		= 1=zeerex:attributeType
index.zeerex.attributeValue		= 1=zeerex:attributeValue
index.zeerex.schema			= 1=zeerex:schema
index.zeerex.recordSyntax		= 1=zeerex:recordSyntax 4=3
index.zeerex.supports_relation		= 1=zeerex:supports_relation
index.zeerex.supports_relationModifier	= 1=zeerex:supports_relationModifier
index.zeerex.supports_maskingCharacter	= 1=zeerex:supports_maskingCharacter
index.zeerex.default_contextSet		= 1=zeerex:default_contextSet
index.zeerex.default_index		= 1=zeerex:default_index
# Extensions
index.zeerex.libType			= 1=zeerex:libType 4=3
index.zeerex.country			= 1=zeerex:country 4=3

# Relation attributes are selected according to the CQL relation by
# looking up the "relation.<relation>" property:
#
relation.<				= 2=1
relation.le				= 2=2
relation.eq				= 2=3
relation.exact				= 2=3
relation.ge				= 2=4
relation.>				= 2=5
relation.<>				= 2=6

# BIB-1 doesn't have a server choice relation, so we just make the
# choice here, and use equality (which is clearly correct).
relation.scr				= 2=3

# Relation modifiers.
#
relationModifier.relevant		= 2=102
relationModifier.fuzzy			= 5=103
	### truncation=regExpr-2 (5=102) in Zebra is "fuzzy matching"
relationModifier.stem			= 2=101
relationModifier.phonetic		= 2=100
relationModifier.regexp			= 5=102

# Non-standard extensions to provoke Zebra's inline sorting
relationModifier.sort			= 7=1
relationModifier.sort-desc		= 7=2
relationModifier.numeric		= 4=109

# Usually this is taken care of by CQL term-anchoring with "^", but
# since that is not done for regular expressions, we need a way to
# state it explicitly in these cases.
relationModifier.firstInField		= 3=1

# Position attributes may be specified for anchored terms (those
# beginning with "^", which is stripped) and unanchored (those not
# beginning with "^").  This may change when we get a BIB-1 truncation
# attribute that says "do what CQL does".
#
position.first				= 3=1 6=1
	# "first in field"
position.any				= 3=3 6=1
	# "any position in field"
position.last				= 3=4 6=1
	# not a standard BIB-1 attribute
position.firstAndLast			= 3=3 6=3
	# search term is anchored to be complete field

# Structure attributes may be specified for individual relations; a
# default structure attribute my be specified by the pseudo-relation
# "*", to be used whenever a relation not listed here occurs.
#
structure.exact				= 4=108
	# string
structure.all				= 4=2
structure.any				= 4=2
structure.*				= 4=1
	# phrase

# Truncation attributes used to implement CQL wildcard patterns.  The
# simpler forms, left, right- and both-truncation will be used for the
# simplest patterns, so that we produce PQF queries that conform more
# closely to the Bath Profile.  However, when a more complex pattern
# such as "foo*bar" is used, we fall back on Z39.58-style masking.
#
truncation.right			= 5=1
truncation.left				= 5=2
truncation.both				= 5=3
truncation.none				= 5=100
truncation.regexp			= 5=102
truncation.z3958			= 5=104

# Finally, any additional attributes that should always be included
# with each term can be specified in the "always" property.
#
#always					= 6=1
# 6=1: completeness = incomplete subfield