packagedDepenencies
Bin, src,tools folders under root
This commit is contained in:
Leo Lee (DEVDIV) 2015-01-29 23:33:06 -08:00
Родитель 68fe1d818e
Коммит 0e24cd32be
27 изменённых файлов: 488 добавлений и 481 удалений

Просмотреть файл

@ -1,55 +0,0 @@
/// <reference path="../typings/node/node.d.ts" />
/// <reference path="../utility/typescriptUtil.ts" />
/// <reference path="../utility/styleCopUtil.ts" />
var fs = require("fs");
var gulp = require("gulp");
var path = require("path");
var typescriptUtil = require("../utility/typescriptUtil");
var styleCopUtil = require("../utility/styleCopUtil");
var eventStream = require("event-stream");
var concat = require("gulp-concat");
var del = require("del");
var compilerPath = {
src: "../../..", // gulp task compiles all source under "taco-cli" source folder
bin: "../..",
};
////////////////// to add additional gulp tasks, add gulpfile in folder and reference it below
// for example: require('./src/compile/gulpfile');
///////////////////////
/* Project wide tasks below, 1 entry for each gulp task */
gulp.task("default", ["compilerDefault", "compilerStyleCop"]);
/* Default task for compiler - runs clean, compile, combine. */
gulp.task("compilerDefault", ["compilerClean", "compilerCompile", "compilerStyleCop"]);
/* Compiles the typescript files in the project. */
gulp.task("compilerCompile", ["compilerClean"], function (cb: Function): void {
var tsUtil = new typescriptUtil.CordovaTools.TypescriptServices();
console.log("compilerPath.src: " + path.resolve(compilerPath.src));
console.log("compilerPath.bin: " + path.resolve(compilerPath.bin));
tsUtil.compileDirectory(compilerPath.src, compilerPath.bin, cb);
});
/* Cleans up the bin location. */
gulp.task("compilerClean", function (cb: Function): void {
del([compilerPath.bin + "**"], cb);
});
/* Runs style cop on the sources. */
gulp.task("compilerStyleCop", function (cb: Function): void {
var copFile = "../../../../../Internal/TSStyleCop/TSStyleCop.js";
if (!fs.existsSync("copFile")) {
var styleCop = new styleCopUtil.CordovaTools.StyleCopUtil();
styleCop.runCop(compilerPath.src, copFile, cb);
}
});
/* Task to generate NPM package */
/* Test */
module.exports = gulp;

Просмотреть файл

Просмотреть файл

@ -1,79 +0,0 @@
//boostrap project
var exec = require("child_process").exec,
fs = require("fs");
path = require('path');
console.log("************************************************************");
console.log("Preparing taco-cli project for first use.....");
console.log("Run 'gulp' in ./bin/taco-cli/taco-cli to build the project.");
console.log("************************************************************\n\n");
//delete folder recursively
var deleteFolderRecursive = function (path) {
if (fs.existsSync(path)) {
fs.readdirSync(path).forEach(function (file, index) {
var curPath = path + "/" + file;
if (fs.lstatSync(curPath).isDirectory()) { // recurse
deleteFolderRecursive(curPath);
} else { // delete file
fs.unlinkSync(curPath);
}
});
fs.rmdirSync(path);
}
};
var run = function () {
if (fs.existsSync("bin")) {
console.log("---removing bin folder")
deleteFolderRecursive("bin")
}
//compile root gulptfile.ts
var compileMainGulp = function () {
var gulpJS = "./bin/taco-cli/taco-cli/gulpfile.js";
exec("tsc gulpfile.ts --outdir bin/taco-cli --module commonjs", { cwd: "." }, function (error, stdout, stderr) {
if (fs.existsSync(gulpJS)) {
console.log("---compiled " + gulpJS);
}
});
};
var installGlobalPackage = function (packageName) {
packageCommand = "npm ls -g " + packageName;
var result = exec(packageCommand, function (error, stdout, stderr) {
if (stdout.indexOf(packageName) > -1) {
console.log("---found '" + packageName + "' installed globally");
} else {
console.log("---did not find " + packageName + " installed globally, installing.....")
exec("npm install -g " + packageName);
}
if (packageName == "typescript") {
compileMainGulp();
}
});
};
//install global packages
installGlobalPackage("typescript");
////npm install on relevant folders
var foldersToPrep = ["."];
foldersToPrep.forEach(function (folder) {
console.log("---NPM install on folder: " + path.resolve(folder));
var npmProcess = exec("npm install", { cwd: folder }, function (error, stdout, stderr) { compileMainGulp() });
});
installGlobalPackage("gulp");
};
run();

Просмотреть файл

@ -1,3 +0,0 @@
{
"a": ""
}

87
TACO/typings/cordova/cordova.d.ts поставляемый
Просмотреть файл

@ -1,87 +0,0 @@
// Type definitions for Apache Cordova
// Project: http://cordova.apache.org
// Definitions by: Microsoft Open Technologies Inc. <http://msopentech.com>
// Definitions: https://github.com/borisyankov/DefinitelyTyped
//
// Copyright (c) Microsoft Open Technologies, Inc.
// Licensed under the MIT license.
/// <reference path="plugins/BatteryStatus.d.ts"/>
/// <reference path="plugins/Camera.d.ts"/>
/// <reference path="plugins/Contacts.d.ts"/>
/// <reference path="plugins/Device.d.ts"/>
/// <reference path="plugins/DeviceMotion.d.ts"/>
/// <reference path="plugins/DeviceOrientation.d.ts"/>
/// <reference path="plugins/Dialogs.d.ts"/>
/// <reference path="plugins/FileSystem.d.ts"/>
/// <reference path="plugins/FileTransfer.d.ts"/>
/// <reference path="plugins/Globalization.d.ts"/>
/// <reference path="plugins/InAppBrowser.d.ts"/>
/// <reference path="plugins/Media.d.ts"/>
/// <reference path="plugins/MediaCapture.d.ts"/>
/// <reference path="plugins/NetworkInformation.d.ts"/>
/// <reference path="plugins/Push.d.ts"/>
/// <reference path="plugins/Splashscreen.d.ts"/>
/// <reference path="plugins/Vibration.d.ts"/>
/// <reference path="plugins/WebSQL.d.ts"/>
interface Cordova {
/** Invokes native functionality by specifying corresponding service name, action and optional parameters.
* @param success A success callback function.
* @param fail An error callback function.
* @param service The service name to call on the native side (corresponds to a native class).
* @param action The action name to call on the native side (generally corresponds to the native class method).
* @param args An array of arguments to pass into the native environment.
*/
exec(success: () => any, fail: () => any, service: string, action: string, args?: string[]): void;
/** Gets the operating system name. */
platformId: string;
/** Gets Cordova framework version */
version: string;
/** Defines custom logic as a Cordova module. Other modules can later access it using module name provided. */
define(moduleName: string, factory: (require: any, exports: any, module: any) => any): void;
/** Access a Cordova module by name. */
require(moduleName: string): any;
}
interface Document {
addEventListener(type: "deviceready", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "pause", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "resume", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "backbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "menubutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "searchbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "startcallbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "endcallbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "volumedownbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: "volumeupbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "deviceready", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "pause", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "resume", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "backbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "menubutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "searchbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "startcallbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "endcallbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "volumedownbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: "volumeupbutton", listener: (ev: Event) => any, useCapture?: boolean): void;
addEventListener(type: string, listener: (ev: Event) => any, useCapture?: boolean): void;
removeEventListener(type: string, listener: (ev: Event) => any, useCapture?: boolean): void;
}
// cordova/argscheck module
interface ArgsCheck {
checkArgs(argsSpec: string, functionName: string, args: any[], callee?: any): void;
getValue(value?: any, defaultValue?: any): any;
enableChecks: boolean;
}
// cordova/urlutil module
interface UrlUtil {
makeAbsolute(url: string): string
}
/** Apache Cordova instance */
declare var cordova: Cordova;

Просмотреть файл

@ -1,168 +0,0 @@
/// <reference path="node.d.ts" />
import assert = require("assert");
import fs = require("fs");
import events = require("events");
import zlib = require("zlib");
import url = require('url');
import util = require("util");
import crypto = require("crypto");
import http = require("http");
import net = require("net");
import dgram = require("dgram");
assert(1 + 1 - 2 === 0, "The universe isn't how it should.");
assert.deepEqual({ x: { y: 3 } }, { x: { y: 3 } }, "DEEP WENT DERP");
assert.equal(3, "3", "uses == comparator");
assert.notStrictEqual(2, "2", "uses === comparator");
assert.throws(() => { throw "a hammer at your face"; }, undefined, "DODGED IT");
assert.doesNotThrow(() => {
if (false) { throw "a hammer at your face"; }
}, undefined, "What the...*crunch*");
////////////////////////////////////////////////////
/// File system tests : http://nodejs.org/api/fs.html
////////////////////////////////////////////////////
fs.writeFile("thebible.txt",
"Do unto others as you would have them do unto you.",
assert.ifError);
fs.writeFile("Harry Potter",
"\"You be wizzing, Harry,\" jived Dumbledore.",
{
encoding: "ascii"
},
assert.ifError);
var content: string,
buffer: Buffer;
content = fs.readFileSync('testfile', 'utf8');
content = fs.readFileSync('testfile', {encoding : 'utf8'});
buffer = fs.readFileSync('testfile');
buffer = fs.readFileSync('testfile', {flag : 'r'});
fs.readFile('testfile', 'utf8', (err, data) => content = data);
fs.readFile('testfile', {encoding : 'utf8'}, (err, data) => content = data);
fs.readFile('testfile', (err, data) => buffer = data);
fs.readFile('testfile', {flag : 'r'}, (err, data) => buffer = data);
class Networker extends events.EventEmitter {
constructor() {
super();
this.emit("mingling");
}
}
////////////////////////////////////////////////////
/// Url tests : http://nodejs.org/api/url.html
////////////////////////////////////////////////////
url.format(url.parse('http://www.example.com/xyz'));
// https://google.com/search?q=you're%20a%20lizard%2C%20gary
url.format({
protocol: 'https',
host: "google.com",
pathname: 'search',
query: { q: "you're a lizard, gary" }
});
var helloUrl = url.parse('http://example.com/?hello=world', true)
assert.equal(helloUrl.query.hello, 'world');
// Old and new util.inspect APIs
util.inspect(["This is nice"], false, 5);
util.inspect(["This is nice"], { colors: true, depth: 5, customInspect: false });
////////////////////////////////////////////////////
/// Stream tests : http://nodejs.org/api/stream.html
////////////////////////////////////////////////////
// http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options
function stream_readable_pipe_test() {
var r = fs.createReadStream('file.txt');
var z = zlib.createGzip();
var w = fs.createWriteStream('file.txt.gz');
r.pipe(z).pipe(w);
r.close();
}
////////////////////////////////////////////////////
/// Crypto tests : http://nodejs.org/api/crypto.html
////////////////////////////////////////////////////
var hmacResult: string = crypto.createHmac('md5', 'hello').update('world').digest('hex');
function crypto_cipher_decipher_string_test() {
var key:Buffer = new Buffer([1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7]);
var clearText:string = "This is the clear text.";
var cipher:crypto.Cipher = crypto.createCipher("aes-128-ecb", key);
var cipherText:string = cipher.update(clearText, "utf8", "hex");
cipherText += cipher.final("hex");
var decipher:crypto.Decipher = crypto.createDecipher("aes-128-ecb", key);
var clearText2:string = decipher.update(cipherText, "hex", "utf8");
clearText2 += decipher.final("utf8");
assert.equal(clearText2, clearText);
}
function crypto_cipher_decipher_buffer_test() {
var key:Buffer = new Buffer([1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7]);
var clearText:Buffer = new Buffer([1, 2, 3, 4, 5, 6, 7, 8, 9, 8, 7, 6, 5, 4]);
var cipher:crypto.Cipher = crypto.createCipher("aes-128-ecb", key);
var cipherBuffers:Buffer[] = [];
cipherBuffers.push(cipher.update(clearText));
cipherBuffers.push(cipher.final());
var cipherText:Buffer = Buffer.concat(cipherBuffers);
var decipher:crypto.Decipher = crypto.createDecipher("aes-128-ecb", key);
var decipherBuffers:Buffer[] = [];
decipherBuffers.push(decipher.update(cipherText));
decipherBuffers.push(decipher.final());
var clearText2:Buffer = Buffer.concat(decipherBuffers);
assert.deepEqual(clearText2, clearText);
}
////////////////////////////////////////////////////
// Make sure .listen() and .close() retuern a Server instance
http.createServer().listen(0).close().address();
net.createServer().listen(0).close().address();
var request = http.request('http://0.0.0.0');
request.once('error', function () {});
request.setNoDelay(true);
request.abort();
////////////////////////////////////////////////////
/// Http tests : http://nodejs.org/api/http.html
////////////////////////////////////////////////////
module http_tests {
// Status codes
var code = 100;
var codeMessage = http.STATUS_CODES['400'];
var codeMessage = http.STATUS_CODES[400];
}
////////////////////////////////////////////////////
/// Dgram tests : http://nodejs.org/api/dgram.html
////////////////////////////////////////////////////
var ds: dgram.Socket = dgram.createSocket("udp4", (msg: Buffer, rinfo: dgram.RemoteInfo): void => {
});
var ai: dgram.AddressInfo = ds.address();
ds.send(new Buffer("hello"), 0, 5, 5000, "127.0.0.1", (error: Error, bytes: number): void => {
});

Просмотреть файл

@ -1,80 +0,0 @@
"use strict";
import fs = require ("fs");
import path = require ("path");
var resources = null;
var defaultLanguage: string = "en";
export function init(language: string, resourcesDir?: string): void {
if (!resourcesDir) {
resourcesDir = path.join(__dirname, "..", "resources");
}
var lang = bestLanguageMatchOrDefault(language, resourcesDir);
resources = loadLanguage(lang, resourcesDir);
}
export function getString(id: string, ...optionalArgs: any[]): string {
if (!resources) {
throw new Error("Resources have not been loaded");
}
var s = resources[id];
if (!s) {
return s;
}
var args = getOptionalArgsArrayFromFunctionCall(arguments, 1);
if (args) {
for (var i: number = 0; i < args.length; i++) {
s = s.replace("{" + i + "}", args[i]);
}
}
return s;
}
function bestLanguageMatchOrDefault(language: string, resourcesDir: string): string {
if (!language) {
return defaultLanguage;
}
var supportedLanguages: string[] = [];
fs.readdirSync(resourcesDir).filter(function (c: string): boolean {
return fs.existsSync(path.join(resourcesDir, c, "resources.json"));
}).forEach(function (l: string): void {
supportedLanguages.push(l.toLowerCase());
});
// TODO: remove assumption of case insensitive file system, so this can work on non-windows systems.
var lang = language.toLowerCase();
if (supportedLanguages.indexOf(lang) !== -1) {
// exact match on language, which could include the region (e.g. it-CH), return the match
return lang;
}
var primaryLang = lang.split("-")[0];
if (supportedLanguages.indexOf(primaryLang) !== -1) {
// match on primary language (e.g. it from it-CH).
return primaryLang;
}
return defaultLanguage;
}
function loadLanguage(language: string, resourcesDir: string): any {
var resourcesPath = path.join(resourcesDir, language, "resources.json");
return require(resourcesPath);
}
function getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[] {
if (functionArguments.length <= startFrom) {
return null;
}
if (Array.isArray(functionArguments[startFrom])) {
return functionArguments[startFrom];
}
return Array.prototype.slice.apply(functionArguments, [startFrom]);
}

71
src/gulp-compile.ts Normal file
Просмотреть файл

@ -0,0 +1,71 @@
/// <reference path="typings/node.d.ts" />
var fs = require("fs");
var gulp = require("gulp");
var path = require("path");
var exec = require("child_process").exec;
import typescriptUtil = require("../tools/typescript-util");
import styleCopUtil = require("../tools/stylecop-util");
var del = require("del");
var compilerPath = {
src: "../../src", // gulp task compiles all source under "taco-cli" source folder
bin: "../../bin",
};
////////////////// to add additional gulp tasks, add gulpfile in folder and reference it below
// for example: require('./src/compile/gulpfile');
///////////////////////
/* Default task for compiler - runs clean, compile, combine. */
gulp.task("default", ["installBinDependencies", "styleCop"]);
/* Compiles the typescript files in the project. */
gulp.task("fast-compile", function (cb: Function): void {
var tsUtil = new typescriptUtil.TacoUtils.TypescriptServices();
console.log("compilerPath.src: " + path.resolve(compilerPath.src));
console.log("compilerPath.bin: " + path.resolve(compilerPath.bin));
tsUtil.compileDirectory(compilerPath.src, compilerPath.bin, cb);
});
gulp.task("compile", ["clean"], function (cb: Function): void {
var tsUtil = new typescriptUtil.TacoUtils.TypescriptServices();
console.log("compilerPath.src: " + path.resolve(compilerPath.src));
console.log("compilerPath.bin: " + path.resolve(compilerPath.bin));
tsUtil.compileDirectory(compilerPath.src, compilerPath.bin, cb);
});
/* Runs style cop on the sources. */
gulp.task("styleCop", function (cb: Function): void {
var copFile = "../../tools/TSStyleCop/TSStyleCop.js";
if (fs.existsSync("copFile")) {
var styleCop = new styleCopUtil.TacoUtils.StyleCopUtil();
styleCop.runCop(compilerPath.src, copFile, cb);
} else {
cb();
}
});
/* Cleans up the bin location. */
gulp.task("clean", function (cb: Function): void {
del([compilerPath.bin + "**"], { force: true }, cb);
});
/* copy package.json files from source to bin */
gulp.task("copyPackageJSON", ["compile"], function (cb: Function): void {
var cliPath: string = "/taco-cli/package.json";
var utilPath: string = "/taco-utility/package.json";
fs.writeFileSync("../../bin" + cliPath, fs.readFileSync("../../src" + cliPath));
fs.writeFileSync("../../bin" + utilPath, fs.readFileSync("../../src" + utilPath));
cb();
});
gulp.task("installBinDependencies", ["copyPackageJSON"], function (cb: Function): void {
exec("npm install", { cwd: "../../bin/taco-cli" }, cb);
});
/* Task to generate NPM package */
/* Test */
module.exports = gulp;

39
src/gulpfile.js Normal file
Просмотреть файл

@ -0,0 +1,39 @@
var exec = require("child_process").exec,
fs = require("fs"),
path = require('path'),
gulp = require("gulp");
/*default task*/
gulp.task("default", ["runCompiledGulp"], function (cb) {
console.log("************************************************************");
console.log("Prepared taco-cli project for first use.....");
console.log("Run 'gulp' in current folder or 'gulp --gulpfile gulp-compile.js' in ../build/src for subsequent builds");
console.log("************************************************************\n\n");
});
/* Runs style cop on the sources. */
gulp.task("runCompiledGulp", ["compileTSGulpFiles"], function (cb) {
exec("gulp --gulpfile gulp-compile.js", { cwd: "../build/src" }, cb);
});
/* Runs style cop on the sources. */
gulp.task("compileTSGulpFiles", ["installRootFolderGulp", "installRootFolderTypeScript", "installRootFolderDel"], function (cb) {
exec("tsc gulp-compile.ts --outdir ../build --module commonjs", { cwd: "." }, cb);
});
/* install gulp in root folder */
gulp.task("installRootFolderGulp", function (cb) {
exec("npm install gulp", { cwd: ".." }, cb);
});
/* install typescript in root folder */
gulp.task("installRootFolderTypeScript", function (cb) {
exec("npm install typescript", { cwd: ".." }, cb);
});
/* install typescript in root folder */
gulp.task("installRootFolderDel", function (cb) {
exec("npm install del", { cwd: ".." }, cb);
});
module.exports = gulp;

36
src/package.json Normal file
Просмотреть файл

@ -0,0 +1,36 @@
{
"name": "taco-root",
"author": {
"name": "Microsoft Corp."
},
"description": "dependencies needed for initial Gulp use",
"homepage": "",
"version": "0.0.1",
"repository": {
"type": "git",
"url": "https://xxxxxxxxxxgithub.com/Microsoft/taco-cli.git"
},
"keywords": [
"Cordova",
"Microsoft",
"taco",
"Apache",
"cross-platform"
],
"main": "utility.js",
"dependencies": {
"cordova": "^4.2.0",
"nconf": "^0.7.1",
"nopt": "^3.0.1",
"q": "^1.1.2"
},
"devDependencies": {
"typescript": ">=1.4.1",
"del": "^1.0.0",
"event-stream": "^3.1.7",
"gulp": "^3.8.10",
"gulp-concat": "^2.4.2",
"jake": "latest",
"mocha": "latest"
}
}

Просмотреть файл

67
src/taco-cli/cli/taco.ts Normal file
Просмотреть файл

@ -0,0 +1,67 @@
///<reference path="../../typings/taco-utility.d.ts"/>
///<reference path="../../typings/node.d.ts"/>
///<reference path="../../typings/nopt.d.ts"/>
import tacoUtility = require("taco-utility");
import nopt = require("nopt");
import path = require("path");
class Taco {
tacoResources: tacoUtility.Resources;
constructor() {
this.tacoResources = new tacoUtility.Resources("abc");
}
run(): void {
console.log(this.tacoResources.getString("usage"));
var knownOpts =
{
'verbose': Boolean
, 'version': Boolean
, 'help': Boolean
, 'silent': Boolean
, 'experimental': Boolean
, 'noregistry': Boolean
, 'shrinkwrap': Boolean
, 'usegit': Boolean
, 'copy-from': String
, 'link-to': path
, 'searchpath': String
, 'variable': Array
// Flags to be passed to `cordova build/run/emulate`
, 'debug': Boolean
, 'release': Boolean
, 'archs': String
, 'device': Boolean
, 'emulator': Boolean
, 'target': String
, 'browserify': Boolean
, 'nobuild': Boolean
};
var shortHands =
{
'd': '--verbose'
, 'v': '--version'
, 'h': '--help'
, 'src': '--copy-from'
};
// If no inputArgs given, use process.argv.
var inputArguments: string[] = process.argv;
var args = nopt.nopt(knownOpts, shortHands, inputArguments);
console.info(args);
console.info("Number of command-line arguments - " + args.argv.remain.length);
for (var i = 0; i < args.argv.remain.length; ++i) {
console.info(args.argv.remain[i]);
}
}
}
var taco = new Taco();
taco.run();

Просмотреть файл

@ -38,8 +38,10 @@
"cordova": "^4.2.0",
"nconf": "^0.7.1",
"nopt": "^3.0.1",
"q": "^1.1.2"
"q": "^1.1.2",
"taco-utility": "file:../taco-utility"
},
"bundledDependencies": ["taco-utility"],
"devDependencies": {
"typescript": ">=1.4.1",
"del": "^1.0.0",

Просмотреть файл

@ -0,0 +1,3 @@
{
"Usage": "Usage: taco-cli command args",
}

Просмотреть файл

@ -0,0 +1,26 @@
{
"name": "taco-utility",
"author": {
"name": "Microsoft Corp."
},
"description": "strictly internal use to enable require in utility folder",
"homepage": "",
"version": "0.0.1",
"repository": {
"type": "git",
"url": "https://xxxxxxxxxxgithub.com/Microsoft/taco-cli.git"
},
"keywords": [
"Cordova",
"Microsoft",
"taco",
"Apache",
"cross-platform"
],
"main": "taco-utility.js",
"dependencies" : {
"typescript": ">=1.4.1"
},
"devDependencies": {
}
}

Просмотреть файл

@ -0,0 +1,174 @@
///<reference path="../typings/node.d.ts"/>
"use strict";
import fs = require("fs");
import path = require("path");
module TacoUtility {
//put more classes here, known limitation that classes in external modules CANNOT span multiple files
export class Remote {
resources: any = null;
defaultLanguage: string = "en";
constructor(language: string, resourcesDir?: string) {
if (!resourcesDir) {
resourcesDir = path.join(__dirname, "..", "resources");
}
var lang = this.bestLanguageMatchOrDefault(language, resourcesDir);
this.resources = this.loadLanguage(lang, resourcesDir);
}
getString(id: string, ...optionalArgs: any[]): string {
if (!this.resources) {
throw new Error("Resources have not been loaded");
}
var s = this.resources[id];
if (!s) {
return s;
}
var args = this.getOptionalArgsArrayFromFunctionCall(arguments, 1);
if (args) {
for (var i: number = 0; i < args.length; i++) {
s = s.replace("{" + i + "}", args[i]);
}
}
return s;
}
bestLanguageMatchOrDefault(language: string, resourcesDir: string): string {
if (!language) {
return this.defaultLanguage;
}
var supportedLanguages: string[] = [];
fs.readdirSync(resourcesDir).filter(function (c: string): boolean {
return fs.existsSync(path.join(resourcesDir, c, "resources.json"));
}).forEach(function (l: string): void {
supportedLanguages.push(l.toLowerCase());
});
// TODO: remove assumption of case insensitive file system, so this can work on non-windows systems.
var lang = language.toLowerCase();
if (supportedLanguages.indexOf(lang) !== -1) {
// exact match on language, which could include the region (e.g. it-CH), return the match
return lang;
}
var primaryLang = lang.split("-")[0];
if (supportedLanguages.indexOf(primaryLang) !== -1) {
// match on primary language (e.g. it from it-CH).
return primaryLang;
}
return this.defaultLanguage;
}
loadLanguage(language: string, resourcesDir: string): any {
var resourcesPath = path.join(resourcesDir, language, "resources.json");
return require(resourcesPath);
}
getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[] {
if (functionArguments.length <= startFrom) {
return null;
}
if (Array.isArray(functionArguments[startFrom])) {
return functionArguments[startFrom];
}
return Array.prototype.slice.apply(functionArguments, [startFrom]);
}
}
export class Resources {
resources: any = null;
defaultLanguage: string = "en";
constructor(language: string, resourcesDir?: string) {
if (!resourcesDir) {
resourcesDir = path.join(__dirname, "..", "resources");
}
var lang = this.bestLanguageMatchOrDefault(language, resourcesDir);
this.resources = this.loadLanguage(lang, resourcesDir);
}
getString(id: string, ...optionalArgs: any[]): string {
if (!this.resources) {
throw new Error("Resources have not been loaded");
}
var s = this.resources[id];
if (!s) {
return s;
}
var args = this.getOptionalArgsArrayFromFunctionCall(arguments, 1);
if (args) {
for (var i: number = 0; i < args.length; i++) {
s = s.replace("{" + i + "}", args[i]);
}
}
return s;
}
bestLanguageMatchOrDefault(language: string, resourcesDir: string): string {
if (!language) {
return this.defaultLanguage;
}
var supportedLanguages: string[] = [];
fs.readdirSync(resourcesDir).filter(function (c: string): boolean {
return fs.existsSync(path.join(resourcesDir, c, "resources.json"));
}).forEach(function (l: string): void {
supportedLanguages.push(l.toLowerCase());
});
// TODO: remove assumption of case insensitive file system, so this can work on non-windows systems.
var lang = language.toLowerCase();
if (supportedLanguages.indexOf(lang) !== -1) {
// exact match on language, which could include the region (e.g. it-CH), return the match
return lang;
}
var primaryLang = lang.split("-")[0];
if (supportedLanguages.indexOf(primaryLang) !== -1) {
// match on primary language (e.g. it from it-CH).
return primaryLang;
}
return this.defaultLanguage;
}
loadLanguage(language: string, resourcesDir: string): any {
var resourcesPath = path.join(resourcesDir, language, "resources.json");
return require(resourcesPath);
}
getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[] {
if (functionArguments.length <= startFrom) {
return null;
}
if (Array.isArray(functionArguments[startFrom])) {
return functionArguments[startFrom];
}
return Array.prototype.slice.apply(functionArguments, [startFrom]);
}
}
}
export = TacoUtility;

Просмотреть файл

Просмотреть файл

@ -3,7 +3,7 @@
// Definitions by: Drew Noakes <https://drewnoakes.com>
// Definitions: https://github.com/borisyankov/DefinitelyTyped
/// <reference path="../node/node.d.ts" />
/// <reference path="node.d.ts" />
declare module gulp {

Просмотреть файл

Просмотреть файл

Просмотреть файл

@ -1,7 +1,11 @@
// Type definitions for nopt
/// <reference path="../node/node.d.ts" />
declare module 'nopt' {
/// <reference path="node.d.ts" />
declare module Nopt {
export function nopt(types: any, shorthands: any, args: any, slice?: any): any;
export function clean(data: any, types: any, typeDefs: any[]): any;
}
declare module "nopt" {
export = Nopt;
}

56
src/typings/taco-utility.d.ts поставляемый Normal file
Просмотреть файл

@ -0,0 +1,56 @@
/// <reference path="../typings/node.d.ts" />
//declare module TacoUtility {
// //put more classes definitions here, known limitation that classes definitions in external modules CANNOT span multiple files
// export class Resources {
// resources: any;
// defaultLanguage: string;
// constructor(language: string, resourcesDir?: string);
// getString(id: string, ...optionalArgs: any[]): string;
// bestLanguageMatchOrDefault(language: string, resourcesDir: string): string;
// loadLanguage(language: string, resourcesDir: string): any;
// getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[];
// }
//}
//declare module "taco-utility" {
// module TacoUtility {
// class Resources {
// resources: any;
// defaultLanguage: string;
// constructor(language: string, resourcesDir?: string);
// getString(id: string, ...optionalArgs: any[]): string;
// bestLanguageMatchOrDefault(language: string, resourcesDir: string): string;
// loadLanguage(language: string, resourcesDir: string): any;
// getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[];
// }
// }
// export = TacoUtility;
//}
/// <reference path="../typings/node.d.ts" />
declare module TacoUtility {
class Remote {
resources: any;
defaultLanguage: string;
constructor(language: string, resourcesDir?: string);
getString(id: string, ...optionalArgs: any[]): string;
bestLanguageMatchOrDefault(language: string, resourcesDir: string): string;
loadLanguage(language: string, resourcesDir: string): any;
getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[];
}
class Resources {
resources: any;
defaultLanguage: string;
constructor(language: string, resourcesDir?: string);
getString(id: string, ...optionalArgs: any[]): string;
bestLanguageMatchOrDefault(language: string, resourcesDir: string): string;
loadLanguage(language: string, resourcesDir: string): any;
getOptionalArgsArrayFromFunctionCall(functionArguments: IArguments, startFrom: number): any[];
}
}
declare module "taco-utility" {
export = TacoUtility;
}

Просмотреть файл

Просмотреть файл

Просмотреть файл

@ -2,7 +2,7 @@
import fs = require ("fs");
import path = require ("path");
export module CordovaTools {
export module TacoUtils {
/**
* Utility for launching TS style cop as a child process.
*/

Просмотреть файл

@ -1,10 +1,10 @@
/// <reference path="../typings/typescript/typescript.d.ts" />
/// <reference path="../src/typings/typescript.d.ts" />
import ts = require ("typescript");
import fs = require ("fs");
import path = require ("path");
export module CordovaTools {
export module TacoUtils {
export class TypescriptServices {
private static FailureMessage = "Typescript compilation failed.";
@ -46,7 +46,8 @@ export module CordovaTools {
/* push the typescript files */
if (path.extname(currentPath) === ".ts" &&
!currentPath.match("d.ts$") &&
!currentPath.match("gulpfile.ts")) {
!currentPath.match("gulpfile.ts") &&
!currentPath.match("gulp-compile.ts")) {
result.push(currentPath);
}
} else {