2017-01-17 23:58:09 +00:00
|
|
|
import * as q from 'smartq'
|
2016-10-21 15:48:52 +00:00
|
|
|
import { ProjectinfoNpm } from 'projectinfo'
|
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
// interfaces
|
|
|
|
import { INpmtsConfig } from '../npmts.config'
|
|
|
|
|
2016-10-21 15:48:52 +00:00
|
|
|
import * as paths from '../npmts.paths'
|
2016-10-02 18:35:13 +00:00
|
|
|
|
2016-10-21 15:48:52 +00:00
|
|
|
import * as plugins from './mod00.plugins'
|
2016-09-02 12:10:09 +00:00
|
|
|
|
2016-09-06 15:21:25 +00:00
|
|
|
export let projectInfo: ProjectinfoNpm
|
2016-09-02 12:10:09 +00:00
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
let checkProjectTypings = (configArg: INpmtsConfig) => {
|
|
|
|
let done = q.defer<INpmtsConfig>()
|
2017-05-04 22:01:21 +00:00
|
|
|
plugins.beautylog.ora.text('Check Module: Check Project Typings...')
|
|
|
|
projectInfo = new ProjectinfoNpm(paths.cwd)
|
|
|
|
if (typeof projectInfo.packageJson.typings === 'undefined') {
|
|
|
|
plugins.beautylog.error(`please add typings field to package.json`)
|
|
|
|
process.exit(1)
|
|
|
|
};
|
|
|
|
done.resolve(configArg)
|
|
|
|
return done.promise
|
2016-09-06 15:21:25 +00:00
|
|
|
}
|
2016-07-28 01:10:51 +00:00
|
|
|
|
2016-07-28 01:45:14 +00:00
|
|
|
const depcheckOptions = {
|
2017-05-04 22:01:21 +00:00
|
|
|
ignoreBinPackage: false, // ignore the packages with bin entry
|
|
|
|
parsers: { // the target parsers
|
|
|
|
'*.ts': plugins.depcheck.parser.typescript
|
|
|
|
},
|
|
|
|
detectors: [ // the target detectors
|
|
|
|
plugins.depcheck.detector.requireCallExpression,
|
|
|
|
plugins.depcheck.detector.importDeclaration
|
|
|
|
],
|
|
|
|
specials: [ // the target special parsers
|
|
|
|
plugins.depcheck.special.eslint,
|
|
|
|
plugins.depcheck.special.webpack
|
|
|
|
]
|
2016-09-06 15:21:25 +00:00
|
|
|
}
|
2016-07-28 01:45:14 +00:00
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
let checkDependencies = (configArg: INpmtsConfig) => {
|
|
|
|
let done = q.defer<INpmtsConfig>()
|
2017-05-04 22:01:21 +00:00
|
|
|
plugins.beautylog.ora.text('Check Module: Check Dependencies...')
|
|
|
|
let depcheckOptionsMerged = plugins.lodash.merge(depcheckOptions, {
|
|
|
|
ignoreDirs: [ // folder with these names will be ignored
|
|
|
|
'test',
|
|
|
|
'dist',
|
|
|
|
'bower_components'
|
|
|
|
],
|
|
|
|
ignoreMatches: [ // ignore dependencies that matches these globs
|
|
|
|
'@types/*',
|
|
|
|
'babel-preset-*'
|
|
|
|
]
|
|
|
|
})
|
|
|
|
plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => {
|
|
|
|
for (let item of unused.dependencies) {
|
|
|
|
plugins.beautylog.warn(`Watch out: unused dependency "${item}"`)
|
|
|
|
}
|
|
|
|
for (let item in unused.missing) {
|
|
|
|
plugins.beautylog.error(`missing dependency "${item}" in package.json`)
|
|
|
|
}
|
|
|
|
if (unused.missing.length > 0) {
|
|
|
|
plugins.beautylog.info('exiting due to missing dependencies in package.json')
|
|
|
|
process.exit(1)
|
|
|
|
}
|
|
|
|
for (let item in unused.invalidFiles) {
|
|
|
|
plugins.beautylog.warn(`Watch out: could not parse file ${item}`)
|
|
|
|
};
|
|
|
|
for (let item in unused.invalidDirs) {
|
|
|
|
plugins.beautylog.warn(`Watch out: could not parse directory ${item}`)
|
|
|
|
}
|
|
|
|
done.resolve(configArg)
|
|
|
|
})
|
|
|
|
return done.promise
|
2016-09-06 15:21:25 +00:00
|
|
|
}
|
2016-07-28 01:45:14 +00:00
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
let checkDevDependencies = (configArg: INpmtsConfig) => {
|
|
|
|
let done = q.defer<INpmtsConfig>()
|
2017-05-04 22:01:21 +00:00
|
|
|
plugins.beautylog.ora.text('Check Module: Check devDependencies...')
|
|
|
|
let depcheckOptionsMerged = plugins.lodash.merge(depcheckOptions, {
|
|
|
|
ignoreDirs: [ // folder with these names will be ignored
|
|
|
|
'ts',
|
|
|
|
'dist',
|
|
|
|
'bower_components'
|
|
|
|
],
|
|
|
|
ignoreMatches: [ // ignore dependencies that matches these globs
|
|
|
|
'@types/*',
|
|
|
|
'babel-preset-*'
|
|
|
|
]
|
|
|
|
})
|
|
|
|
plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => {
|
|
|
|
for (let item of unused.devDependencies) {
|
|
|
|
plugins.beautylog.log(`unused devDependency ${item}`)
|
|
|
|
}
|
|
|
|
for (let item in unused.missing) {
|
|
|
|
plugins.beautylog.error(`missing devDependency ${item}`)
|
|
|
|
}
|
|
|
|
if (unused.missing.length > 0) {
|
|
|
|
plugins.beautylog.info('exiting due to missing dependencies in package.json')
|
|
|
|
process.exit(1)
|
|
|
|
}
|
|
|
|
for (let item in unused.invalidFiles) {
|
|
|
|
plugins.beautylog.warn(`Watch out: could not parse file ${item}`)
|
|
|
|
}
|
|
|
|
for (let item in unused.invalidDirs) {
|
|
|
|
plugins.beautylog.warn(`Watch out: could not parse directory ${item}`)
|
|
|
|
}
|
|
|
|
done.resolve(configArg)
|
|
|
|
})
|
|
|
|
return done.promise
|
2016-09-06 15:21:25 +00:00
|
|
|
}
|
2016-07-28 01:10:51 +00:00
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
let checkNodeVersion = (configArg: INpmtsConfig) => {
|
|
|
|
let done = q.defer<INpmtsConfig>()
|
2017-05-04 22:01:21 +00:00
|
|
|
plugins.beautylog.ora.text('checking node version')
|
|
|
|
done.resolve(configArg)
|
|
|
|
return done.promise
|
2016-07-28 01:10:51 +00:00
|
|
|
}
|
|
|
|
|
2017-06-21 18:54:28 +00:00
|
|
|
export let run = async (configArg: INpmtsConfig) => {
|
2017-05-04 22:01:21 +00:00
|
|
|
plugins.beautylog.ora.text('Check Module: ...')
|
2017-06-15 23:42:48 +00:00
|
|
|
|
|
|
|
if (configArg.checkDependencies) {
|
2017-06-21 18:54:28 +00:00
|
|
|
configArg = await checkProjectTypings(configArg)
|
|
|
|
configArg = await checkDependencies(configArg)
|
|
|
|
configArg = await checkDevDependencies(configArg)
|
|
|
|
configArg = await checkNodeVersion(configArg)
|
|
|
|
return configArg
|
2017-06-15 23:42:48 +00:00
|
|
|
} else {
|
2017-06-21 18:54:28 +00:00
|
|
|
configArg = await checkProjectTypings(configArg)
|
|
|
|
return configArg
|
2017-06-15 23:42:48 +00:00
|
|
|
}
|
2016-07-28 01:10:51 +00:00
|
|
|
}
|