Search: Add some search options

pull/620/head
gnosygnu 8 years ago
parent 8de3cf0cc6
commit ca88091d90

@ -32,17 +32,21 @@ class Xosearch_fulltext_svc {
cbk_highlight = new Xosearch_finder_cbk__highlight(app, cbk_trg); cbk_highlight = new Xosearch_finder_cbk__highlight(app, cbk_trg);
} }
public void Search(Json_nde args) { public void Search(Json_nde args) {
boolean case_match = args.Get_as_bool_or("case_match", false);
boolean auto_wildcard_bgn = args.Get_as_bool_or("auto_wildcard_bgn", false);
boolean auto_wildcard_end = args.Get_as_bool_or("auto_wildcard_end", false);
int max_pages_per_wiki = args.Get_as_int_or("max_pages_per_wiki", 25);
int max_snips_per_page = args.Get_as_int_or("max_snips_per_page", 10);
String wikis = args.Get_as_str("wikis"); String wikis = args.Get_as_str("wikis");
byte[] query_mcase = args.Get_as_bry("query"); byte[] query = args.Get_as_bry("query");
String[] wikis_ary = String_.Split(wikis, "|"); String[] wikis_ary = String_.Split(wikis, "|");
for (String wiki_domain : wikis_ary) { for (String wiki_domain : wikis_ary) {
Xow_wiki wiki = app.Wiki_mgri().Get_by_or_make_init_y(Bry_.new_u8(wiki_domain)); Xow_wiki wiki = app.Wiki_mgri().Get_by_or_make_init_y(Bry_.new_u8(wiki_domain));
byte[] query_lcase = wiki.Case_mgr().Case_build_lower(query_mcase); Search_wiki(wiki, query, case_match, auto_wildcard_bgn, auto_wildcard_end, max_pages_per_wiki, max_snips_per_page);
Search_wiki(wiki, query_lcase);
} }
} }
private void Search_wiki(Xow_wiki wiki, byte[] query_lcase) { private void Search_wiki(Xow_wiki wiki, byte[] query, boolean case_match, boolean auto_wildcard_bgn, boolean auto_wildcard_end, int max_pages_per_wiki, int max_snips_per_page) {
Db_conn page_conn = wiki.Data__core_mgr().Tbl__page().Conn(); Db_conn page_conn = wiki.Data__core_mgr().Tbl__page().Conn();
Db_rdr page_rdr = page_conn.Stmt_sql("SELECT * FROM page WHERE page_namespace IN (0) ORDER BY page_score DESC").Exec_select__rls_auto(); Db_rdr page_rdr = page_conn.Stmt_sql("SELECT * FROM page WHERE page_namespace IN (0) ORDER BY page_score DESC").Exec_select__rls_auto();
@ -51,7 +55,7 @@ class Xosearch_fulltext_svc {
.Add_long("page_count", 0) .Add_long("page_count", 0)
); );
finder.Init(query_lcase, false, false, Byte_ascii.Star, Byte_ascii.Dash); finder.Init(query, case_match, auto_wildcard_bgn, auto_wildcard_end, Byte_ascii.Star, Byte_ascii.Dash);
try { try {
int found = 0; int found = 0;
while (page_rdr.Move_next()) { while (page_rdr.Move_next()) {
@ -64,19 +68,24 @@ class Xosearch_fulltext_svc {
if (cbk_eval.found) { if (cbk_eval.found) {
int ns_id = page_rdr.Read_int("page_namespace"); int ns_id = page_rdr.Read_int("page_namespace");
byte[] ttl_bry = page_rdr.Read_bry_by_str("page_title"); byte[] ttl_bry = page_rdr.Read_bry_by_str("page_title");
++found;
app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__wiki__update__recv", gplx.core.gfobjs.Gfobj_nde.New() app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__wiki__update__recv", gplx.core.gfobjs.Gfobj_nde.New()
.Add_bry("wiki", wiki.Domain_bry()) .Add_bry("wiki", wiki.Domain_bry())
.Add_int("found", ++found) .Add_int("found", found)
); );
Xoa_ttl ttl = wiki.Ttl_parse(ns_id, ttl_bry); Xoa_ttl ttl = wiki.Ttl_parse(ns_id, ttl_bry);
cbk_highlight.Init(wiki, ttl);
app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__page__add__recv", gplx.core.gfobjs.Gfobj_nde.New() if (found <= max_pages_per_wiki) {
cbk_highlight.Init(wiki, ttl, max_snips_per_page);
app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__page__add__recv", gplx.core.gfobjs.Gfobj_nde.New()
.Add_bry("wiki", wiki.Domain_bry()) .Add_bry("wiki", wiki.Domain_bry())
.Add_bry("page", ttl.Full_db()) .Add_bry("page", ttl.Full_db())
.Add_int("found", 0) .Add_int("found", 0)
); );
finder.Match(text_mcase, 0, text_mcase.length, cbk_highlight);
finder.Match(text_mcase, 0, text_mcase.length, cbk_highlight);
}
} }
} }
} finally { } finally {

@ -95,13 +95,14 @@ public class Xosearch_finder_cbk__eval__tst {
} }
class Xosearch_finder_cbk__eval__fxt { class Xosearch_finder_cbk__eval__fxt {
private boolean case_match = false; private boolean case_match = false;
private boolean auto_wildcard = false; private boolean auto_wildcard_bgn = false;
private boolean auto_wildcard_end = false;
private byte wildcard_byte = Byte_ascii.Star; private byte wildcard_byte = Byte_ascii.Star;
private byte not_byte = Byte_ascii.Dash; private byte not_byte = Byte_ascii.Dash;
private final Xosearch_finder_mgr finder = new Xosearch_finder_mgr(); private final Xosearch_finder_mgr finder = new Xosearch_finder_mgr();
private final Xosearch_finder_cbk__eval cbk = new Xosearch_finder_cbk__eval(); private final Xosearch_finder_cbk__eval cbk = new Xosearch_finder_cbk__eval();
public void Init__search(String query) { public void Init__search(String query) {
finder.Init(Bry_.new_u8(query), case_match, auto_wildcard, wildcard_byte, not_byte); finder.Init(Bry_.new_u8(query), case_match, auto_wildcard_bgn, auto_wildcard_end, wildcard_byte, not_byte);
} }
public void Test__eval_y(String... texts) {Test__eval(Bool_.Y, texts);} public void Test__eval_y(String... texts) {Test__eval(Bool_.Y, texts);}
public void Test__eval_n(String... texts) {Test__eval(Bool_.N, texts);} public void Test__eval_n(String... texts) {Test__eval(Bool_.N, texts);}

@ -22,47 +22,52 @@ public class Xosearch_finder_cbk__highlight implements Xosearch_finder_cbk {
private Xoa_ttl ttl; private Xoa_ttl ttl;
private final Bry_bfr tmp_bfr = Bry_bfr_.New(); private final Bry_bfr tmp_bfr = Bry_bfr_.New();
public int found; public int found;
private int max_snips_per_page;
public Xosearch_finder_cbk__highlight(Xoa_app app, Xog_cbk_trg cbk_trg) { public Xosearch_finder_cbk__highlight(Xoa_app app, Xog_cbk_trg cbk_trg) {
this.app = app; this.app = app;
this.cbk_trg = cbk_trg; this.cbk_trg = cbk_trg;
} }
public void Init(Xow_wiki wiki, Xoa_ttl ttl) { public void Init(Xow_wiki wiki, Xoa_ttl ttl, int max_snips_per_page) {
this.wiki = wiki; this.wiki = wiki;
this.ttl = ttl; this.ttl = ttl;
this.max_snips_per_page = max_snips_per_page;
found = 0; found = 0;
} }
public void Process_item_found(byte[] src, int hook_bgn, int hook_end, int word_bgn, int word_end, Xosearch_word_node term) { public void Process_item_found(byte[] src, int hook_bgn, int hook_end, int word_bgn, int word_end, Xosearch_word_node term) {
// get snip bounds by finding flanking 50 chars and then expanding to word-bounds ++found;
int snip_bgn = hook_bgn - 50; if (found <= max_snips_per_page) {
if (snip_bgn < 0) // get snip bounds by finding flanking 50 chars and then expanding to word-bounds
snip_bgn = 0; int snip_bgn = hook_bgn - 50;
else { if (snip_bgn < 0)
snip_bgn = Bry_find_.Find_bwd_ws(src, snip_bgn, 0) + 1; snip_bgn = 0;
} else {
int snip_end = hook_end + 50; snip_bgn = Bry_find_.Find_bwd_ws(src, snip_bgn, 0) + 1;
if (snip_end >= src.length) }
snip_end = src.length; int snip_end = hook_end + 50;
else { if (snip_end >= src.length)
snip_end = Bry_find_.Find_fwd_until_ws(src, snip_end, src.length);
if (snip_end == Bry_find_.Not_found) { // when snip_end == src.length
snip_end = src.length; snip_end = src.length;
else {
snip_end = Bry_find_.Find_fwd_until_ws(src, snip_end, src.length);
if (snip_end == Bry_find_.Not_found) { // when snip_end == src.length
snip_end = src.length;
}
} }
}
// build snip // build snip
Add_snip(tmp_bfr, src, snip_bgn, hook_bgn); Add_snip(tmp_bfr, src, snip_bgn, hook_bgn);
tmp_bfr.Add_str_a7("<span class='snip_highlight'>"); tmp_bfr.Add_str_a7("<span class='snip_highlight'>");
Add_snip(tmp_bfr, src, hook_bgn, hook_end); Add_snip(tmp_bfr, src, hook_bgn, hook_end);
tmp_bfr.Add_str_a7("</span>"); tmp_bfr.Add_str_a7("</span>");
Add_snip(tmp_bfr, src, hook_end, snip_end); Add_snip(tmp_bfr, src, hook_end, snip_end);
// send notification // send notification
app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__line__add__recv", gplx.core.gfobjs.Gfobj_nde.New() app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__line__add__recv", gplx.core.gfobjs.Gfobj_nde.New()
.Add_bry("wiki", wiki.Domain_bry()) .Add_bry("wiki", wiki.Domain_bry())
.Add_bry("page", ttl.Full_db()) .Add_bry("page", ttl.Full_db())
.Add_int("line", ++found) .Add_int("line", found)
.Add_bry("html", tmp_bfr.To_bry_and_clear()) .Add_bry("html", tmp_bfr.To_bry_and_clear())
); );
}
app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__page__update__recv", gplx.core.gfobjs.Gfobj_nde.New() app.Gui__cbk_mgr().Send_json(cbk_trg, "xo.search_fulltext.results__page__update__recv", gplx.core.gfobjs.Gfobj_nde.New()
.Add_bry("wiki", wiki.Domain_bry()) .Add_bry("wiki", wiki.Domain_bry())
.Add_bry("page", ttl.Full_db()) .Add_bry("page", ttl.Full_db())

@ -26,13 +26,13 @@ public class Xosearch_finder_mgr {
private final Xosearch_word_bounds word_bounds = new Xosearch_word_bounds(); private final Xosearch_word_bounds word_bounds = new Xosearch_word_bounds();
public byte[] Query() {return query;} private byte[] query; public byte[] Query() {return query;} private byte[] query;
public void Init(byte[] query, boolean case_match, boolean auto_wildcard, byte wildchar_byte, byte not_byte) { public void Init(byte[] query, boolean case_match, boolean auto_wildcard_bgn, boolean auto_wildcard_end, byte wildchar_byte, byte not_byte) {
this.query = query; this.query = query;
// create a new hook_trie based on case_match // create a new hook_trie based on case_match
this.hook_trie = case_match ? Btrie_slim_mgr.cs() : Btrie_slim_mgr.ci_u8(); this.hook_trie = case_match ? Btrie_slim_mgr.cs() : Btrie_slim_mgr.ci_u8();
// create a new tree_root for eval // create a new tree_root for eval
this.tree_root = Xosearch_word_node_.New_root(parser.Parse_or_invalid(query, auto_wildcard).Root, hook_trie, wildchar_byte, not_byte); this.tree_root = Xosearch_word_node_.New_root(parser.Parse_or_invalid(query).Root, hook_trie, auto_wildcard_bgn, auto_wildcard_end, wildchar_byte, not_byte);
} }
public void Match(byte[] src, int src_bgn, int src_end, Xosearch_finder_cbk cbk) { public void Match(byte[] src, int src_bgn, int src_end, Xosearch_finder_cbk cbk) {
// init and clear // init and clear

@ -18,7 +18,7 @@ import gplx.core.btries.*;
import gplx.core.intls.*; import gplx.core.intls.*;
public class Xosearch_word_lang { public class Xosearch_word_lang {
private final Btrie_slim_mgr ws_bgn = Btrie_slim_mgr.cs() private final Btrie_slim_mgr ws_bgn = Btrie_slim_mgr.cs()
.Add_many_str("\t", "\n", "\r", " ", "/"); .Add_many_str("\t", "\n", "\r", " ", "/", "(", ")");
private final Btrie_slim_mgr ws_end; private final Btrie_slim_mgr ws_end;
private final Btrie_slim_mgr punct_bgn = Btrie_slim_mgr.cs() private final Btrie_slim_mgr punct_bgn = Btrie_slim_mgr.cs()
.Add_many_str(".", ",", "?", "!", ":", ";", "'", "\"") .Add_many_str(".", ",", "?", "!", ":", ";", "'", "\"")

@ -17,7 +17,7 @@ package gplx.xowa.addons.wikis.searchs.fulltexts.finders; import gplx.*; import
import gplx.core.btries.*; import gplx.core.btries.*;
import gplx.xowa.addons.wikis.searchs.searchers.crts.*; import gplx.xowa.addons.wikis.searchs.searchers.crts.*;
public class Xosearch_word_node_ { public class Xosearch_word_node_ {
public static Xosearch_word_node New_root(Srch_crt_itm src, Btrie_slim_mgr word_trie, byte wildchar_byte, byte not_byte) { public static Xosearch_word_node New_root(Srch_crt_itm src, Btrie_slim_mgr word_trie, boolean auto_wildcard_bgn, boolean auto_wildcard_end, byte wildchar_byte, byte not_byte) {
Xosearch_word_node trg = new Xosearch_word_node(); Xosearch_word_node trg = new Xosearch_word_node();
trg.tid = src.Tid; trg.tid = src.Tid;
@ -34,14 +34,14 @@ public class Xosearch_word_node_ {
int hook_end = word_orig_len; int hook_end = word_orig_len;
// handle wildcard at bgn; EX: "*a" // handle wildcard at bgn; EX: "*a"
boolean wildcard_at_bgn = false; boolean wildcard_at_bgn = auto_wildcard_bgn;
if (word_orig_len > hook_bgn + 1 && word_orig[hook_bgn] == wildchar_byte) { if (word_orig_len > hook_bgn + 1 && word_orig[hook_bgn] == wildchar_byte) {
wildcard_at_bgn = true; wildcard_at_bgn = true;
hook_bgn++; hook_bgn++;
} }
// handle wildcard at end; EX: "a*" // handle wildcard at end; EX: "a*"
boolean wildcard_at_end = false; boolean wildcard_at_end = auto_wildcard_end;
if (word_orig_len > hook_bgn + 1 && word_orig[hook_end - 1] == wildchar_byte) { if (word_orig_len > hook_bgn + 1 && word_orig[hook_end - 1] == wildchar_byte) {
wildcard_at_end = true; wildcard_at_end = true;
hook_end--; hook_end--;
@ -69,7 +69,7 @@ public class Xosearch_word_node_ {
trg.subs = trg_subs; trg.subs = trg_subs;
int len = src_subs.length; int len = src_subs.length;
for (int i = 0; i < len; i++) { for (int i = 0; i < len; i++) {
trg.subs[i] = New_root(src_subs[i], word_trie, wildchar_byte, not_byte); trg.subs[i] = New_root(src_subs[i], word_trie, auto_wildcard_bgn, auto_wildcard_end, wildchar_byte, not_byte);
} }
return trg; return trg;

@ -16,14 +16,41 @@ Apache License: https://github.com/gnosygnu/xowa/blob/master/LICENSE-APACHE2.txt
package gplx.xowa.addons.wikis.searchs.fulltexts.specials; import gplx.*; import gplx.xowa.*; import gplx.xowa.addons.*; import gplx.xowa.addons.wikis.*; import gplx.xowa.addons.wikis.searchs.*; import gplx.xowa.addons.wikis.searchs.fulltexts.*; package gplx.xowa.addons.wikis.searchs.fulltexts.specials; import gplx.*; import gplx.xowa.*; import gplx.xowa.addons.*; import gplx.xowa.addons.wikis.*; import gplx.xowa.addons.wikis.searchs.*; import gplx.xowa.addons.wikis.searchs.fulltexts.*;
import gplx.langs.mustaches.*; import gplx.langs.mustaches.*;
public class Xosearch_fulltext_doc implements Mustache_doc_itm { public class Xosearch_fulltext_doc implements Mustache_doc_itm {
public Xosearch_fulltext_doc() { private final boolean case_match, auto_wildcard_bgn, auto_wildcard_end;
private final int max_pages_per_wiki, max_snips_per_page;
private final String wikis, namespaces;
public Xosearch_fulltext_doc
( boolean case_match, boolean auto_wildcard_bgn, boolean auto_wildcard_end
, int max_pages_per_wiki, int max_snips_per_page
, String wikis, String namespaces) {
this.case_match = case_match;
this.auto_wildcard_bgn = auto_wildcard_bgn;
this.auto_wildcard_end = auto_wildcard_end;
this.max_pages_per_wiki = max_pages_per_wiki;
this.max_snips_per_page = max_snips_per_page;
this.wikis = wikis;
this.namespaces = namespaces;
} }
public boolean Mustache__write(String key, Mustache_bfr bfr) { public boolean Mustache__write(String key, Mustache_bfr bfr) {
// if (String_.Eq(key, "domain")) bfr.Add_str_u8(domain); if (String_.Eq(key, "wikis"))
// else return false; bfr.Add_str_u8(wikis);
else if (String_.Eq(key, "namespaces"))
bfr.Add_str_u8(namespaces);
else if (String_.Eq(key, "max_pages_per_wiki"))
bfr.Add_int(max_pages_per_wiki);
else if (String_.Eq(key, "max_snips_per_page"))
bfr.Add_int(max_snips_per_page);
else
return false;
return true; return true;
} }
public Mustache_doc_itm[] Mustache__subs(String key) { public Mustache_doc_itm[] Mustache__subs(String key) {
if (String_.Eq(key, "case_match"))
return Mustache_doc_itm_.Ary__bool(case_match);
else if (String_.Eq(key, "auto_wildcard_bgn"))
return Mustache_doc_itm_.Ary__bool(auto_wildcard_bgn);
else if (String_.Eq(key, "auto_wildcard_end"))
return Mustache_doc_itm_.Ary__bool(auto_wildcard_end);
return Mustache_doc_itm_.Ary__empty; return Mustache_doc_itm_.Ary__empty;
} }
} }

@ -17,12 +17,25 @@ package gplx.xowa.addons.wikis.searchs.fulltexts.specials; import gplx.*; import
import gplx.xowa.specials.*; import gplx.langs.mustaches.*; import gplx.xowa.wikis.pages.*; import gplx.xowa.wikis.pages.tags.*; import gplx.xowa.specials.*; import gplx.langs.mustaches.*; import gplx.xowa.wikis.pages.*; import gplx.xowa.wikis.pages.tags.*;
import gplx.dbs.*; import gplx.dbs.*;
class Xosearch_fulltext_html extends Xow_special_wtr__base { class Xosearch_fulltext_html extends Xow_special_wtr__base {
public Xosearch_fulltext_html() { private final boolean case_match, auto_wildcard_bgn, auto_wildcard_end;
private final int max_pages_per_wiki, max_snips_per_page;
private final String wikis, namespaces;
public Xosearch_fulltext_html
( boolean case_match, boolean auto_wildcard_bgn, boolean auto_wildcard_end
, int max_pages_per_wiki, int max_snips_per_page
, String wikis, String namespaces) {
this.case_match = case_match;
this.auto_wildcard_bgn = auto_wildcard_bgn;
this.auto_wildcard_end = auto_wildcard_end;
this.max_pages_per_wiki = max_pages_per_wiki;
this.max_snips_per_page = max_snips_per_page;
this.wikis = wikis;
this.namespaces = namespaces;
} }
@Override protected Io_url Get_addon_dir(Xoa_app app) {return Addon_dir(app);} @Override protected Io_url Get_addon_dir(Xoa_app app) {return Addon_dir(app);}
@Override protected Io_url Get_mustache_fil(Io_url addon_dir) {return addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.template.html");} @Override protected Io_url Get_mustache_fil(Io_url addon_dir) {return addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.template.html");}
@Override protected Mustache_doc_itm Bld_mustache_root(Xoa_app app) { @Override protected Mustache_doc_itm Bld_mustache_root(Xoa_app app) {
return new Xosearch_fulltext_doc(); return new Xosearch_fulltext_doc(case_match, auto_wildcard_bgn, auto_wildcard_end, max_pages_per_wiki, max_snips_per_page, wikis, namespaces);
} }
@Override protected void Bld_tags(Xoa_app app, Io_url addon_dir, Xopage_html_data page_data) { @Override protected void Bld_tags(Xoa_app app, Io_url addon_dir, Xopage_html_data page_data) {
Xopg_tag_mgr head_tags = page_data.Head_tags(); Xopg_tag_mgr head_tags = page_data.Head_tags();
@ -38,6 +51,8 @@ class Xosearch_fulltext_html extends Xow_special_wtr__base {
head_tags.Add(Xopg_tag_itm.New_css_file(addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.css"))); head_tags.Add(Xopg_tag_itm.New_css_file(addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.css")));
head_tags.Add(Xopg_tag_itm.New_js_file(addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.js"))); head_tags.Add(Xopg_tag_itm.New_js_file(addon_dir.GenSubFil_nest("bin", "xosearch_fulltext.js")));
page_data.Js_enabled_y_();
} }
public static Io_url Addon_dir(Xoa_app app) { public static Io_url Addon_dir(Xoa_app app) {
return app.Fsys_mgr().Http_root().GenSubDir_nest("bin", "any", "xowa", "addon", "wiki", "search", "fulltext"); return app.Fsys_mgr().Http_root().GenSubDir_nest("bin", "any", "xowa", "addon", "wiki", "search", "fulltext");

@ -19,11 +19,7 @@ public class Xosearch_fulltext_special implements Xow_special_page {
public void Special__gen(Xow_wiki wiki, Xoa_page page, Xoa_url url, Xoa_ttl ttl) { public void Special__gen(Xow_wiki wiki, Xoa_page page, Xoa_url url, Xoa_ttl ttl) {
// Gfo_qarg_mgr url_args = new Gfo_qarg_mgr().Init(url.Qargs_ary()); // Gfo_qarg_mgr url_args = new Gfo_qarg_mgr().Init(url.Qargs_ary());
// String domain = url_args.Read_str_or("domain", "[xowa.home]"); new Xosearch_fulltext_html(false, false, false, 20, 10, wiki.Domain_str(), "0|4").Bld_page_by_mustache(wiki.App(), page, this);
// String db = url_args.Read_str_or("db", "core");
// String sql = url_args.Read_str_or("sql", "SELECT * FROM xowa_cfg;");
new Xosearch_fulltext_html().Bld_page_by_mustache(wiki.App(), page, this);
} }
Xosearch_fulltext_special(Xow_special_meta special__meta) {this.special__meta = special__meta;} Xosearch_fulltext_special(Xow_special_meta special__meta) {this.special__meta = special__meta;}
public Xow_special_meta Special__meta() {return special__meta;} private final Xow_special_meta special__meta; public Xow_special_meta Special__meta() {return special__meta;} private final Xow_special_meta special__meta;

@ -60,7 +60,7 @@ public class Srch_search_mgr implements Gfo_invk {
cur_cmd.Cancel(); cur_cmd.Cancel();
// create new one; run it; // create new one; run it;
Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(qry.Phrase.Compiled, qry.Phrase.Wildcard); Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(qry.Phrase.Compiled);
if (crt_mgr == Srch_crt_mgr.Invalid) return; // handle "\\" which is invalid or other fatal errors if (crt_mgr == Srch_crt_mgr.Invalid) return; // handle "\\" which is invalid or other fatal errors
Srch_rslt_list rslts_list = cache__rslts.Get_or_new(crt_mgr.Key); Srch_rslt_list rslts_list = cache__rslts.Get_or_new(crt_mgr.Key);
cur_cmd = new Srch_search_cmd(this, qry, crt_mgr, cbk, rslts_list); cur_cmd = new Srch_search_cmd(this, qry, crt_mgr, cbk, rslts_list);

@ -26,7 +26,7 @@ public class Srch_crt_parser {
this.scanner = new Srch_crt_scanner(trie_bldr); this.scanner = new Srch_crt_scanner(trie_bldr);
} }
public int Next_uid() {return ++uid_next;} public int Next_uid() {return ++uid_next;}
public Srch_crt_mgr Parse_or_invalid(byte[] src, boolean auto_wildcard) { public Srch_crt_mgr Parse_or_invalid(byte[] src) {
this.uid_next = -1; this.uid_next = -1;
Srch_crt_tkn[] tkns_ary = scanner.Scan(src); Srch_crt_tkn[] tkns_ary = scanner.Scan(src);

@ -60,7 +60,7 @@ class Srch_crt_parser_fxt {
} }
public void Test__parse(String src_str, String expd) { public void Test__parse(String src_str, String expd) {
byte[] src_bry = Bry_.new_a7(src_str); byte[] src_bry = Bry_.new_a7(src_str);
Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(src_bry, Bool_.N); Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(src_bry);
Tfds.Eq(expd, String_.new_u8(visitor__to_str.Print(crt_mgr.Root))); Tfds.Eq(expd, String_.new_u8(visitor__to_str.Print(crt_mgr.Root)));
} }
} }

@ -39,7 +39,7 @@ class Srch_page_tbl_wkr_fxt {
} }
public void Test__to_bry_or_null(String src_str, String expd) { public void Test__to_bry_or_null(String src_str, String expd) {
byte[] src_bry = Bry_.new_a7(src_str); byte[] src_bry = Bry_.new_a7(src_str);
Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(src_bry, Bool_.N); Srch_crt_mgr crt_mgr = crt_parser.Parse_or_invalid(src_bry);
Tfds.Eq(expd, String_.new_u8(Srch_page_tbl_wkr.To_bry_or_null(tmp_bfr, Srch_search_addon.Wildcard__star, crt_mgr))); Tfds.Eq(expd, String_.new_u8(Srch_page_tbl_wkr.To_bry_or_null(tmp_bfr, Srch_search_addon.Wildcard__star, crt_mgr)));
} }
} }

@ -142,6 +142,7 @@ public class Xoh_page_wtr_wkr {
} }
} }
if ( wiki.Domain_tid() != Xow_domain_tid_.Tid__home // allow home wiki to use javascript if ( wiki.Domain_tid() != Xow_domain_tid_.Tid__home // allow home wiki to use javascript
&& !page.Html_data().Js_enabled() // allow special pages to use js
&& !page_tid_uses_pre) { // if .js, .css or .lua, skip test; may have js fragments, but entire text is escaped and put in pre; don't show spurious warning; DATE:2013-11-21 && !page_tid_uses_pre) { // if .js, .css or .lua, skip test; may have js fragments, but entire text is escaped and put in pre; don't show spurious warning; DATE:2013-11-21
wiki.Html_mgr().Js_cleaner().Clean_bfr(wiki, page_ttl, bfr, bfr_page_bgn); wiki.Html_mgr().Js_cleaner().Clean_bfr(wiki, page_ttl, bfr, bfr_page_bgn);
} }

@ -23,6 +23,7 @@ public class Xopage_html_data {
public byte[] Display_ttl() {return display_ttl;} private byte[] display_ttl; public byte[] Display_ttl() {return display_ttl;} private byte[] display_ttl;
public byte[] Body() {return body;} private final byte[] body; public byte[] Body() {return body;} private final byte[] body;
public boolean Cbk_enabled() {return cbk_enabled;} private boolean cbk_enabled; public void Cbk_enabled_y_() {this.cbk_enabled = true;} public boolean Cbk_enabled() {return cbk_enabled;} private boolean cbk_enabled; public void Cbk_enabled_y_() {this.cbk_enabled = true;}
public boolean Js_enabled() {return js_enabled;} private boolean js_enabled; public void Js_enabled_y_() {this.js_enabled = true;}
public Xopg_tag_mgr Head_tags() {return head_tags;} private final Xopg_tag_mgr head_tags = new Xopg_tag_mgr(Bool_.Y); public Xopg_tag_mgr Head_tags() {return head_tags;} private final Xopg_tag_mgr head_tags = new Xopg_tag_mgr(Bool_.Y);
public Xopg_tag_mgr Tail_tags() {return tail_tags;} private final Xopg_tag_mgr tail_tags = new Xopg_tag_mgr(Bool_.N); public Xopg_tag_mgr Tail_tags() {return tail_tags;} private final Xopg_tag_mgr tail_tags = new Xopg_tag_mgr(Bool_.N);
@ -35,6 +36,7 @@ public class Xopage_html_data {
html_data.Custom_head_tags().Copy(head_tags); html_data.Custom_head_tags().Copy(head_tags);
html_data.Custom_tail_tags().Copy(tail_tags); html_data.Custom_tail_tags().Copy(tail_tags);
html_data.Cbk_enabled_(cbk_enabled); html_data.Cbk_enabled_(cbk_enabled);
html_data.Js_enabled_(js_enabled);
} }
public static Xopage_html_data err_(String msg) {return new Xopage_html_data(Bry_.Empty, Bry_.new_u8(msg));} public static Xopage_html_data err_(String msg) {return new Xopage_html_data(Bry_.Empty, Bry_.new_u8(msg));}

@ -42,7 +42,8 @@ public class Xopg_html_data {
public byte[] Edit_preview_w_dbg() {return Bry_.Add(xtn_scribunto_dbg, edit_preview);} public void Edit_preview_(byte[] v) {edit_preview = v;} private byte[] edit_preview = Bry_.Empty; public byte[] Edit_preview_w_dbg() {return Bry_.Add(xtn_scribunto_dbg, edit_preview);} public void Edit_preview_(byte[] v) {edit_preview = v;} private byte[] edit_preview = Bry_.Empty;
public int Lnke_autonumber_next() {return lnke_autonumber++;} private int lnke_autonumber = 1; public int Lnke_autonumber_next() {return lnke_autonumber++;} private int lnke_autonumber = 1;
public int Sect_uid() {return sect_uid;} private int sect_uid = -1; public int Sect_uid_next() {return ++sect_uid;} public int Sect_uid() {return sect_uid;} private int sect_uid = -1; public int Sect_uid_next() {return ++sect_uid;}
public boolean Cbk_enabled() {return cbk_enabled;} private boolean cbk_enabled; public void Cbk_enabled_(boolean v) {this.cbk_enabled = v;} public boolean Cbk_enabled() {return cbk_enabled;} private boolean cbk_enabled; public void Cbk_enabled_(boolean v) {this.cbk_enabled = v;}
public boolean Js_enabled() {return js_enabled;} private boolean js_enabled; public void Js_enabled_(boolean v) {this.js_enabled = v;}
public boolean Hdump_exists() {return hdump_exists;} private boolean hdump_exists; public void Hdump_exists_(boolean v) {this.hdump_exists = v;} public boolean Hdump_exists() {return hdump_exists;} private boolean hdump_exists; public void Hdump_exists_(boolean v) {this.hdump_exists = v;}
public byte[] Catpage_data() {return catpage_data;} private byte[] catpage_data; public void Catpage_data_(byte[] v) {this.catpage_data = v;} public byte[] Catpage_data() {return catpage_data;} private byte[] catpage_data; public void Catpage_data_(byte[] v) {this.catpage_data = v;}

Loading…
Cancel
Save