Snažím se převést oblíbený projekt na psacím stroji a nezdá se, že by mohli používat tscnástroj pro sledování a kompilovat moje soubory. Pomoc říká, že bych měl použít -wpřepínače, ale vypadá to, že nemůže sledovat a shromažďovat všechny *.tssoubory v určitém adresáři rekurzivně. To se jeví jako něco, co tscby měl být schopen zvládnout. Jaké jsou možnosti?
Jak sledovat a kompilovat všechny zdroje strojopisem?
Vytvořte soubor s názvem tsconfig.jsonv kořenovém adresáři projektu a zahrnují následující řádky v něm:
{
"compilerOptions": {
"emitDecoratorMetadata": true,
"module": "commonjs",
"target": "ES5",
"outDir": "ts-built",
"rootDir": "src"
}
}
Vezměte prosím na vědomí , že outDirby měla být cesta k adresáři přijímat kompilované soubory JS a rootDirby měla být cesta k adresáři, který obsahuje soubory zdroje (Ts).
Otevřete terminál a spusťte tsc -w, bude to sestavit libovolný .tssoubor v srcadresáři do .jsa ukládat je do ts-builtadresáře.
Strojopisem 1.5 beta zavedla podporu pro konfigurační soubor s názvem tsconfig.json. V tomto souboru můžete nastavit kompilátor, definovat pravidla formátování kódu, a co je důležitější pro vás, poskytne mu informace o souborech TS v projektu.
Jakmile správně nastaven, můžete jednoduše spustit příkaz TSC a mít ji shromažďují veškeré strojopisu kódu v projektu.
Chcete-li mít ho sledovat soubory pro změny pak můžete jednoduše přidat --watch příkazu TSC.
Zde je příklad souboru tsconfig.json
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"declaration": false,
"noImplicitAny": false,
"removeComments": true,
"noLib": false
},
"include": [
"**/*"
],
"exclude": [
"node_modules",
"**/*.spec.ts"
]}
Ve výše uvedeném příkladu, I zahrnují všechny Ts soubory v mém projektu (rekurzivně). Všimněte si, že můžete také vyloučit soubory pomocí „vyloučit“ vlastnictví s řadou.
Další informace naleznete v dokumentaci: http://www.typescriptlang.org/docs/handbook/tsconfig-json.html
Technicky vzato máte několik možností zde:
Pokud používáte IDE jako Sublime Text a integrované MSN plugin pro strojopisem: http://blogs.msdn.com/b/interoperability/archive/2012/10/01/sublime-text-vi-emacs-typescript-enabled. aspx můžete vytvořit sestavení systému, který kompilaci .tszdroj na .jsautomaticky. Zde je vysvětlení, jak to lze udělat: Jak nakonfigurovat Sublime sestavit systém pro strojopisem .
Můžete definovat i ke kompilaci zdrojového kódu do cílového .jssouboru na uložení souboru. K dispozici je úžasný balíček umístěn na github: https://github.com/alexnj/SublimeOnSaveBuild které dělají to stalo, jen je třeba zahrnout tspříponu do SublimeOnSaveBuild.sublime-settingssouboru.
Další možností by bylo sestavit každý soubor v příkazovém řádku. Si můžete sestavit i více souborů najednou, oddělte je mezerami, jako je takto: tsc foo.ts bar.ts. Zkontrolujte, zda toto téma: Jak mohu přenést více zdrojových souborů do strojopisu kompilátor? , Ale myslím, že první varianta je po ruce.
Podívejte se do pomocí grunt automatizovat toho existují četné konzultace okolo, ale tady je rychlý start.
Pro strukturu složek, jako jsou:
blah/
blah/one.ts
blah/two.ts
blah/example/
blah/example/example.ts
blah/example/package.json
blah/example/Gruntfile.js
blah/example/index.html
Můžete sledovat a pracovat s psacím stroji snadno z příkladu složky s:
npm install
grunt
S package.json:
{
"name": "PROJECT",
"version": "0.0.1",
"author": "",
"description": "",
"homepage": "",
"private": true,
"devDependencies": {
"typescript": "~0.9.5",
"connect": "~2.12.0",
"grunt-ts": "~1.6.4",
"grunt-contrib-watch": "~0.5.3",
"grunt-contrib-connect": "~0.6.0",
"grunt-open": "~0.2.3"
}
}
A grunt souboru:
module.exports = function (grunt) {
// Import dependencies
grunt.loadNpmTasks('grunt-contrib-watch');
grunt.loadNpmTasks('grunt-contrib-connect');
grunt.loadNpmTasks('grunt-open');
grunt.loadNpmTasks('grunt-ts');
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
connect: {
server: { // <--- Run a local server on :8089
options: {
port: 8089,
base: './'
}
}
},
ts: {
lib: { // <-- compile all the files in ../ to PROJECT.js
src: ['../*.ts'],
out: 'PROJECT.js',
options: {
target: 'es3',
sourceMaps: false,
declaration: true,
removeComments: false
}
},
example: { // <--- compile all the files in . to example.js
src: ['*.ts'],
out: 'example.js',
options: {
target: 'es3',
sourceMaps: false,
declaration: false,
removeComments: false
}
}
},
watch: {
lib: { // <-- Watch for changes on the library and rebuild both
files: '../*.ts',
tasks: ['ts:lib', 'ts:example']
},
example: { // <--- Watch for change on example and rebuild
files: ['*.ts', '!*.d.ts'],
tasks: ['ts:example']
}
},
open: { // <--- Launch index.html in browser when you run grunt
dev: {
path: 'http://localhost:8089/index.html'
}
}
});
// Register the default tasks to run when you run grunt
grunt.registerTask('default', ['ts', 'connect', 'open', 'watch']);
}
TSC kompilátor bude sledovat pouze ty soubory, které procházejí na příkazovém řádku. Bude to sledovat soubory, které jsou zahrnuty pomocí /// <sourcefile>odkazu. Pokud váš práci s bash, můžete použít najít rekurzivně najít všechny *.tssoubory a sestaví z nich:
find . -name "*.ts" | xargs tsc -w
můžete sledovat všechny soubory, jako je tento
tsc *.ts --watch
TSC 0.9.1.1 nezdá mít hodinky funkci.
můžete použít PowerShell skript, jako ten, který jsem provedené na tento post:
Dnes jsem navrhl tento mravenec MacroDef pro stejný problém, jako je ta vaše:
<!--
Recursively read a source directory for TypeScript files, generate a compile list in the
format needed by the TypeScript compiler adding every parameters it take.
-->
<macrodef name="TypeScriptCompileDir">
<!-- required attribute -->
<attribute name="src" />
<!-- optional attributes -->
<attribute name="out" default="" />
<attribute name="module" default="" />
<attribute name="comments" default="" />
<attribute name="declarations" default="" />
<attribute name="nolib" default="" />
<attribute name="target" default="" />
<sequential>
<!-- local properties -->
<local name="out.arg"/>
<local name="module.arg"/>
<local name="comments.arg"/>
<local name="declarations.arg"/>
<local name="nolib.arg"/>
<local name="target.arg"/>
<local name="typescript.file.list"/>
<local name="tsc.compile.file"/>
<property name="tsc.compile.file" value="@{src}compile.list" />
<!-- Optional arguments are not written to compile file when attributes not set -->
<condition property="out.arg" value="" else='--out "@{out}"'>
<equals arg1="@{out}" arg2="" />
</condition>
<condition property="module.arg" value="" else="--module @{module}">
<equals arg1="@{module}" arg2="" />
</condition>
<condition property="comments.arg" value="" else="--comments">
<equals arg1="@{comments}" arg2="" />
</condition>
<condition property="declarations.arg" value="" else="--declarations">
<equals arg1="@{declarations}" arg2="" />
</condition>
<condition property="nolib.arg" value="" else="--nolib">
<equals arg1="@{nolib}" arg2="" />
</condition>
<!-- Could have been defaulted to ES3 but let the compiler uses its own default is quite better -->
<condition property="target.arg" value="" else="--target @{target}">
<equals arg1="@{target}" arg2="" />
</condition>
<!-- Recursively read TypeScript source directory and generate a compile list -->
<pathconvert property="typescript.file.list" dirsep="\" pathsep="${line.separator}">
<fileset dir="@{src}">
<include name="**/*.ts" />
</fileset>
<!-- In case regexp doesn't work on your computer, comment <mapper /> and uncomment <regexpmapper /> -->
<mapper type="regexp" from="^(.*)$" to='"\1"' />
<!--regexpmapper from="^(.*)$" to='"\1"' /-->
</pathconvert>
<!-- Write to the file -->
<echo message="Writing tsc command line arguments to : ${tsc.compile.file}" />
<echo file="${tsc.compile.file}" message="${typescript.file.list}${line.separator}${out.arg}${line.separator}${module.arg}${line.separator}${comments.arg}${line.separator}${declarations.arg}${line.separator}${nolib.arg}${line.separator}${target.arg}" append="false" />
<!-- Compile using the generated compile file -->
<echo message="Calling ${typescript.compiler.path} with ${tsc.compile.file}" />
<exec dir="@{src}" executable="${typescript.compiler.path}">
<arg value="@${tsc.compile.file}"/>
</exec>
<!-- Finally delete the compile file -->
<echo message="${tsc.compile.file} deleted" />
<delete file="${tsc.compile.file}" />
</sequential>
</macrodef>
Použijte ji ve svém sestavení souboru s:
<!-- Compile a single JavaScript file in the bin dir for release -->
<TypeScriptCompileDir
src="${src-js.dir}"
out="${release-file-path}"
module="amd"
/>
To je použito v rámci projektu PureMVC na psacím stroji pracuji v té době používání Webstorm.













