LP#1389403 Add normalizer detection to call number browse
authorDan Wells <dbw2@calvin.edu>
Fri, 4 Oct 2013 14:02:39 +0000 (10:02 -0400)
committerChris Sharp <csharp@georgialibraries.org>
Mon, 5 Jan 2015 17:45:35 +0000 (12:45 -0500)
commit8f4c605d84e917dd8a282a65e28a497e97673861
tree10f2b8c7e1d62858e197b40e324bbc23ddfeb528
parentc1758188abca343b5d2718a44df4c02fa6ef1fe3
LP#1389403 Add normalizer detection to call number browse

When finding the pivot for call number browse, we currently rely on
simple label matching (rather than normalized label matching), since
we do not know at the time of the search which normalizer we should
use.

Rather than blindly using the label, let's select the pivot in two
phases.  First, we will do what we do know, getting as close as
possible by label alone.  If we find an exact match, we are done (same
as the current code).  If we don't find an exact match, we take the
normalizer setting from the closest label match, normalize our input,
then search again.

This method *greatly* improves the overall accuracy of call number
searching whenever the call number being browsed for does not exist,
while causing no harm to accuracy when it does exist (since it will
either match the label or normalize to the same call number anyway).

Eventually, we may want to add interface elements for selecting the
call number type, probably defaulting to the default call number type
for the org unit being searched, but even with that in place, this
"auto-detection" logic should still be valuable.

Signed-off-by: Dan Wells <dbw2@calvin.edu>
Signed-off-by: Kathy Lussier <klussier@masslnc.org>
Signed-off-by: Ben Shum <bshum@biblio.org>
Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
Open-ILS/src/sql/Pg/040.schema.asset.sql
Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql [new file with mode: 0644]