All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.scudata.ide.spl.Esprocx Maven / Gradle / Ivy

Go to download

SPL(Structured Process Language) A programming language specially for structured data computing.

There is a newer version: 20241126
Show newest version
package com.scudata.ide.spl;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.lang.reflect.Method;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.StringTokenizer;

import com.scudata.app.common.AppConsts;
import com.scudata.app.common.AppUtil;
import com.scudata.app.common.Section;
import com.scudata.app.common.Segment;
import com.scudata.app.config.ConfigUtil;
import com.scudata.app.config.RaqsoftConfig;
import com.scudata.cellset.datamodel.PgmCellSet;
import com.scudata.common.CellLocation;
import com.scudata.common.Logger;
import com.scudata.common.ScudataLogger;
import com.scudata.common.ScudataLogger.FileHandler;
import com.scudata.common.Sentence;
import com.scudata.common.StringUtils;
import com.scudata.common.UUID;
import com.scudata.dm.BaseRecord;
import com.scudata.dm.Context;
import com.scudata.dm.Env;
import com.scudata.dm.FileObject;
import com.scudata.dm.JobSpace;
import com.scudata.dm.JobSpaceManager;
import com.scudata.dm.LocalFile;
import com.scudata.dm.Sequence;
import com.scudata.dm.cursor.ICursor;
import com.scudata.ide.common.ConfigFile;
import com.scudata.ide.common.ConfigOptions;
import com.scudata.ide.common.DataSource;
import com.scudata.ide.common.XMLFile;
import com.scudata.resources.ParallelMessage;
import com.scudata.util.CellSetUtil;
import com.scudata.util.DatabaseUtil;
import com.scudata.util.Variant;

/**
 * ʹ?ø?????dos??????ֱ??ִ??һ??dfx?ű?
 * 
 * @author Joancy
 *
 */
public class Esprocx {
	static RaqsoftConfig config;
	static Object remoteStore;

	public static void loadDataSource(Context ctx) throws Exception {
		// ????ϵͳ????Դ
		ConfigFile cf = ConfigFile.getSystemConfigFile();
		if(cf==null) {
			return;
		}
		XMLFile configFile = cf.xmlFile();
		Section ss = new Section(); // ?쳣?????޷???demo????Դ??Ų??????
		ss = configFile.listElement(ConfigFile.PATH_DATASOURCE);
		String sId, name;
		String sconfig;
		for (int i = 0; i < ss.size(); i++) {
			sId = ss.getSection(i);
			name = configFile.getAttribute(ConfigFile.PATH_DATASOURCE + "/"
					+ sId + "/name");

			sconfig = configFile.getAttribute(ConfigFile.PATH_DATASOURCE + "/"
					+ sId + "/config");
			DataSource ds = new DataSource(sconfig);
			ds.setName(name);
			ctx.setDBSessionFactory(name, ds.getDBInfo().createSessionFactory());
		}

	}

	/**
	 * ׼???????????Ļ???
	 * @return ?????Ļ???
	 */
	public static Context prepareEnv() {
		Context ctx;
		try {
			ctx = new Context();
			if (config != null) {
				DatabaseUtil.connectAutoDBs(ctx, config.getAutoConnectList());
			}
			loadDataSource(ctx);
		} catch (Throwable x) {
			Logger.debug(x);
			ctx = new Context();
		}
		String uuid = Esprocx.getUUID();
		JobSpace js = JobSpaceManager.getSpace(uuid);
		ctx.setJobSpace(js);

		return ctx;
	}

	/**
	 * ??GM???????÷???????Ҫ????GM?࣬???ⲻ??Ҫ??awt???ã?
	 * ????Ӧ?ڷ?ͼ?β???ϵͳ??ִ?и??ࡣ
	 * @param path ???·???ļ???
	 * @return ????·????
	 */
	public static String getAbsolutePath(String path) {
		String home = System.getProperty("start.home");
		return getAbsolutePath(path, home);
	}

	/**
	 * ??·??ƴ??home???ϲ?Ϊ????·??
	 * @param path ????ļ???
	 * @param home home·??
	 * @return ????·????
	 */
	public static String getAbsolutePath(String path, String home) {
		if (home != null && (home.endsWith("\\") || home.endsWith("/"))) {
			home = home.substring(0, home.length() - 1);
		}
		if (!path.startsWith("/")) {
			path = "/" + path;
		}
		String filePath = home + path;
		String p = System.getProperty("file.separator");
		if (p.equals("\\")) {
			filePath = Sentence.replace(filePath, "/", p, Sentence.IGNORE_CASE);
		} else {
			filePath = Sentence
					.replace(filePath, "\\", p, Sentence.IGNORE_CASE);
		}
		return filePath;
	}
	
	public static String getConfigValue(String key) {
		try {
			String configFile = getAbsolutePath("bin\\config.txt");
			FileReader fr = new FileReader(configFile);
			BufferedReader br = new BufferedReader(fr);
			String segValue = br.readLine();
			Segment seg = new Segment(segValue);
			return seg.get(key);
		} catch (Exception x) {
		}
		return null;
	}

	/**
	 * 
	 * init֮ǰû?е??Լ???ֻ??system.err; 
	 * init֮??Ĵ??????ʹ??logger.debug
	 *
	 * @throws Exception
	 */
	public static void initEnv() throws Exception {
		String startHome = System.getProperty("start.home");
		if (!StringUtils.isValidString(startHome)) {
			System.setProperty("raqsoft.home", System.getProperty("user.home"));
		} else {
			System.setProperty("raqsoft.home", startHome + ""); // ԭ????user.dir,
		}

		String envFile = getAbsolutePath("/config/raqsoftConfig.xml");
		config = ConfigUtil.load(envFile);

		try {
			ConfigOptions.load2(false, false);
			if (StringUtils.isValidString(ConfigOptions.sLogFileName)) {
				String file = ConfigOptions.sLogFileName;
				File f = new File(file);
				File fp = f.getParentFile();
				if (!fp.exists()) {
					fp.mkdirs();
				}
				String path = f.getAbsolutePath();
				FileHandler lfh = ScudataLogger.newFileHandler(path);
				ScudataLogger.addFileHandler(lfh);
			}
		} catch (Throwable e) {
			e.printStackTrace();
		}
		
		String init = getConfigValue("init");
		if(StringUtils.isValidString(init)) {
			StringTokenizer st = new StringTokenizer(init);
			while(st.hasMoreElements()) {
				String token = st.nextToken();
				int dot = token.lastIndexOf('.');
				if(dot>0) {
					String clsName = token.substring(0,dot);
					String method = token.substring(dot+1);
					try {
						Class clz = Class.forName(clsName);
						Method m = clz.getMethod(method, null);
						remoteStore = m.invoke(clz, null);
						Logger.info("Initial "+token+" ok.");
					} catch (Throwable t) {
						Logger.info(t);
					}
				}
			}
		}
	}

	public static void closeRemoteStore(Object remoteStore) {
		if (remoteStore == null)
			return;
		try {
			Class clz = Class.forName("com.scudata.ecloud.ide.GMCloud");
			Method m = clz.getMethod("closeRemoteStore", Object.class);
			m.invoke(clz, remoteStore);
			Logger.info("Remote store is closed.");
		} catch (ClassNotFoundException ex) {
		} catch (Throwable t) {
			Logger.error(t);
		}
	}
	
	static int finishedWorkers = 0;

	/**
	 * ????ҵ????ʱ?????һ????ҵ????һ?θķ???
	 * ????һ????ɵ???ҵ
	 */
	public static synchronized void addFinish() {
		finishedWorkers++;
		Logger.debug(ParallelMessage.get().getMessage("Esproc.taskFinish",
				finishedWorkers));
	}

	/**
	 * ?????Ŀ¼???ã??????Ŀ¼Ϊ?գ???????Ϊ??ǰĿ¼
	 */
	private static void checkMainPath() {
		String mainPath = Env.getMainPath();
		if (!StringUtils.isValidString(mainPath)) {
			mainPath = new File("").getAbsolutePath();
			Env.setMainPath(mainPath);
			Logger.debug("Esprocx is using main path: " + mainPath);
		}
	}

	private static void exit() {
		closeRemoteStore(remoteStore);
		System.exit(0);
	}
	
	/**
	 * ʹ?ø?IDE??ͬ???????Լ?ע??????Dos????ִ??һ??dfx 
	 * ?ö??߳?nͬʱ????ִ?е?ǰ??dfx?? 
	 * 
	 * @param args ִ?еIJ???
	 */
	public static void main(String[] args) throws Exception {
		boolean debug = false;
		String etlUsage = "Esprocx [etlFile] [argN] ...\r\n"
				+ " [etlFile]   ?????Ѱַ·????????·????etl?ļ?????Ҳ?????Ǿ???·????\r\n"
				+ " [argN]      etlFile?в???ʱ?????????? ????˳?? ָ????\r\n";

		String fileExts = AppConsts.SPL_FILE_EXTS + "," + "etl";

		String usage = "????ִ??һ??" + fileExts
				+ "?ļ???һ?????׵ı???ʽ????SQL??һ???ı???????dfx?ű???\r\n\r\n"
				+ "Esprocx [-r] [-c]\r\n" + " [-r]   ??ӡ???ؽ????????̨??\r\n"
				+ " [-c]   ?ӿ???̨????һ??????Tab???ֿ??Ķ???ʽ????ű???ִ??(Ctrl+C????¼??)??\r\n\r\n"
				+ "Esprocx [-r] [dfxFile] [arg0] [arg1]...\r\n"
				+ " [splxFile]   ?????Ѱַ·????????·????splx?ļ?????Ҳ?????Ǿ???·????\r\n"
				+ " [argN]      ?????splxFile???в???????˳?????ζ?Ӧ??\r\n\r\n" + etlUsage
				+ "Esprocx [-r] [exp]\r\n" + " [exp]   һ??dfx?ű????\r\n\r\n"
				+ "ʾ??:\r\n" + "  Esprocx -r -c\r\n"
				+ "    ִ??һ????¼????ı?ʽ???񲢴?ӡ???ؽ????\r\n"
				+ "  Esprocx -r demo.splx arg1 arg2\r\n"
				+ "    ?ò???arg1??arg2ִ??Ѱַ·???ϵ?demo.splx????ӡ???ؽ????\r\n"
				+ "  Esprocx SELECT count(*) FROM t.json\r\n"
				+ "    ִ??һ???SQL??\r\n" + "  Esprocx demo.etl 1\r\n"
				+ "    ??Ӧ????monthΪ1?£?ִ??Ѱַ·???ϵ?demo.etl??\r\n";

		String etlUsageEn = "Esprocx [etlFile] [argN]...\r\n"
				+ " [etlFile]   An etl file name relative to a search path or a main path; can be an absolute path. \r\n"
				+ " [argN]      If etlFile contains parameters, pass values to them according to the order defined. \r\n";
		String usageEn = "It is used to execute a "
				+ fileExts
				+ " file, a simple expression, a simple SQL statement, or a text formatting dfx script. \r\n\r\n"
				+ "Esprocx [-r] [-c]\r\n"
				+ " [-r]   Print result to the console. \r\n"
				+ " [-c]   Read from the console a multiline cellset script in which columns are separated by the Tab to execute (Ctrl+C for finishing  input).  \r\n\r\n"
				+ "Esprocx [-r] [splxFile] [arg0] [arg1]...\r\n"
				+ " [splxFile]   A splx file name relative to a search path or a main path; can be an absolute path. \r\n"
				+ " [argN]      If the splxFile contains parameters, pass values to them in order. \r\n\r\n"
				+ "Esprocx [-r] [exp]\r\n"
				+ " [exp]   A dfx script command. \r\n\r\n"
				+ etlUsageEn
				+ "Example:\r\n"
				+ "  Esprocx -r -c\r\n"
				+ "    Execute a to-be-input text formatting cellset and print the returned result. \r\n"
				+ "  Esprocx -r demo.splx arg1 arg2\r\n"
				+ "    Execute demo.splx on a search path with parameters arg1 and arg2, and print the returned result. \r\n"
				+ "  Esprocx SELECT count(*) FROM t.json\r\n"
				+ "    Execute a simple SQL statement. \r\n"
				+ "  Esprocx demo.etl 1\r\n"
				+ "    Execute demo.etl on a search path by inputting January as the paramer value. \r\n";
		String lang = System.getProperty("user.language");
		if (lang.equalsIgnoreCase("en")) {
			usage = usageEn;
		}
		if (!debug && args.length == 0) {
			System.err.println(usage);
			Thread.sleep(3000);
			exit();
		}

		String arg = "", dfxFile = null;
		StringBuffer fileArgs = new StringBuffer();
		boolean loadArg = false, printResult = false;
		boolean isParallel = true;
		int threadCount = 1;

		if (args.length == 1) {
			arg = args[0].trim();
			if (arg.trim().indexOf(" ") > 0) {
				Section st = new Section(arg, ' ');
				args = st.toStringArray();
			}
		}
//		args = new String[] {"select","esprocx.sh","other.cmd","from","a.txt"};
//		args = new String[] {"esprocx.sh","other.cmd","from","a.txt"};
//		args = new String[] {"field1","field2","from","a.txt"};
//		args = new String[] {"$select","field1","field2","from","a.txt"};
		boolean existStar = false;// ???? Select *
		boolean isSql = false;// ????$select?ᱻlinux????ϵͳ??????????from
//		?ؼ??????жϵ?ǰ????ʽ?Ƿ?Ϊsql???
		if (args.length > 0) {
			for (int i = 0; i < args.length; i++) {
				arg = args[i];// .toLowerCase();
//				Logger.debug("arg "+i+"=" + arg);
				
				boolean existSpace = false;// ?˴??滻??c???????????⴦???Ŀո??????
				char[] argchars = arg.toCharArray();
				for (int n = 0; n < argchars.length; n++) {
					if (argchars[n] == 2) {
						argchars[n] = ' ';
						existSpace = true;
					} else if (argchars[n] == 3) {
						argchars[n] = '"';
						existSpace = true;
					}
				}
				if (existSpace) {
					arg = new String(argchars);
				}

				if (arg.toLowerCase().equals("com.scudata.ide.spl.esprocx")) { // ??bat?򿪵??ļ??????????????Dz???
					continue;
				}
				if (arg.toLowerCase().startsWith("-r")) {
					printResult = true;
				} else if (arg.toLowerCase().startsWith("-t")) {
					i++;
					String tmp = args[i];
					threadCount = Integer.parseInt(tmp);
				} else if (arg.toLowerCase().startsWith("-s")) {// ????ִ??
					i++;
					String tmp = args[i];
					threadCount = Integer.parseInt(tmp);
					isParallel = false;
				} else if (arg.toLowerCase().startsWith("-c")) {
					dfxFile = null;
					fileArgs.setLength(0);
					fileArgs.append("=");
					int row = 1;
					while (true) {
						String line = System.console()
								.readLine("(%d): ", row++);
						if (line == null)
							break;
						if (fileArgs.length()>1) {
							fileArgs.append('\n');
						}
						fileArgs.append(line);
					}
					break;
				} else if (!arg.startsWith("-")) {
					if (!StringUtils.isValidString(arg)) {
						continue;
					}
					if (loadArg) {
						if (arg.equalsIgnoreCase("esprocx.exe")) {
							existStar = true;
							continue;
						}
						if (arg.equalsIgnoreCase("esprocx.sh")) {
							existStar = true;
							continue;
						}
						if (arg.equalsIgnoreCase("from")) {
							if(existStar) { 
								fileArgs.setLength(0);
								fileArgs.append(" * From ");
							}else {
								fileArgs.append(arg + " ");
								isSql = true;
							}
						} else {
							fileArgs.append(arg + " ");
						}
					} else {
						if(arg.equalsIgnoreCase("esprocx.sh")) {
							dfxFile="$select";//Linux??ִ?? esprocx.sh $select * from txtʱ
//							?Ὣ$select????Ҳ?滻????
							existStar = true;
						}else {
							dfxFile = arg;
						}
						loadArg = true;
					}

				} else if (arg.toLowerCase().startsWith("-help")
						|| arg.startsWith("-?")) {
					System.err.println(usage);
					exit();
				}
			}
		}

		try {
			if (debug) {
				dfxFile = "d:\\p2.splx";
			}
			initEnv();// ?趨??IDE??ͬ??StartHome
			checkMainPath();
			// ???˻?????????жϿ??Ƶ?

			long workBegin = System.currentTimeMillis();
			boolean isFile = false, isDfx = false, isEtl = false, isSplx = false, isSpl = false;
			if (dfxFile != null) {
				String lower = dfxFile.toLowerCase();
				isDfx = lower.endsWith("." + AppConsts.FILE_DFX);
				isSplx = lower.endsWith("." + AppConsts.FILE_SPLX);
				isSpl = lower.endsWith("." + AppConsts.FILE_SPL);
				isEtl = lower.endsWith(".etl");
				isFile = (isDfx || isEtl || isSplx || isSpl);
			}
			if (isFile) {
				FileObject fo = new FileObject(dfxFile, "s");
				if (isDfx || isEtl || isSplx || isSpl) {
					PgmCellSet pcs = null;
					if (isDfx || isSplx) {
						pcs = fo.readPgmCellSet();
					}else if( isSpl ) {
						Object f = fo.getFile();
						if(f instanceof LocalFile) {
							LocalFile lf = (LocalFile)f;
							String path = lf.getFile().getAbsolutePath();
							pcs = GMSpl.readSPL( path );
						}else {
							System.err.println("Unsupported file:"
									+ fo.getFileName());
							Thread.sleep(3000);
							exit();
						}
					} else {
						System.err.println("Unsupported file:"
								+ fo.getFileName());
						Thread.sleep(3000);
						exit();
					}

					String argstr = fileArgs.toString();
					ArrayList workers = new ArrayList();
					for (int i = 0; i < threadCount; i++) {
						Worker w = new Worker(pcs, argstr, printResult);
						workers.add(w);
						w.start();
						if (!isParallel) {
							w.join();
						}
					}

					if (isParallel) {
						for (Worker w : workers) {
							w.join();
						}
					}
				} else {
					Logger.severe(ParallelMessage.get().getMessage(
							"Esproc.unsupportedfile", dfxFile));// "??֧?ֵ??ļ???"+dfxFile);
				}
			} else {// ????ʽ
				Context context = Esprocx.prepareEnv();
				try {
					String cmd;
					if (dfxFile == null) {
						cmd = fileArgs.toString();
					} else {
						if(dfxFile.equalsIgnoreCase("select") || dfxFile.equalsIgnoreCase("$select")) {
							dfxFile = "$Select";//Ҫ??select?﷨???????$???Ը?DQLһ??2023??9??18?? xq
						}else if(isSql) {
							dfxFile = "$Select "+dfxFile;//????????Ϊ$select field from t.txtʱ
						}
						cmd = dfxFile + " " + fileArgs;
					}
					Logger.debug(ParallelMessage.get().getMessage(
							"Esproc.executecmd", cmd));
					Object result = AppUtil.executeCmd(cmd, context);
					if (printResult) {
						printResult(result);
					}
				} finally {
					DatabaseUtil.closeAutoDBs(context);
				}
			}

			long finishTime = System.currentTimeMillis();
			DecimalFormat df = new DecimalFormat("###,###");
			long lastTime = finishTime - workBegin;
			if (threadCount > 1 || isEtl) {
				Logger.debug(ParallelMessage.get().getMessage(
						"Esproc.taketimes", df.format(lastTime)));
			}
		} catch (Throwable x) {
			Logger.error(x.getMessage(), x);
		}

		exit();
	}

	/**
	 * ??ȡȫ?ֵ?Ψһ??
	 * @return Ψһ???
	 */
	public static synchronized String getUUID() {
		return UUID.randomUUID().toString();
	}

	static void print(Sequence atoms) {
		for (int i = 1; i <= atoms.length(); i++) {
			Object element = atoms.get(i);
			if (element instanceof BaseRecord) {
				System.out.println(((BaseRecord) element).toString("t"));
			} else {
				System.out.println(Variant.toString(element));
			}
		}
	}

	/**
	 * ??ִ?еĽ????ӡ??????̨
	 * @param result ??????
	 */
	public static void printResult(Object result) {
		if (result instanceof Sequence) {
			Sequence atoms = (Sequence) result;
			print(atoms);
		} else if (result instanceof ICursor) {
			ICursor cursor = (ICursor) result;
			Sequence seq = cursor.fetch(1024);
			while (seq != null) {
				print(seq);
				seq = cursor.fetch(1024);
			}
		} else if (result instanceof PgmCellSet) {
			PgmCellSet pcs = (PgmCellSet)result;
			while (pcs.hasNextResult()) {
				CellLocation cl = pcs.nextResultLocation();
				System.out.println();
				if (cl != null) {// û??return???ʱ??λ??Ϊnull
					String msg = cl + ":";
					System.err.println(msg);
				}
				Object tmp = pcs.nextResult();
				Esprocx.printResult(tmp);
			}
		} else {
			System.out.println(Variant.toString(result));
		}
	}

}

class Worker extends Thread {
	PgmCellSet pcs;
	String[] argArr = null;
	boolean printResult = false;

	public Worker(PgmCellSet pcs, String argstr, boolean printResult) {
		this.pcs = (PgmCellSet) pcs.deepClone();
		if (StringUtils.isValidString(argstr)) {
			argArr = argstr.split(" ");
		}
		this.printResult = printResult;
	}

	public void run() {
		Context context = Esprocx.prepareEnv();
		pcs.setContext(context);
		try {
			CellSetUtil.putArgStringValue(pcs, argArr);
			long taskBegin = System.currentTimeMillis();
			Logger.debug(ParallelMessage.get().getMessage("Task.taskBegin", ""));
			if (printResult) {
				pcs.calculateResult();
				while (pcs.hasNextResult()) {
					CellLocation cl = pcs.nextResultLocation();
					System.out.println();
					if (cl != null) {// û??return???ʱ??λ??Ϊnull
						String msg = cl + ":";
						System.err.println(msg);
					}
					Object result = pcs.nextResult();
					Esprocx.printResult(result);
				}
			} else {
				pcs.run();
			}

			long finishTime = System.currentTimeMillis();
			DecimalFormat df = new DecimalFormat("###,###");
			long lastTime = finishTime - taskBegin;
			Logger.debug(ParallelMessage.get().getMessage("Task.taskEnd", "",
					df.format(lastTime)));
			Esprocx.addFinish();
		} catch (Exception x) {
			Logger.severe(x);
			x.printStackTrace();
		} finally {
			if (context.getJobSpace() != null) {
				String sid = context.getJobSpace().getID();
				if (sid != null)
					JobSpaceManager.closeSpace(sid);
			}
			DatabaseUtil.closeAutoDBs(context);
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy