--- FM2SQL/Attic/Convert.java 2004/01/12 13:22:36 1.5 +++ FM2SQL/Attic/Convert.java 2004/01/15 13:32:09 1.11 @@ -36,7 +36,6 @@ class Convert //System.out.println(new String(b,"UTF-8")); } catch (UnsupportedEncodingException e) { - // TODO Auto-generated catch block e.printStackTrace(); }*/ FileOutputStream file = null; @@ -51,7 +50,6 @@ class Convert file = new FileOutputStream("./log.txt"); } catch (FileNotFoundException e1) { - // TODO Auto-generated catch block e1.printStackTrace(); } PrintStream stream= new PrintStream(file); @@ -61,7 +59,7 @@ class Convert System.out.println("Finished!"); //convert("jdbc:fmpro:http://141.14.237.74:8050","jdbc:postgresql://erebos/test",null,null); } - public static void convertBatch(DBBean source,DBBean destination,Vector names,Vector layouts,Vector selects,Vector creates) throws Exception + public static void convertBatch(DBBean source,DBBean destination,Vector names,Vector layouts,Vector selects,Vector creates,int mode) throws Exception { /*FM2SQL.ProgressDialog dialog = new FM2SQL.ProgressDialog(FM2SQL.fmInstance); dialog.setTitle("Conversion running ..."); @@ -139,7 +137,7 @@ class Convert // System.out.println(beanDest.getTableNames(beanDest.getCatalogs().get(2).toString())); stm = beanDest.getConnection().createStatement(); // System.exit(0); - if(true) + if(mode==Convert.DataBase.CONVERT_MODE) { if(tables.indexOf(names.get(tbIndex))>=0) { @@ -307,7 +305,7 @@ class Convert - public static void convert(String source,String destination,Vector names,Vector layouts,Vector selects,Vector creates) throws Exception + public static void convert(String source,String destination,Vector names,Vector layouts,Vector selects,Vector creates,int mode) throws Exception { FM2SQL.ProgressDialog dialog = new FM2SQL.ProgressDialog(FM2SQL.fmInstance); dialog.setTitle("Conversion running ..."); @@ -377,7 +375,7 @@ class Convert // System.out.println(beanDest.getTableNames(beanDest.getCatalogs().get(2).toString())); stm = beanDest.getConnection().createStatement(); // System.exit(0); - if(true) + if(mode==Convert.DataBase.CONVERT_MODE) { if(tables.indexOf(names.get(tbIndex))>=0) { @@ -627,6 +625,8 @@ class Convert alterMe.delete(j, j); length--; } + else + alterMe.setCharAt(j,'_'); } ++j; @@ -786,7 +786,8 @@ class Convert Vector layouts = new Vector(); Vector selects = new Vector(); Vector creates = new Vector(); - int mode = -1; + Vector ids = new Vector(); + int mode = -1; try { @@ -802,7 +803,7 @@ class Convert layouts = new Vector(); selects = new Vector(); creates = new Vector(); - + ids = new Vector(); // parse dataBase Node node = root.find("convert/source/database/url", new int[] { 1, 1, i, 1 }); Node node1 = root.find("convert/source/database/user", new int[] { 1, 1, i, 1, 1 }); @@ -858,11 +859,15 @@ class Convert // if(node6==null) throw new Error("parse error create tag missing"); String name = (String)node4.attributes.get("name"); String layout = (String)node4.attributes.get("layout"); + String id = (String)node4.attributes.get("id"); + System.out.println("id was "+id); if(name==null) throw new Error("parse error required table tag attribute name missing"); if(layout==null) layout =""; + if(id==null) id = ""; if(name.equals("")) throw new Error("parse error table tag attribute must not be empty"); tables.add(name); layouts.add(layout); + ids.add(id); String query = (node5==null) ? "":node5.getCharacters(); if(query.equals("")) System.err.println("Warning empty select tag or select tag missing !!"); query = (query.equals("")) ? "select * from "+database.getQC()+name+database.getQC():query; @@ -872,7 +877,7 @@ class Convert creates.add(""); } - databases.add(new DataBase(database, tables, layouts, selects,creates,mode)); + databases.add(new DataBase(database, tables, layouts, selects,creates,ids,mode)); } DBBean database = new DBBean(); // parse dataBase @@ -889,7 +894,7 @@ class Convert for (Iterator iter = databases.iterator(); iter.hasNext();) { DataBase db = (DataBase) iter.next(); - convertBatch(db.bean,database,db.tables,db.layouts,db.selects,db.creates); + convertBatch(db.bean,database,db.tables,db.layouts,db.selects,db.creates,mode); } // printContents(node3); @@ -1018,6 +1023,8 @@ class Convert Vector layouts = new Vector(); Vector selects = new Vector(); Vector creates = new Vector(); + Vector ids = new Vector(); + int mode = -1; try { @@ -1033,7 +1040,7 @@ class Convert layouts = new Vector(); selects = new Vector(); creates = new Vector(); - + ids = new Vector(); // parse dataBase Node node = root.find("convert/source/database/url", new int[] { 1, 1, i, 1 }); Node node1 = root.find("convert/source/database/user", new int[] { 1, 1, i, 1, 1 }); @@ -1091,11 +1098,16 @@ class Convert // if(node6==null) throw new Error("parse error create tag missing"); String name = (String)node4.attributes.get("name"); String layout = (String)node4.attributes.get("layout"); + String id = (String)node4.attributes.get("id"); + System.out.println("id was "+id); + if(name==null) throw new Error("parse error required table tag attribute name missing"); if(layout==null) layout =""; + if(id == null) id=""; if(name.equals("")) throw new Error("parse error table tag attribute must not be empty"); tables.add(name); layouts.add(layout); + ids.add(id); String query = (node5==null) ? "":node5.getCharacters(); if(query.equals("")) System.err.println("Warning empty select tag or select tag missing !!"); query = (query.equals("")) ? "select * from "+database.getQC()+name+database.getQC():query; @@ -1105,7 +1117,7 @@ class Convert creates.add(""); } - databases.add(new DataBase(database, tables, layouts, selects,creates,mode)); + databases.add(new DataBase(database, tables, layouts, selects,creates,ids,mode)); } DBBean database = new DBBean(); // parse dataBase @@ -1118,7 +1130,7 @@ class Convert System.out.println(url); database.setURL(url.trim()); database.setUserAndPasswd(user.trim(), password.trim()); - databases.add(new DataBase(database,null,null,null,null,0)); + databases.add(new DataBase(database,null,null,null,null,null,0)); //databases.add(database); /* for (Iterator iter = databases.iterator(); iter.hasNext();) { @@ -1198,18 +1210,20 @@ public static class DataBase Vector selects; Vector layouts; Vector tables; + Vector ids; final static int CONVERT_MODE = 1; final static int APPEND_MODE = 2; final static int UPDATE_MODE = 3; int mode = -1; - public DataBase(DBBean bean,Vector tables,Vector layouts,Vector selects,Vector creates,int mode) + public DataBase(DBBean bean,Vector tables,Vector layouts,Vector selects,Vector creates,Vector ids,int mode) { this.bean = bean; this.tables = tables; this.layouts = layouts; this.selects = selects; this.creates = creates; + this.ids = ids; this.mode = mode; } public void exportToXML(BufferedWriter buffr) throws Exception @@ -1236,8 +1250,9 @@ public static class DataBase String layout=(String)layouts.get(index); String select=(String)selects.get(index); String create=(String)creates.get(index); + String id=(String)ids.get(index); - buffr.write(" \n"); + buffr.write("
\n"); buffr.write(" \n"); if(!create.equals("")) buffr.write(" "+create+" \n");