#!/usr/bin/env node /** * Copyright 2017 Google Inc. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ const path = require('path'); const Source = require('./Source.js'); const PROJECT_DIR = path.join(__dirname, '..', '..'); const VERSION = require(path.join(PROJECT_DIR, 'package.json')).version; const RED_COLOR = '\x1b[31m'; const BLUE_COLOR = '\x1b[34m'; const YELLOW_COLOR = '\x1b[33m'; const RESET_COLOR = '\x1b[0m'; const IS_RELEASE = Boolean(process.env.IS_RELEASE); run(); async function run() { const startTime = Date.now(); /** @type {!Array<!Message>} */ const messages = []; let changedFiles = false; if (IS_RELEASE) { const versions = await Source.readFile( path.join(PROJECT_DIR, 'versions.js') ); versions.setText( versions.text().replace(`, 'NEXT'],`, `, 'v${VERSION}'],`) ); await versions.save(); } // Documentation checks. const readme = await Source.readFile(path.join(PROJECT_DIR, 'README.md')); const contributing = await Source.readFile( path.join(PROJECT_DIR, 'CONTRIBUTING.md') ); const api = await Source.readFile(path.join(PROJECT_DIR, 'docs', 'api.md')); const troubleshooting = await Source.readFile( path.join(PROJECT_DIR, 'docs', 'troubleshooting.md') ); const mdSources = [readme, api, troubleshooting, contributing]; const preprocessor = require('./preprocessor/index.js'); messages.push( ...(await preprocessor.runCommands(mdSources, VERSION, IS_RELEASE)) ); messages.push( ...(await preprocessor.ensureReleasedAPILinks( [readme], VERSION, IS_RELEASE )) ); for (const source of mdSources) { if (!source.hasUpdatedText()) { continue; } await source.save(); changedFiles = true; } // Report results. const errors = messages.filter((message) => message.type === 'error'); if (errors.length) { console.log('DocLint Failures:'); for (let i = 0; i < errors.length; ++i) { const text = errors[i].text.split('\n').join('\n '); console.log(` ${i + 1}) ${RED_COLOR}${text}${RESET_COLOR}`); } } const warnings = messages.filter((message) => message.type === 'warning'); if (warnings.length) { console.log('DocLint Warnings:'); for (let i = 0; i < warnings.length; ++i) { const text = warnings[i].text.split('\n').join('\n '); console.log(` ${i + 1}) ${YELLOW_COLOR}${text}${RESET_COLOR}`); } } const info = messages.filter((message) => message.type === 'info'); if (info.length) { console.log('DocLint Info:'); for (let i = 0; i < info.length; i++) { const text = info[i].text.split('\n').join('\n '); console.log(` ${i + 1}) ${BLUE_COLOR}${text}${RESET_COLOR}`); } } if (changedFiles) { console.log(`${BLUE_COLOR}Some files were updated.${RESET_COLOR}`); } console.log( `${info.length} info, ${errors.length} failures, ${warnings.length} warnings.` ); const clearExit = errors.length + warnings.length === 0; if (!clearExit && !process.env.GITHUB_ACTIONS) { console.log( '\nIs your lib/ directory up to date? You might need to `npm run build:tsc`.\n' ); } const runningTime = Date.now() - startTime; console.log(`DocLint Finished in ${runningTime / 1000} seconds`); process.exit(clearExit || IS_RELEASE ? 0 : 1); }