2015-10-05 35 views
8

Mam aplikację kątową wygenerowaną za pomocą generatora maszynowego Yeomana.pisarz maszynowy wyrzuca błąd TS2300: Zduplikowany identyfikator "moment"

Nagle bez żadnego widocznego powodu zmian w projekcie() podczas kompilacji maszynopisu zaczęli rzucać błędy:

.tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'. 
[22:08:34] [TypeScript] TypeScript error: .tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'. 
.tmp/typings/moment/moment.d.ts(8,13): error TS2300: Duplicate identifier 'moment'. 

patrz poniżej treść poniższych plików na odniesienie. Usunięto zadanie "tsd: install" z gulp script, aby zapobiec kompilacji z nadpisywania plików d.ts i tsd.d.ts. Następnie próbowałem zmodyfikować tsd.dts, aby naprawić problem (próbowałem usunąć moment-węzeł, moment, zmienić kolejność, próbowałem również edytować moment.d.ts i moment-node.d.ts, nic nie działało: /) .

Mój plik tsd.json:

{ 
    "version": "v4", 
    "repo": "borisyankov/DefinitelyTyped", 
    "ref": "master", 
    "path": ".tmp/typings", 
    "bundle": ".tmp/typings/tsd.d.ts" 
} 

Moi script.js (taks haustem):

'use strict'; 

var path = require('path'); 
var gulp = require('gulp'); 
var conf = require('./conf'); 

var browserSync = require('browser-sync'); 

var $ = require('gulp-load-plugins')(); 

    var tsProject = $.typescript.createProject({ 
    target: 'es5', 
    sortOutput: true 
    }); 

    gulp.task('scripts', ['tsd:install'], function() { 
    return gulp.src(path.join(conf.paths.src, '/app/**/*.ts')) 
    .pipe($.sourcemaps.init()) 
    .pipe($.tslint()) 
    .pipe($.tslint.report('prose', { emitError: false })) 
    .pipe($.typescript(tsProject)).on('error', conf.errorHandler('TypeScript')) 
    .pipe($.concat('index.module.js')) 
    .pipe($.sourcemaps.write()) 
    .pipe(gulp.dest(path.join(conf.paths.tmp, '/serve/app'))) 
    .pipe(browserSync.reload({ stream: true })) 
    .pipe($.size()) 
}); 

Wygenerowane tsd.d.ts:

/// <reference path="angular-local-storage/angular-local-storage.d.ts" /> 
/// <reference path="angular-ui-router/angular-ui-router.d.ts" /> 
/// <reference path="angularjs/angular-animate.d.ts" /> 
/// <reference path="angularjs/angular-cookies.d.ts" /> 
/// <reference path="angularjs/angular-mocks.d.ts" /> 
/// <reference path="angularjs/angular-resource.d.ts" /> 
/// <reference path="angularjs/angular-sanitize.d.ts" /> 
/// <reference path="angularjs/angular.d.ts" /> 
/// <reference path="bootstrap/bootstrap.d.ts" /> 
/// <reference path="d3/d3.d.ts" /> 
/// <reference path="jquery/jquery.d.ts" /> 
/// <reference path="moment/moment.d.ts" /> 
/// <reference path="moment/moment-node.d.ts" /> 
/// <reference path="toastr/toastr.d.ts" /> 

Odpowiedz

6

Jeśli wskażesz do konkretnej wersji takiej jak 1.4.1 zamiast "master" dla ref: - Myślę, że to naprawi to za Ciebie. To działa dla mnie.

{ 
    "version": "v4", 
    "repo": "borisyankov/DefinitelyTyped", 
    "ref": "1.4.1", 
    "path": ".tmp/typings", 
    "bundle": ".tmp/typings/tsd.d.ts" 
} 
+0

Dodanie jawnej wersji '1.4.1' w' tsd.json', pracował. Dobre wyczucie czasu :-) –

1

Komunikat o błędzie wprowadza w błąd. Wierzę, że ten faktyczny powód błędu ortograficznego wynika z pliku definicji typu na chwilę przy użyciu funkcji TypeScript, której aktualna wersja nie obsługuje. Uruchom następującą wersję, aby uzyskać najnowszą wersję gulp-maszynopisu, a następnie myślę, że wszystko będzie działać dla ciebie, bez konieczności ograniczania pliku TSD do konkretnej wersji. Ograniczenie go do konkretnej wersji będzie miało swoje własne problemy.

npm install [email protected] --save-dev 
0

usuń kendo all.d.ts, a następnie przebuduj swoją witrynę w wwwroot. działa to dla mnie