allow for local yacy.stopwords and yacy.badwords list (in DATA/SETTINGS/)

if file in DATA/SETTINGS it is loaded otherwise file in ./defaults is loaded
   (if locale ./defaults/stopwords.xx doesn't exist take solr/lang/stopwords_xx.txt as default)

move yacy.stopwords, yacy.stopwords.de and yacy.badwords.example out of root directory to ./defaults directory
pull/1/head
reger 10 years ago
parent de56266bcb
commit ee277b9b3e

@ -15,6 +15,7 @@
# $LastChangedRevision$ # $LastChangedRevision$
# $LastChangedBy$ # $LastChangedBy$
# #
# if list exists in DATA/SETTINGS/ it takes preference otherwise list is loaded from defaults/ directory
aber aber
allen allen
alles alles

@ -0,0 +1,6 @@
# Default stopword list (always loaded)
# a configured language specific stopword list is appended (like: yacy.stopwords.de)
# (depending on the language of the yacy user interface)
# Stopwords are excluded from search queries and excluded from the topword (navigation, in addition to yacy.badwords)
#
# if list exists in DATA/SETTINGS/ it takes preference otherwise list is loaded from defaults/ directory

@ -633,7 +633,10 @@ public final class Switchboard extends serverSwitch {
// load badwords (to filter the topwords) // load badwords (to filter the topwords)
if ( badwords == null || badwords.isEmpty() ) { if ( badwords == null || badwords.isEmpty() ) {
final File badwordsFile = new File(appPath, SwitchboardConstants.LIST_BADWORDS_DEFAULT); File badwordsFile = new File(appPath, "/DATA/SETTINGS/" + SwitchboardConstants.LIST_BADWORDS_DEFAULT);
if (!badwordsFile.exists()) {
badwordsFile = new File(appPath, SwitchboardConstants.LIST_BADWORDS_DEFAULT);
}
badwords = SetTools.loadList(badwordsFile, NaturalOrder.naturalComparator); badwords = SetTools.loadList(badwordsFile, NaturalOrder.naturalComparator);
// badwordHashes = Word.words2hashesHandles(badwords); // badwordHashes = Word.words2hashesHandles(badwords);
this.log.config("loaded badwords from file " this.log.config("loaded badwords from file "
@ -644,30 +647,30 @@ public final class Switchboard extends serverSwitch {
+ ppRamString(badwordsFile.length() / 1024)); + ppRamString(badwordsFile.length() / 1024));
} }
// load stopwords // load stopwords (to filter query and topwords)
if ( stopwords == null || stopwords.isEmpty() ) { if ( stopwords == null || stopwords.isEmpty() ) {
final File stopwordsFile = new File(appPath, SwitchboardConstants.LIST_STOPWORDS_DEFAULT); File stopwordsFile = new File(dataPath, "/DATA/SETTINGS/" + SwitchboardConstants.LIST_STOPWORDS_DEFAULT);
if (!stopwordsFile.exists()) {
stopwordsFile = new File(appPath, "defaults/"+SwitchboardConstants.LIST_STOPWORDS_DEFAULT);
}
stopwords = SetTools.loadList(stopwordsFile, NaturalOrder.naturalComparator); stopwords = SetTools.loadList(stopwordsFile, NaturalOrder.naturalComparator);
// append locale language stopwords using setting of interface language (file yacy.stopwords.xx) // append locale language stopwords using setting of interface language (file yacy.stopwords.xx)
//TODO: append / share Solr stopwords.txt String lng = this.getConfig("locale.language", "en");
final File stopwordsFilelocale = new File (stopwordsFile.getAbsolutePath()+"."+this.getConfig("locale.language","default")); if ("default".equals(lng)) lng="en"; // english is stored as default (needed for locale html file overlay)
File stopwordsFilelocale = new File (dataPath, "DATA/SETTINGS/"+stopwordsFile.getName()+"."+lng);
if (!stopwordsFilelocale.exists()) stopwordsFilelocale = new File (appPath, "defaults/"+stopwordsFile.getName()+"."+lng);
if (stopwordsFilelocale.exists()) { if (stopwordsFilelocale.exists()) {
// load YaCy locale stopword list
stopwords.addAll(SetTools.loadList(stopwordsFilelocale, NaturalOrder.naturalComparator)); stopwords.addAll(SetTools.loadList(stopwordsFilelocale, NaturalOrder.naturalComparator));
} this.log.config("append stopwords from file " + stopwordsFilelocale.getName());
} else {
if (!stopwords.isEmpty()) { // alternatively load/append default solr stopword list
stopwordHashes = new TreeSet<byte[]>(NaturalOrder.naturalOrder); stopwordsFilelocale = new File (appPath, "defaults/solr/lang/stopwords_" + lng + ".txt");
for (final String wordstr : stopwords) { if (stopwordsFilelocale.exists()) {
stopwordHashes.add(Word.word2hash(wordstr)); stopwords.addAll(SetTools.loadList(stopwordsFilelocale, NaturalOrder.naturalComparator));
this.log.config("append stopwords from file " + stopwordsFilelocale.getName());
} }
} }
this.log.config("loaded stopwords from file "
+ stopwordsFile.getName()
+ ", "
+ stopwords.size()
+ " entries, "
+ ppRamString(stopwordsFile.length() / 1024));
} }
// start a cache manager // start a cache manager

@ -1,3 +0,0 @@
# Default stopword list (always loaded)
# a configured language specific stopword list is appended (like: yacy.stopwords.de)
#
Loading…
Cancel
Save