| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 | 
							- #!/usr/bin/env node
 
- var path = require('path');
 
- var amberc = require('amber-dev/lib/amberc');
 
- // get parameters passed to the command line script
 
- // discard the first two parameters which are the node binary and the script name
 
- var parameters = process.argv.slice(2);
 
- // check if at least one parameter was passed to the script
 
- if (1 > parameters.length) {
 
- 	print_usage();
 
- 	process.exit();
 
- }
 
- // Get Amber root directory from the location of this script so that
 
- // we can find the st and js directories etc.
 
- var amber_dir = path.normalize(path.join(__dirname, '..', '..', 'node_modules', 'amber'));
 
- var compiler = new amberc.Compiler(amber_dir);
 
- var configuration = handle_options(parameters);
 
- compiler.main(configuration);
 
- /**
 
-  * Process given program options and update defaults values.
 
-  * Followed by check_for_closure_compiler() and then collect_files().
 
-  */
 
- function handle_options(optionsArray) {
 
- 	var programName = [];
 
- 	var currentItem = optionsArray.shift();
 
- 	var defaults = amberc.createDefaultConfiguration();
 
- 	while(undefined !== currentItem) {
 
- 		switch(currentItem) {
 
- 			case '-l':
 
- 				defaults.load.push.apply(defaults.load, optionsArray.shift().split(','));
 
- 				break;
 
- 			case '-L':
 
- 				defaults.jsLibraryDirs.push.apply(defaults.jsLibraryDirs, optionsArray.shift().split(','));
 
- 				break;
 
- 			case '-g':
 
- 				defaults.jsGlobals.push.apply(defaults.jsGlobals, optionsArray.shift().split(','));
 
- 				break;
 
- 			case '-m':
 
- 				defaults.main = optionsArray.shift();
 
- 				break;
 
- 			case '-M':
 
- 				defaults.mainfile = optionsArray.shift();
 
- 				break;
 
- 			case '-n':
 
- 				defaults.amd_namespace = optionsArray.shift();
 
- 				break;
 
- 			case '-D':
 
- 				defaults.output_dir = optionsArray.shift();
 
- 				break;
 
-             case '-d':
 
-                 amber_dir = path.normalize(optionsArray.shift());
 
-                 break;
 
- 			case '-s':
 
- 				defaults.suffix = optionsArray.shift();
 
- 				defaults.suffix_used = defaults.suffix;
 
- 				break;
 
- 			case '-S':
 
- 				defaults.loadsuffix = optionsArray.shift();
 
- 				defaults.suffix_used = defaults.suffix;
 
- 				break;
 
- 			case '-v':
 
- 				defaults.verbose = true;
 
- 				break;
 
- 			case '-h':
 
- 			case '--help':
 
- 			case '?':
 
- 				print_usage();
 
- 				break;
 
- 			default:
 
- 				var fileSuffix = path.extname(currentItem);
 
- 				switch (fileSuffix) {
 
- 					case '.st':
 
- 						defaults.stFiles.push(currentItem);
 
- 						break;
 
- 					case '.js':
 
- 						defaults.jsFiles.push(currentItem);
 
- 						break;
 
- 					default:
 
- 						// Will end up being the last non js/st argument
 
- 						programName.push(currentItem);
 
- 						break;
 
- 				}
 
- 		}
 
- 		currentItem = optionsArray.shift();
 
- 	}
 
- 	if(1 < programName.length) {
 
- 		throw new Error('More than one name for ProgramName given: ' + programName);
 
- 	} else {
 
- 		defaults.program = programName[0];
 
- 	}
 
- 	return defaults;
 
- }
 
- // print available flags
 
- function print_usage() {
 
- 	var usage = [
 
- 		'Usage: amberc [-l lib1,lib2...] [-g jsGlobal1,jsGlobla2] [-m main_class] [-M main_file]',
 
- 		'          [-n namespace] [-D output_dir] [-v] [-s suffix] [-S suffix] [file1 [file2 ...]] [Program]',
 
- 		'',
 
- 		'   amberc compiles Amber files - either separately or into a complete runnable',
 
- 		'   program. If no .st files are listed only a linking stage is performed.',
 
- 		'   Files listed will be handled using the following rules:',
 
- 		'',
 
- 		'   *.js',
 
- 		'     Files are linked (concatenated) in listed order.',
 
- 		'     If not found we look in $AMBER/src/',
 
- 		'',
 
- 		'   *.st',
 
- 		'     Files are compiled into .js files before concatenation.',
 
- 		'     If not found we look in $AMBER/src/',
 
- 		'',
 
- 		'     NOTE: Each .st file is currently considered to be a fileout of a single class',
 
- 		'     category of the same name as the file!',
 
- 		'',
 
- 		'   If no <Program> is specified each given .st file will be compiled into',
 
- 		'   a matching .js file. Otherwise a <Program>.js file is linked together based on',
 
- 		'   the given options:',
 
- 		'',
 
- 		'  -l library1,library2',
 
- 		'     Add listed JavaScript libraries in listed order.',
 
- 		'     Libraries are not separated by spaces or end with .js.',
 
- 		'',
 
- 		'  -L directory1,directory2',
 
- 		'     Add listed directories to the library search path.',
 
- 		'     The order of processing is:',
 
- 		'     1. current directory',
 
- 		'     2. directories specified by -L',
 
- 		'     3. $AMBER',
 
- 		'',
 
- 		'  -g jsGlobal1,jsGlobal2',
 
- 		'     Comma separated list of JS global variable names.',
 
- 		'     The names are added to a list containing "window", "document" and others.',
 
- 		'',
 
- 		'  -m main_class',
 
- 		'     Add a call to the class method main_class>>main at the end of <Program>.',
 
- 		'',
 
- 		'  -M main_file',
 
- 		'     Add <main_file> at the end of <Program.js> acting as #main.',
 
- 		'',
 
- 		'  -n amd_namespace',
 
- 		'     Export packages with <amd_namespace> as the require.js namespace.',
 
- 		'     Default value is "amber_core".',
 
- 		'',
 
- 		'  -v',
 
- 		'     Produce a more verbose output.',
 
- 		'',
 
- 		'  -D',
 
- 		'     Specifies the output directory for all generated .js files.',
 
- 		'     The hierarchy of the input files is not maintaned.',
 
- 		'     If this option is omitted all generated .js files are placed next to their input files',
 
- 		'',
 
- 		'  -d',
 
- 		'     Specifies the alternate directory to look for Amber files.',
 
- 		'     If not specified, the version embedded in CLI is used..',
 
- 		'',
 
- 		'  -s suffix',
 
- 		'     Add <suffix> to compiled .js files. File.st is then compiled into',
 
- 		'     File.<suffix>.js.',
 
- 		'',
 
- 		'  -S suffix',
 
- 		'     Use <suffix> for all libraries accessed using -l. This makes it possible',
 
- 		'     to have multiple flavors of Amber and libraries in the same place.',
 
- 		'',
 
- 		'',
 
- 		'     Example invocations:',
 
- 		'',
 
- 		'     Just compile Kernel-Objects.st to Kernel-Objects.js:',
 
- 		'',
 
- 		'        amberc Kernel-Objects.st',
 
- 		'',
 
- 		'     Compile Hello.st to Hello.js and create complete program called Program.js.',
 
- 		'     Additionally add a call to the class method Hello>>main:',
 
- 		'',
 
- 		'        amberc -m Hello Hello.st Program',
 
- 		'',
 
- 		'     Compile Cat1.st and Cat2.st files into corresponding .js files.',
 
- 		'     Link them with myboot.js and myKernel.js',
 
- 		'     and merge everything into a complete program named Program.js:',
 
- 		'',
 
- 		'        amberc -M main.js myboot.js myKernel.js Cat1.st Cat2.st Program',
 
- 	];
 
- 	usage.forEach(function (line) {
 
-         console.log(line);
 
- 	});
 
- }
 
 
  |