[open-ils-commits] ***SPAM*** [GIT] Evergreen ILS branch master updated. c0680f7fcce12e2001b1d5e9abaaa18fa6ffd5d1
Evergreen Git
git at git.evergreen-ils.org
Tue Dec 16 14:56:10 EST 2014
This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "Evergreen ILS".
The branch, master has been updated
via c0680f7fcce12e2001b1d5e9abaaa18fa6ffd5d1 (commit)
via ea1c430358991b3df45b9ee0da2356649d957207 (commit)
via 0836acd0ed5cd226c41fa666e393b89f0e30099b (commit)
from d04d181e0db2181866de3b5d30e4c21cf7f3aaa1 (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
- Log -----------------------------------------------------------------
commit c0680f7fcce12e2001b1d5e9abaaa18fa6ffd5d1
Author: Ben Shum <bshum at biblio.org>
Date: Tue Dec 16 14:54:28 2014 -0500
LP#1389403: Stamping upgrade script for normalizer detection to call number browse
Signed-off-by: Ben Shum <bshum at biblio.org>
diff --git a/Open-ILS/src/sql/Pg/002.schema.config.sql b/Open-ILS/src/sql/Pg/002.schema.config.sql
index e674182..c60c5f6 100644
--- a/Open-ILS/src/sql/Pg/002.schema.config.sql
+++ b/Open-ILS/src/sql/Pg/002.schema.config.sql
@@ -91,7 +91,7 @@ CREATE TRIGGER no_overlapping_deps
BEFORE INSERT OR UPDATE ON config.db_patch_dependencies
FOR EACH ROW EXECUTE PROCEDURE evergreen.array_overlap_check ('deprecates');
-INSERT INTO config.upgrade_log (version, applied_to) VALUES ('0898', :eg_version); -- miker/Dyrcona
+INSERT INTO config.upgrade_log (version, applied_to) VALUES ('0899', :eg_version); -- dbwells/kmlussier/bshum
CREATE TABLE config.bib_source (
id SERIAL PRIMARY KEY,
diff --git a/Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql b/Open-ILS/src/sql/Pg/upgrade/0899.function.cn_normalizers_immutable.sql
similarity index 75%
rename from Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql
rename to Open-ILS/src/sql/Pg/upgrade/0899.function.cn_normalizers_immutable.sql
index 60618da..77e7e9c 100644
--- a/Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql
+++ b/Open-ILS/src/sql/Pg/upgrade/0899.function.cn_normalizers_immutable.sql
@@ -1,6 +1,6 @@
BEGIN;
---SELECT evergreen.upgrade_deps_block_check('XXXX', :eg_version);
+SELECT evergreen.upgrade_deps_block_check('0899', :eg_version);
ALTER FUNCTION asset.label_normalizer_generic(TEXT) IMMUTABLE;
ALTER FUNCTION asset.label_normalizer_dewey(TEXT) IMMUTABLE;
commit ea1c430358991b3df45b9ee0da2356649d957207
Author: Dan Wells <dbw2 at calvin.edu>
Date: Wed Nov 19 12:16:03 2014 -0500
LP#1389403 Normalizer detection compatibility with LP#1373693
In LP#1373693, $ou_ids become an optional argument when at the top of
the tree. We need to account for that.
Signed-off-by: Dan Wells <dbw2 at calvin.edu>
Signed-off-by: Kathy Lussier <klussier at masslnc.org>
Signed-off-by: Ben Shum <bshum at biblio.org>
diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
index 61e9c07..7f53b53 100644
--- a/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
+++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
@@ -356,7 +356,7 @@ sub _label_sortkey_from_label {
"open-ils.cstore.direct.asset.call_number.search.atomic",
{ label_sortkey
=> { ">=" => [$closest_cn->[0]->label_class->normalizer, $label] },
- owning_lib => $ou_ids,
+ (scalar(@$ou_ids) ? (owning_lib => $ou_ids) : ()),
deleted => 'f',
@$cp_filter
},
commit 0836acd0ed5cd226c41fa666e393b89f0e30099b
Author: Dan Wells <dbw2 at calvin.edu>
Date: Fri Oct 4 10:02:39 2013 -0400
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 at calvin.edu>
Signed-off-by: Kathy Lussier <klussier at masslnc.org>
Signed-off-by: Ben Shum <bshum at biblio.org>
diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
index bf795e4..61e9c07 100644
--- a/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
+++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/SuperCat.pm
@@ -339,15 +339,38 @@ sub _label_sortkey_from_label {
deleted => 'f',
@$cp_filter
},
- { limit => 1,
+ { flesh => 1,
+ flesh_fields => { acn => [qw/label_class/] },
+ limit => 1,
order_by => { acn => "oils_text_as_bytea(label), id" }
}
)->gather(1);
if (@$closest_cn) {
- return $closest_cn->[0]->label_sortkey;
- } else {
- return '~~~'; #fallback to high ascii value, we are at the end
+ if ($closest_cn->[0]->label eq $label) {
+ # we found an exact match stop here
+ return $closest_cn->[0]->label_sortkey;
+ } else {
+ # we got as close as we could by label alone, let's try to
+ # normalize and get closer
+ $closest_cn = $_storage->request(
+ "open-ils.cstore.direct.asset.call_number.search.atomic",
+ { label_sortkey
+ => { ">=" => [$closest_cn->[0]->label_class->normalizer, $label] },
+ owning_lib => $ou_ids,
+ deleted => 'f',
+ @$cp_filter
+ },
+ { limit => 1,
+ order_by => { acn => "label_sortkey, id" }
+ }
+ )->gather(1);
+ if (@$closest_cn) {
+ return $closest_cn->[0]->label_sortkey;
+ }
+ }
}
+
+ return '~~~'; #fallback to high ascii value, we are at the end of the range
}
sub cn_browse {
diff --git a/Open-ILS/src/sql/Pg/040.schema.asset.sql b/Open-ILS/src/sql/Pg/040.schema.asset.sql
index 2381fdb..e7b1daa 100644
--- a/Open-ILS/src/sql/Pg/040.schema.asset.sql
+++ b/Open-ILS/src/sql/Pg/040.schema.asset.sql
@@ -348,7 +348,7 @@ CREATE OR REPLACE FUNCTION asset.label_normalizer_generic(TEXT) RETURNS TEXT AS
$callnum =~ s/ {2,}/ /g;
return $callnum;
-$func$ LANGUAGE PLPERLU;
+$func$ LANGUAGE PLPERLU IMMUTABLE;
CREATE OR REPLACE FUNCTION asset.label_normalizer_dewey(TEXT) RETURNS TEXT AS $func$
# Derived from the Koha C4::ClassSortRoutine::Dewey module
@@ -387,7 +387,7 @@ CREATE OR REPLACE FUNCTION asset.label_normalizer_dewey(TEXT) RETURNS TEXT AS $f
return $key;
-$func$ LANGUAGE PLPERLU;
+$func$ LANGUAGE PLPERLU IMMUTABLE;
CREATE OR REPLACE FUNCTION asset.label_normalizer_lc(TEXT) RETURNS TEXT AS $func$
@@ -401,7 +401,7 @@ CREATE OR REPLACE FUNCTION asset.label_normalizer_lc(TEXT) RETURNS TEXT AS $func
my $callnum = Library::CallNumber::LC->new(shift);
return $callnum->normalize();
-$func$ LANGUAGE PLPERLU;
+$func$ LANGUAGE PLPERLU IMMUTABLE;
INSERT INTO asset.call_number_class (name, normalizer, field) VALUES
('Generic', 'asset.label_normalizer_generic', '050ab,055ab,060ab,070ab,080ab,082ab,086ab,088ab,090,092,096,098,099'),
diff --git a/Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql b/Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql
new file mode 100644
index 0000000..60618da
--- /dev/null
+++ b/Open-ILS/src/sql/Pg/upgrade/XXXX.function.cn_normalizers_immutable.sql
@@ -0,0 +1,9 @@
+BEGIN;
+
+--SELECT evergreen.upgrade_deps_block_check('XXXX', :eg_version);
+
+ALTER FUNCTION asset.label_normalizer_generic(TEXT) IMMUTABLE;
+ALTER FUNCTION asset.label_normalizer_dewey(TEXT) IMMUTABLE;
+ALTER FUNCTION asset.label_normalizer_lc(TEXT) IMMUTABLE;
+
+COMMIT;
-----------------------------------------------------------------------
Summary of changes:
.../perlmods/lib/OpenILS/Application/SuperCat.pm | 31 +++++++++++++++++--
Open-ILS/src/sql/Pg/002.schema.config.sql | 2 +-
Open-ILS/src/sql/Pg/040.schema.asset.sql | 6 ++--
.../0899.function.cn_normalizers_immutable.sql | 9 ++++++
4 files changed, 40 insertions(+), 8 deletions(-)
create mode 100644 Open-ILS/src/sql/Pg/upgrade/0899.function.cn_normalizers_immutable.sql
hooks/post-receive
--
Evergreen ILS
More information about the open-ils-commits
mailing list