Mercurial Hosting > luan
changeset 1367:836e00bf7ce2
add Lucene backup_to
| author | Franklin Schmidt <fschmidt@gmail.com> | 
|---|---|
| date | Tue, 18 Jun 2019 16:27:03 -0600 | 
| parents | ae2321a09723 | 
| children | 5225cd6ed478 | 
| files | src/luan/modules/Boot.luan src/luan/modules/IoLuan.java src/luan/modules/Utils.java src/luan/modules/lucene/Lucene.luan | 
| diffstat | 4 files changed, 40 insertions(+), 113 deletions(-) [+] | 
line wrap: on
 line diff
--- a/src/luan/modules/Boot.luan Mon Jun 17 21:50:40 2019 -0600 +++ b/src/luan/modules/Boot.luan Tue Jun 18 16:27:03 2019 -0600 @@ -173,6 +173,8 @@ this.set_last_modified = io.set_last_modified this.length = io.file.length this.rename_to = io.rename_to + this.link_to = io.link_to + this.symlink_to = io.symlink_to this.is_symbolic_link = io.is_symbolic_link function this.child(name)
--- a/src/luan/modules/IoLuan.java Mon Jun 17 21:50:40 2019 -0600 +++ b/src/luan/modules/IoLuan.java Tue Jun 18 16:27:03 2019 -0600 @@ -134,9 +134,11 @@ } - private static File objToFile(Object obj) { + private static File objToFile(Luan luan,Object obj) throws LuanException { if( obj instanceof String ) { - return new File((String)obj); + String fileName = (String)obj; + check(luan,"file:"+fileName); + return new File(fileName); } if( obj instanceof LuanTable ) { LuanTable t = (LuanTable)obj; @@ -444,14 +446,28 @@ return file.exists(); } - public void rename_to(Object destObj) throws LuanException { - File dest = objToFile(destObj); + public void rename_to(Luan luan,Object destObj) throws LuanException { + File dest = objToFile(luan,destObj); if( dest==null ) - throw new LuanException( "bad argument #1 to 'objToFile' (string or file table expected)" ); + throw new LuanException( "bad argument #1 to 'rename_to' (string or file table expected)" ); if( !file.renameTo(dest) ) throw new LuanException("couldn't rename file "+file+" to "+dest); } + public void link_to(Luan luan,Object destObj) throws LuanException, IOException { + File dest = objToFile(luan,destObj); + if( dest==null ) + throw new LuanException( "bad argument #1 to 'link_to' (string or file table expected)" ); + Files.createLink( file.toPath(), dest.toPath() ); + } + + public void symlink_to(Luan luan,Object destObj) throws LuanException, IOException { + File dest = objToFile(luan,destObj); + if( dest==null ) + throw new LuanException( "bad argument #1 to 'symlink_to' (string or file table expected)" ); + Files.createSymbolicLink( file.toPath(), dest.toPath() ); + } + public LuanFile canonical(Luan luan) throws LuanException, IOException { return new LuanFile(luan,file.getCanonicalFile()); } @@ -535,13 +551,13 @@ final File dir; Process proc; - private BaseOs(String cmd,LuanTable options) throws IOException, LuanException { + private BaseOs(Luan luan,String cmd,LuanTable options) throws IOException, LuanException { this.cmd = cmd; File dir = null; if( options != null ) { Map map = options.asMap(); Object obj = map.remove("dir"); - dir = objToFile(obj); + dir = objToFile(luan,obj); if( dir==null ) throw new LuanException( "bad option 'dir' (string or file table expected)" ); if( !map.isEmpty() ) @@ -596,7 +612,7 @@ public static final class LuanOs extends BaseOs { public LuanOs(Luan luan,String cmd,LuanTable options) throws IOException, LuanException { - super(cmd,options); + super(luan,cmd,options); check(luan,"os:"+cmd); this.proc = Runtime.getRuntime().exec(cmd,null,dir); } @@ -604,7 +620,7 @@ public static final class LuanBash extends BaseOs { public LuanBash(Luan luan,String cmd,LuanTable options) throws IOException, LuanException { - super(cmd,options); + super(luan,cmd,options); check(luan,"bash:"+cmd); this.proc = Runtime.getRuntime().exec(new String[]{"bash","-c",cmd},null,dir); }
--- a/src/luan/modules/Utils.java Mon Jun 17 21:50:40 2019 -0600 +++ b/src/luan/modules/Utils.java Tue Jun 18 16:27:03 2019 -0600 @@ -93,108 +93,5 @@ copyAll(in,out); return out.toByteArray(); } -/* - public static boolean exists(File file) { - try { - return file.exists() && file.getName().equals(file.getCanonicalFile().getName()); - } catch(IOException e) { - throw new RuntimeException(e); - } - } -*/ -/* - private static File toFile(String path) { - if( path.contains("//") ) - return null; - File file = new File(path); - return file.exists() ? file : null; - } - private static URL toUrl(String path) { - if( path.indexOf(':') == -1 ) - return null; - if( path.startsWith("classpath:") ) { - path = path.substring(10); - if( path.contains("//") ) - return null; - URL url; - if( !path.contains("#") ) { - url = ClassLoader.getSystemResource(path); - } else { - String[] a = path.split("#"); - url = ClassLoader.getSystemResource(a[0]); - if( url==null ) { - for( int i=1; i<a.length; i++ ) { - url = ClassLoader.getSystemResource(a[0]+"/"+a[i]); - if( url != null ) { - try { - url = new URL(url,"."); - } catch(MalformedURLException e) { - throw new RuntimeException(e); - } - break; - } - } - } - } - return url==null ? null : url; - } - try { - return new URL(path); - } catch(MalformedURLException e) {} - return null; - } - - static boolean exists(String path) { - return toFile(path)!=null || toUrl(path)!=null; - } -*/ - - - -/* replace by uri"os:..." - - // process - - public static class ProcessException extends IOException { - private ProcessException(String msg) { - super(msg); - } - } - - public static void checkProcess(Process proc) - throws IOException - { - try { - proc.waitFor(); - } catch(InterruptedException e) { - throw new RuntimeException(e); - } - int exitVal = proc.exitValue(); - if( exitVal != 0 ) { - Reader err = new InputStreamReader(proc.getErrorStream()); - String error = readAll(err); - err.close(); - throw new ProcessException(error); - } - } - - public static String getOutput(Process proc) - throws IOException - { - Reader in = new InputStreamReader(proc.getInputStream()); - String s = readAll(in); - in.close(); - return s; - } - - public static String execProcess(String... cmd) - throws IOException - { - Process proc = Runtime.getRuntime().exec(cmd); - String s = getOutput(proc); - checkProcess(proc); - return s; - } -*/ }
--- a/src/luan/modules/lucene/Lucene.luan Mon Jun 17 21:50:40 2019 -0600 +++ b/src/luan/modules/lucene/Lucene.luan Tue Jun 18 16:27:03 2019 -0600 @@ -48,7 +48,6 @@ end index.to_string = java_index.to_string --- index.backup = java_index.backup index.snapshot = java_index.snapshot index.advanced_search = java_index.advanced_search index.search_in_transaction = java_index.search_in_transaction @@ -126,6 +125,19 @@ end end + function index.backup_to(backup_dir) + backup_dir.delete() + backup_dir.mkdir() + index.snapshot( function(dir_path,file_names) + local lucene_dir = uri("file:"..dir_path) + for _, file_name in ipairs(file_names) do + local lucene_file = lucene_dir.child(file_name) + local backup_file = backup_dir.child(file_name) + backup_file.link_to(lucene_file) + end + end ) + end + function index.zip(zip_file) index.snapshot( function(dir_path,file_names) zip_file.delete()
