From 5fbf168fb7e5ff72d40034abdc2ceaa73d0be330 Mon Sep 17 00:00:00 2001 From: gnosygnu Date: Thu, 15 Dec 2016 02:10:09 -0500 Subject: [PATCH] Cfg: Convert 'App - Content Apps' --- 100_core/src/gplx/core/envs/Process_adp.java | 18 ++++ 400_xowa/src/gplx/xowa/Xoae_app.java | 2 +- .../gplx/xowa/addons/apps/cfgs/Xocfg_mgr.java | 11 +++ .../apps/cfgs/mgrs/dflts/Xocfg_dflt_mgr.java | 2 +- .../specials/edits/objs/Xoedit_itm_html.java | 8 +- .../gplx/xowa/apps/progs/Xoa_prog_mgr.java | 93 +++++++++---------- .../gplx/xowa/parsers/lnkes/Xop_lnke_wkr.java | 2 +- .../gplx/xowa/parsers/xndes/Xop_xnde_wkr.java | 4 +- .../gplx/xowa/users/prefs/Prefs_mgr_tst.java | 14 +-- 9 files changed, 88 insertions(+), 66 deletions(-) diff --git a/100_core/src/gplx/core/envs/Process_adp.java b/100_core/src/gplx/core/envs/Process_adp.java index 24c840d2e..f71d8a1d9 100644 --- a/100_core/src/gplx/core/envs/Process_adp.java +++ b/100_core/src/gplx/core/envs/Process_adp.java @@ -132,6 +132,24 @@ public class Process_adp implements Gfo_invk, Rls_able { : exe_args ; } + + public void Exe_and_args_(String exe, String args) { + Io_url exe_url = Bry_fmtr_eval_mgr_.Eval_url(this.cmd_url_eval, Bry_.new_u8(exe)); + this.Exe_url_(exe_url).Tmp_dir_(exe_url.OwnerDir()); + this.Args_fmtr().Fmt_(args); + } + public static Process_adp New(Gfo_usr_dlg usr_dlg, Bry_fmtr_eval_mgr eval_mgr, byte run_mode, int timeout, String exe, String args, String... args_keys) { + Process_adp rv = new Process_adp(); + rv.Prog_dlg_(usr_dlg); + rv.Run_mode_(run_mode); + rv.Thread_timeout_seconds_(timeout); + + rv.cmd_url_eval = eval_mgr; + Io_url exe_url = Bry_fmtr_eval_mgr_.Eval_url(eval_mgr, Bry_.new_u8(exe)); + rv.Exe_url_(exe_url).Tmp_dir_(exe_url.OwnerDir()); + rv.Args_fmtr().Fmt_(args).Keys_(args_keys); + return rv; + } private Bry_fmtr notify_fmtr = Bry_fmtr.new_("", "process_exe_name", "process_exe_args", "process_seconds"); Bry_bfr notify_bfr = Bry_bfr_.Reset(255); public Process UnderProcess() {return process;} Process process; public void Rls() {if (process != null) process.destroy();} diff --git a/400_xowa/src/gplx/xowa/Xoae_app.java b/400_xowa/src/gplx/xowa/Xoae_app.java index be1d4f315..8ebe5bba3 100644 --- a/400_xowa/src/gplx/xowa/Xoae_app.java +++ b/400_xowa/src/gplx/xowa/Xoae_app.java @@ -148,7 +148,7 @@ public class Xoae_app implements Xoa_app, Gfo_invk { stage = Xoa_stage_.Tid_init; user.Init_by_app(this); cfg.Init_by_app(this); - prog_mgr.Init_by_app(url_cmd_eval); + prog_mgr.Init_by_app(this, url_cmd_eval); xtn_mgr.Init_by_app(this); gui_mgr.Init_by_app(); html__css_installer.Init_by_app(this); diff --git a/400_xowa/src/gplx/xowa/addons/apps/cfgs/Xocfg_mgr.java b/400_xowa/src/gplx/xowa/addons/apps/cfgs/Xocfg_mgr.java index 762c54a7d..544849d42 100644 --- a/400_xowa/src/gplx/xowa/addons/apps/cfgs/Xocfg_mgr.java +++ b/400_xowa/src/gplx/xowa/addons/apps/cfgs/Xocfg_mgr.java @@ -108,4 +108,15 @@ public class Xocfg_mgr { cache_mgr.Del(ctx, key); } public static String Ctx__app = "app"; + public static String[] Parse_io_cmd(String raw) { + String[] rv = new String[2]; + rv[0] = ""; + rv[1] = ""; + int pos = String_.FindFwd(raw, "\n"); + if (pos != Bry_find_.Not_found) { + rv[0] = String_.Mid(raw, 0, pos); + rv[1] = String_.Mid(raw, pos + 1); + } + return rv; + } } diff --git a/400_xowa/src/gplx/xowa/addons/apps/cfgs/mgrs/dflts/Xocfg_dflt_mgr.java b/400_xowa/src/gplx/xowa/addons/apps/cfgs/mgrs/dflts/Xocfg_dflt_mgr.java index 505d54ea1..d7b33c419 100644 --- a/400_xowa/src/gplx/xowa/addons/apps/cfgs/mgrs/dflts/Xocfg_dflt_mgr.java +++ b/400_xowa/src/gplx/xowa/addons/apps/cfgs/mgrs/dflts/Xocfg_dflt_mgr.java @@ -25,7 +25,7 @@ public class Xocfg_dflt_mgr { } public void Init_by_app(Xoa_app app) { Xocfg_dflt_loader loader = new Xocfg_dflt_loader(); - loader.Load_by_file(this, app.Fsys_mgr().Bin_plat_dir().GenSubFil_nest("cfg", "xo.cfg.dflt.json")); + loader.Load_by_file(this, app.Fsys_mgr().Bin_plat_dir().GenSubFil_nest("xowa", "cfg", "xo.cfg.dflt.json")); } public String Get_or(String key, String or) { Xocfg_dflt_itm itm = (Xocfg_dflt_itm)hash.Get_by(key); diff --git a/400_xowa/src/gplx/xowa/addons/apps/cfgs/specials/edits/objs/Xoedit_itm_html.java b/400_xowa/src/gplx/xowa/addons/apps/cfgs/specials/edits/objs/Xoedit_itm_html.java index 856980aef..6f619cf77 100644 --- a/400_xowa/src/gplx/xowa/addons/apps/cfgs/specials/edits/objs/Xoedit_itm_html.java +++ b/400_xowa/src/gplx/xowa/addons/apps/cfgs/specials/edits/objs/Xoedit_itm_html.java @@ -46,16 +46,14 @@ public class Xoedit_itm_html { bfr.Add_str_u8_fmt("\n"); break; case Xoitm_gui_tid.Tid__io_cmd: - String[] fields = String_.Split(data, "\n"); - String exe = fields.length > 0 && !String_.Eq(fields[0], "") ? fields[0] : ""; - String arg = fields.length > 1 ? fields[1] : ""; + String[] lines = Xocfg_mgr.Parse_io_cmd(data); bfr.Add_str_u8_fmt ( "\n" + "
\n" - , gui_type_key, key, exe); + , gui_type_key, key, lines[0]); bfr.Add_str_u8_fmt ( "\n" - , gui_type_key, key, arg); + , gui_type_key, key, lines[1]); break; default: break; diff --git a/400_xowa/src/gplx/xowa/apps/progs/Xoa_prog_mgr.java b/400_xowa/src/gplx/xowa/apps/progs/Xoa_prog_mgr.java index 57515d889..a9c247882 100644 --- a/400_xowa/src/gplx/xowa/apps/progs/Xoa_prog_mgr.java +++ b/400_xowa/src/gplx/xowa/apps/progs/Xoa_prog_mgr.java @@ -18,8 +18,11 @@ along with this program. If not, see . package gplx.xowa.apps.progs; import gplx.*; import gplx.xowa.*; import gplx.xowa.apps.*; import gplx.xowa.apps.fsys.*; import gplx.xowa.files.*; import gplx.core.envs.*; public class Xoa_prog_mgr implements Gfo_invk { - public void Init_by_app(Xoa_fsys_eval cmd_eval) { - Gfo_usr_dlg usr_dlg = Xoa_app_.Usr_dlg(); + private Gfo_usr_dlg usr_dlg; + private Process_adp app_web; + private Process_adp[] apps_by_ext = new Process_adp[Xof_ext_.Id__max]; + public void Init_by_app(Xoa_app app, Xoa_fsys_eval cmd_eval) { + this.usr_dlg = Xoa_app_.Usr_dlg(); Process_adp.ini_(this, usr_dlg, app_query_img_size , cmd_eval, Process_adp.Run_mode_sync_timeout , 10 * 60, "~{<>bin_plat_dir<>}imagemagick\\identify", "-ping -format \"<{%w,%h}>\" \"~{file}\"", "file"); Process_adp.ini_(this, usr_dlg, app_resize_img , cmd_eval, Process_adp.Run_mode_sync_timeout , 10 * 60, "~{<>bin_plat_dir<>}imagemagick\\convert", "\"~{source}\" -coalesce -resize ~{width}x~{height} \"~{target}\"", "source", "target", "width", "height"); Process_adp.ini_(this, usr_dlg, app_convert_svg_to_png , cmd_eval, Process_adp.Run_mode_sync_timeout , 10 * 60, "~{<>bin_plat_dir<>}inkscape\\inkscape", "-z -w ~{width} -f \"~{source}\" -e \"~{target}\"", "source", "target", "width").Thread_kill_name_("inkscape.exe"); // // -z=without-gui; -w=width; -f=file -e=export-png @@ -35,22 +38,21 @@ public class Xoa_prog_mgr implements Gfo_invk { Process_adp.ini_(this, usr_dlg, app_abc2ly , cmd_eval, Process_adp.Run_mode_sync_timeout , 1 * 60, "~{<>bin_plat_dir<>}lilypond\\usr\\bin\\python.exe", "abc2ly.py -s \"--output=~{target}\" \"~{source}\"", "source", "target"); Process_adp.ini_(this, usr_dlg, app_trim_img , cmd_eval, Process_adp.Run_mode_sync_timeout , 1 * 60, "~{<>bin_plat_dir<>}imagemagick\\convert", "-trim \"~{source}\" \"~{target}\"", "source", "target"); Process_adp.ini_(this, usr_dlg, app_convert_midi_to_ogg , cmd_eval, Process_adp.Run_mode_sync_timeout , 1 * 60, "~{<>bin_plat_dir<>}timidity\\timidity", "-Ov \"--output-file=~{target}\" \"~{source}\"", "source", "target"); - Process_adp.ini_(this, usr_dlg, app_view_web , cmd_eval, Process_adp.Run_mode_async , 0 , "cmd", "/c start \"~{url}\"", "url"); Process_adp.ini_(this, usr_dlg, app_view_text , cmd_eval, Process_adp.Run_mode_async , 0 , "cmd", "/c start \"~{url}\"", "url"); - int cmds_view_file_by_ext_len = cmds_view_file_by_ext.length; - for (int i= 0; i < cmds_view_file_by_ext_len; i++) { - Process_adp cmd = new Process_adp(); - cmds_view_file_by_ext [i] = cmd; - Process_adp.ini_(this, usr_dlg, cmd , cmd_eval, Process_adp.Run_mode_async , 0 , "cmd", "/c start \"~{file}\"", "file"); + + for (int i = 0; i < apps_by_ext.length; i++) { + apps_by_ext[i] = Process_adp.New(usr_dlg, cmd_eval, Process_adp.Run_mode_async, 0, "cmd", "/c start \"\" \"~{file}\"", "file"); } + app_web = Process_adp.New(usr_dlg, cmd_eval, Process_adp.Run_mode_async, 0, "cmd", "/c start \"\" \"~{url}\"", "url"); + app.Cfg().Bind_many_app(this, Cfg__web, Cfg__media, Cfg__image, Cfg__svg, Cfg__pdf, Cfg__djvu); } + private Process_adp App_by_ext_key(String ext) {return apps_by_ext[Xof_ext_.Get_id_by_ext_(Bry_.new_a7(ext))];} public Process_adp App_query_img_size() {return app_query_img_size;} private Process_adp app_query_img_size = new Process_adp(); public Process_adp App_resize_img() {return app_resize_img;} private Process_adp app_resize_img = new Process_adp(); public Process_adp App_convert_svg_to_png() {return app_convert_svg_to_png;} private Process_adp app_convert_svg_to_png = new Process_adp(); public Process_adp App_convert_tex_to_dvi() {return app_convert_tex_to_dvi;} private Process_adp app_convert_tex_to_dvi = new Process_adp(); public Process_adp App_convert_dvi_to_png() {return app_convert_dvi_to_png;} private Process_adp app_convert_dvi_to_png = new Process_adp(); public Process_adp App_convert_djvu_to_tiff() {return app_convert_djvu_to_tiff;} private Process_adp app_convert_djvu_to_tiff = new Process_adp(); - public Process_adp App_view_web() {return app_view_web;} private Process_adp app_view_web = new Process_adp(); public Process_adp App_view_text() {return app_view_text;} private Process_adp app_view_text = new Process_adp(); public Process_adp App_decompress_bz2() {return app_decompress_bz2;} private Process_adp app_decompress_bz2 = new Process_adp(); public Process_adp App_decompress_zip() {return app_decompress_zip;} private Process_adp app_decompress_zip = new Process_adp(); @@ -69,7 +71,7 @@ public class Xoa_prog_mgr implements Gfo_invk { else if (ctx.Match(k, Invk_convert_tex_to_dvi)) return app_convert_tex_to_dvi; else if (ctx.Match(k, Invk_convert_dvi_to_png)) return app_convert_dvi_to_png; else if (ctx.Match(k, Invk_convert_djvu_to_tiff)) return app_convert_djvu_to_tiff; - else if (ctx.Match(k, Invk_view_web)) return app_view_web; + else if (ctx.Match(k, Invk_view_web)) return app_web; else if (ctx.Match(k, Invk_decompress_bz2)) return app_decompress_bz2; else if (ctx.Match(k, Invk_decompress_zip)) return app_decompress_zip; else if (ctx.Match(k, Invk_decompress_gz)) return app_decompress_gz; @@ -79,50 +81,43 @@ public class Xoa_prog_mgr implements Gfo_invk { else if (ctx.Match(k, Invk_abc2ly)) return app_abc2ly; else if (ctx.Match(k, Invk_convert_midi_to_ogg)) return app_convert_midi_to_ogg; else if (ctx.Match(k, Invk_trim_img)) return app_trim_img; - else if (ctx.Match(k, Invk_web)) return app_view_web; - else if (ctx.Match(k, Invk_text)) return app_view_text; - else if (ctx.Match(k, Invk_image)) return Init_by_exts("png", "jpg", "jpeg", "gif", "tif", "tiff", "svg"); - else if (ctx.Match(k, Invk_media)) return Init_by_exts("mid", "ogg", "oga", "ogv", "webm"); - else if (ctx.Match(k, Invk_svg)) return Init_by_exts("svg"); - else if (ctx.Match(k, Invk_pdf)) return Init_by_exts("pdf"); - else if (ctx.Match(k, Invk_djvu)) return Init_by_exts("djvu"); - else if (ctx.Match(k, Invk_view_by_ext)) Exec_view_by_ext(m.ReadStr("exts"), m.ReadStr("cmd"), m.ReadStr("args")); + + else if (String_.Eq(k, Cfg__web)) {Init_cmd(m.ReadStr("v"), app_web);} + else if (String_.Eq(k, Cfg__media)) {Init_cmd(m.ReadStr("v"), Xof_ext_.Id_ogv, Xof_ext_.Id_webm, Xof_ext_.Id_flac, Xof_ext_.Id_ogg, Xof_ext_.Id_oga, Xof_ext_.Id_mid, Xof_ext_.Id_wav);} + else if (String_.Eq(k, Cfg__image)) {Init_cmd(m.ReadStr("v"), Xof_ext_.Id_png, Xof_ext_.Id_jpg, Xof_ext_.Id_jpeg, Xof_ext_.Id_gif, Xof_ext_.Id_tif, Xof_ext_.Id_tiff, Xof_ext_.Id_bmp);} + else if (String_.Eq(k, Cfg__svg)) {Init_cmd(m.ReadStr("v"), Xof_ext_.Id_svg);} + else if (String_.Eq(k, Cfg__pdf)) {Init_cmd(m.ReadStr("v"), Xof_ext_.Id_pdf);} + else if (String_.Eq(k, Cfg__djvu)) {Init_cmd(m.ReadStr("v"), Xof_ext_.Id_djvu);} else return Gfo_invk_.Rv_unhandled; return this; } + private void Init_cmd(String exe_and_args, Process_adp proc) { + String[] lines = gplx.xowa.addons.apps.cfgs.Xocfg_mgr.Parse_io_cmd(exe_and_args); + proc.Exe_and_args_(lines[0], lines[1]); + } + private void Init_cmd(String exe_and_args, int... exts) { + String[] lines = gplx.xowa.addons.apps.cfgs.Xocfg_mgr.Parse_io_cmd(exe_and_args); + for (int ext_id : exts) { + apps_by_ext[ext_id].Exe_and_args_(lines[0], lines[1]); + } + } public void Exec_view_web(byte[] url) { - url = Bry_.Replace(url, Quote_normal, Quote_escape); // escape quotes; DATE:2013-03-31 String url_str = String_.new_u8(url); - url_str = Process_adp.Escape_ampersands_if_process_is_cmd(Op_sys.Cur().Tid_is_wnt(), app_view_web.Exe_url().Raw(), url_str); // escape ampersands; DATE:2014-05-20 - app_view_web.Run(url_str); - } private static final byte[] Quote_normal = new byte[] {Byte_ascii.Quote}, Quote_escape = new byte[] {Byte_ascii.Quote, Byte_ascii.Quote}; - private Process_adp App_by_ext_key(String ext) {return cmds_view_file_by_ext[Xof_ext_.Get_id_by_ext_(Bry_.new_a7(ext))];} - public void Exec_view_by_ext(String exts_raw, String cmd, String args) { - String[] exts_ary = String_.Split(exts_raw, '|'); - int exts_ary_len = exts_ary.length; - for (int i = 0; i < exts_ary_len; i++) - App_by_ext_key(exts_ary[i]).Cmd_args(cmd, args); - } Process_adp[] cmds_view_file_by_ext = new Process_adp[Xof_ext_.Id__max]; - private Process_adp Init_by_exts(String... exts) { - Process_adp rv = App_by_ext_key(exts[0]); - int len = exts.length; - for (int i = 0; i < len; i++) { - cmds_view_file_by_ext[Xof_ext_.Get_id_by_ext_(Bry_.new_a7(exts[i]))] = rv; - } - return rv; + url_str = String_.Replace(url_str, "\"", "\"\""); // escape quotes; DATE:2013-03-31 + url_str = Process_adp.Escape_ampersands_if_process_is_cmd(Op_sys.Cur().Tid_is_wnt(), app_web.Exe_url().Raw(), url_str); // escape ampersands; DATE:2014-05-20 + app_web.Run(url_str); } private static final String Invk_query_img_size = "query_img_size", Invk_resize_img = "resize_img", Invk_convert_svg_to_png = "convert_svg_to_png", Invk_convert_tex_to_dvi = "convert_tex_to_dvi", Invk_convert_dvi_to_png = "convert_dvi_to_png" - , Invk_convert_djvu_to_tiff = "convert_djvu_to_tiff", Invk_view_web = "view_web" - , Invk_decompress_bz2 = "decompress_bz2", Invk_decompress_zip = "decompress_zip", Invk_decompress_gz = "decompress_gz", Invk_decompress_bz2_by_stdout = "decompress_bz2_by_stdout" - , Invk_view_by_ext = "view_by_ext" - , Invk_lua = "lua", Invk_lilypond = "lilypond", Invk_abc2ly = "abc2ly", Invk_trim_img = "trim_img", Invk_convert_midi_to_ogg = "convert_midi_to_ogg" - , Invk_web = "web" - , Invk_media = "media" - , Invk_image = "image" - , Invk_svg = "svg" - , Invk_pdf = "pdf" - , Invk_djvu = "djvu" - , Invk_text = "text" - ; - public static final int Len_dlm_fld = 1, Adj_next_char = 1; + , Invk_convert_djvu_to_tiff = "convert_djvu_to_tiff", Invk_view_web = "view_web" + , Invk_decompress_bz2 = "decompress_bz2", Invk_decompress_zip = "decompress_zip", Invk_decompress_gz = "decompress_gz", Invk_decompress_bz2_by_stdout = "decompress_bz2_by_stdout" + , Invk_lua = "lua", Invk_lilypond = "lilypond", Invk_abc2ly = "abc2ly", Invk_trim_img = "trim_img", Invk_convert_midi_to_ogg = "convert_midi_to_ogg" + ; + private static final String + Cfg__web = "xowa.app.content_apps.web" + , Cfg__media = "xowa.app.content_apps.media" + , Cfg__image = "xowa.app.content_apps.image" + , Cfg__svg = "xowa.app.content_apps.svg" + , Cfg__pdf = "xowa.app.content_apps.pdf" + , Cfg__djvu = "xowa.app.content_apps.djvu" + ; } diff --git a/400_xowa/src/gplx/xowa/parsers/lnkes/Xop_lnke_wkr.java b/400_xowa/src/gplx/xowa/parsers/lnkes/Xop_lnke_wkr.java index 6313f8b5c..e5c9b8449 100644 --- a/400_xowa/src/gplx/xowa/parsers/lnkes/Xop_lnke_wkr.java +++ b/400_xowa/src/gplx/xowa/parsers/lnkes/Xop_lnke_wkr.java @@ -85,7 +85,7 @@ public class Xop_lnke_wkr implements Xop_ctx_wkr { switch (src[cur_pos]) { case Byte_ascii.Brack_end: if (lnke_type_brack) { // NOTE: check that frame begins with [ in order to end with ] - lnke_end_tid = End_tid_brack; brack_end_pos = cur_pos + Xoa_prog_mgr.Adj_next_char; + lnke_end_tid = End_tid_brack; brack_end_pos = cur_pos + 1; // 1=adj_next_char } else { // NOTE: frame does not begin with [ but ] encountered. mark "invalid" in order to force parser to stop before "]" lnke_end_tid = End_tid_invalid; diff --git a/400_xowa/src/gplx/xowa/parsers/xndes/Xop_xnde_wkr.java b/400_xowa/src/gplx/xowa/parsers/xndes/Xop_xnde_wkr.java index 24029111c..18dbf338a 100644 --- a/400_xowa/src/gplx/xowa/parsers/xndes/Xop_xnde_wkr.java +++ b/400_xowa/src/gplx/xowa/parsers/xndes/Xop_xnde_wkr.java @@ -247,7 +247,7 @@ public class Xop_xnde_wkr implements Xop_ctx_wkr { } if (valid) { ctx.Subs_add(root, tkn_mkr.Ignore(bgn_pos, gtPos, Xop_ignore_tkn.Ignore_tid_include_tmpl)); - return gtPos + Xoa_prog_mgr.Adj_next_char; + return gtPos + 1; // 1=adj_next_char } else { return ctx.Lxr_make_txt_(gtPos); @@ -281,7 +281,7 @@ public class Xop_xnde_wkr implements Xop_ctx_wkr { private boolean pre2_pending = false; private int Make_xtag_bgn(Xop_ctx ctx, Xop_tkn_mkr tkn_mkr, Xop_root_tkn root, byte[] src, int src_len, int bgn_pos, int gtPos, int name_bgn, int name_end, Xop_xnde_tag tag, int tag_end_pos, byte tag_end_byte, boolean force_xtn_for_nowiki, boolean pre2_hack) { boolean inline = false; - int open_tag_end = gtPos + Xoa_prog_mgr.Adj_next_char, atrs_bgn = -1, atrs_end = -1; + int open_tag_end = gtPos + 1, atrs_bgn = -1, atrs_end = -1; // 1=adj_next_char // calc (a) inline; (b) atrs switch (tag_end_byte) { // look at last char of tag; EX: for b, following are registered: "b/","b>","b\s","b\n","b\t" case Byte_ascii.Slash: // "/" EX: "
,
 are allowed
diff --git a/400_xowa/src/gplx/xowa/users/prefs/Prefs_mgr_tst.java b/400_xowa/src/gplx/xowa/users/prefs/Prefs_mgr_tst.java
index 10e1585e1..8fdcef45b 100644
--- a/400_xowa/src/gplx/xowa/users/prefs/Prefs_mgr_tst.java
+++ b/400_xowa/src/gplx/xowa/users/prefs/Prefs_mgr_tst.java
@@ -88,13 +88,13 @@ public class Prefs_mgr_tst {
 		fxt.Test_set("");
 		Tfds.Eq(false, fxt.App().File_mgr().Math_mgr().Renderer_is_mathjax());
 	}
-	@Test   public void Get_io_file() {
-		fxt.Exec_get
-		(	"", String_.Concat
-		(	""
-		,	""
-		));
-	}
+//		@Test   public void Get_io_file() {
+//			fxt.Exec_get
+//			(	"", String_.Concat
+//			(	""
+//			,	""
+//			));
+//		}
 	@Test  public void Scrub_tidy_trailing_nl_in_textarea() {
 		fxt.Test_Scrub_tidy_trailing_nl_in_textarea(Bool_.Y, Bool_.Y, "a\n", "a");
 		fxt.Test_Scrub_tidy_trailing_nl_in_textarea(Bool_.Y, Bool_.Y, "a\n\n", "a\n");