transfer-out: transfer out
This commit is contained in:
parent
ec84f64e63
commit
29ed921c67
1056 changed files with 154507 additions and 0 deletions
62
scripts/build-api.ts
Normal file
62
scripts/build-api.ts
Normal file
|
@ -0,0 +1,62 @@
|
|||
import glob from 'glob'
|
||||
import isCI from 'is-ci'
|
||||
import path from 'path'
|
||||
import { rimraf } from 'rimraf'
|
||||
import { exec } from './lib/exec'
|
||||
import { sortUnions } from './lib/sort-unions'
|
||||
|
||||
async function buildApi(sourcePackageDir: string) {
|
||||
// this depends on `build:types` being run first, but we'll rely on turbo to
|
||||
// make that happen.
|
||||
|
||||
const relativeSourcePackageDir = path.relative(path.resolve(__dirname, '../..'), sourcePackageDir)
|
||||
|
||||
// we need to copy the .tsbuild dir to another location so we can edit it without busting the cache
|
||||
await rimraf(path.join(sourcePackageDir, '.tsbuild-api'))
|
||||
await exec('cp', ['-R', './.tsbuild', './.tsbuild-api'], { pwd: sourcePackageDir })
|
||||
|
||||
sortUnions(path.join(sourcePackageDir, '.tsbuild-api'))
|
||||
|
||||
// clear api-extractor build files
|
||||
rimraf.sync(glob.sync(path.join(sourcePackageDir, 'api')))
|
||||
// extract public api
|
||||
try {
|
||||
await exec('yarn', ['run', '-T', 'api-extractor', 'run', isCI ? null : '--local'], {
|
||||
pwd: sourcePackageDir,
|
||||
processStderrLine: (line) => {
|
||||
process.stderr.write(`${line}\n`)
|
||||
|
||||
if (process.env.PRINT_GITHUB_ANNOTATIONS) {
|
||||
const errorMatch = line.match(
|
||||
// eslint-disable-next-line no-control-regex
|
||||
/^(?:\u001b\[33m)?(Warning|Error): (.+?):(\d+):(\d+) - \((.*)\) (.*)(?:\u001b\[39m)?$/
|
||||
)
|
||||
if (errorMatch) {
|
||||
const [, errorType, file, line, column, messageTitle, message] = errorMatch
|
||||
|
||||
process.stdout.write(
|
||||
`::${errorType.toLowerCase()} file=${relativeSourcePackageDir}/${file},line=${line},col=${column},title=${messageTitle}::${message}}\n`
|
||||
)
|
||||
}
|
||||
}
|
||||
},
|
||||
})
|
||||
} catch (e) {
|
||||
console.error(e)
|
||||
|
||||
// get git diff
|
||||
console.error('api-report diff')
|
||||
await exec('git', [
|
||||
'diff',
|
||||
'--no-color',
|
||||
'--no-ext-diff',
|
||||
'--no-index',
|
||||
'api-report.md',
|
||||
'api/temp/api-report.md',
|
||||
])
|
||||
|
||||
process.exit(1)
|
||||
}
|
||||
}
|
||||
|
||||
buildApi(process.cwd())
|
Loading…
Add table
Add a link
Reference in a new issue