We can define regions in our examples that can be referenced and rendered in guides as code snippets. It is quite hard to ensure that these regions are maintained correctly. One reason for this is it is hard to know whether a region is being used or not. This commit adds a new processor that checks for unused named regions in examples and fails if any are found. Fixes #19761 PR Close #40479
157 lines
6.3 KiB
JavaScript
157 lines
6.3 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
const path = require('path');
|
|
const Package = require('dgeni').Package;
|
|
|
|
const gitPackage = require('dgeni-packages/git');
|
|
const jsdocPackage = require('dgeni-packages/jsdoc');
|
|
const nunjucksPackage = require('dgeni-packages/nunjucks');
|
|
const linksPackage = require('../links-package');
|
|
const examplesPackage = require('../examples-package');
|
|
const targetPackage = require('../target-package');
|
|
const remarkPackage = require('../remark-package');
|
|
const postProcessPackage = require('dgeni-packages/post-process-html');
|
|
|
|
const { PROJECT_ROOT, CONTENTS_PATH, OUTPUT_PATH, DOCS_OUTPUT_PATH, TEMPLATES_PATH, AIO_PATH, requireFolder } = require('../config');
|
|
|
|
module.exports = new Package('angular-base', [
|
|
gitPackage, jsdocPackage, nunjucksPackage, linksPackage, examplesPackage, targetPackage, remarkPackage, postProcessPackage
|
|
])
|
|
|
|
// Register the processors
|
|
.processor(require('./processors/generateKeywords'))
|
|
.processor(require('./processors/createSitemap'))
|
|
.processor(require('./processors/checkUnbalancedBackTicks'))
|
|
.processor(require('./processors/convertToJson'))
|
|
.processor(require('./processors/fixInternalDocumentLinks'))
|
|
.processor(require('./processors/copyContentAssets'))
|
|
.processor(require('./processors/renderLinkInfo'))
|
|
.processor(require('./processors/checkContentRules'))
|
|
.processor(require('./processors/splitDescription'))
|
|
|
|
// overrides base packageInfo and returns the one for the 'angular/angular' repo.
|
|
.factory('packageInfo', function() { return require(path.resolve(PROJECT_ROOT, 'package.json')); })
|
|
.factory(require('./readers/json'))
|
|
.factory(require('./services/copyFolder'))
|
|
.factory(require('./services/getImageDimensions'))
|
|
.factory(require('./services/getPreviousMajorVersions'))
|
|
.factory(require('./services/auto-link-filters/filterPipes'))
|
|
.factory(require('./services/auto-link-filters/filterAmbiguousDirectiveAliases'))
|
|
.factory(require('./services/auto-link-filters/ignoreHttpInUrls'))
|
|
.factory(require('./services/auto-link-filters/ignoreGenericWords'))
|
|
|
|
.factory(require('./post-processors/add-image-dimensions'))
|
|
.factory(require('./post-processors/auto-link-code'))
|
|
|
|
// Configure jsdoc-style tag parsing
|
|
.config(function(inlineTagProcessor) {
|
|
inlineTagProcessor.inlineTagDefinitions.push(require('./inline-tag-defs/custom-search-defs/'));
|
|
})
|
|
|
|
.config(function(checkAnchorLinksProcessor, checkForUnusedExampleRegions) {
|
|
// These are disabled here to prevent false negatives for the `docs-watch` task.
|
|
// It is re-enabled in the main `angular.io-package`
|
|
checkAnchorLinksProcessor.$enabled = false;
|
|
checkForUnusedExampleRegions.$enabled = false;
|
|
})
|
|
|
|
// Where do we get the source files?
|
|
.config(function(readFilesProcessor, collectExamples, generateKeywordsProcessor, jsonFileReader) {
|
|
|
|
readFilesProcessor.fileReaders.push(jsonFileReader);
|
|
readFilesProcessor.basePath = PROJECT_ROOT;
|
|
readFilesProcessor.sourceFiles = [];
|
|
collectExamples.exampleFolders = [];
|
|
|
|
generateKeywordsProcessor.ignoreWordsFile = path.resolve(__dirname, 'ignore.words');
|
|
generateKeywordsProcessor.docTypesToIgnore = ['example-region'];
|
|
generateKeywordsProcessor.propertiesToIgnore = ['basePath', 'renderedContent'];
|
|
})
|
|
|
|
// Where do we write the output files?
|
|
.config(function(writeFilesProcessor) { writeFilesProcessor.outputFolder = DOCS_OUTPUT_PATH; })
|
|
|
|
// Target environments
|
|
.config(function(targetEnvironments) {
|
|
const ALLOWED_LANGUAGES = ['ts', 'js', 'dart'];
|
|
const TARGET_LANGUAGE = 'ts';
|
|
|
|
ALLOWED_LANGUAGES.forEach(target => targetEnvironments.addAllowed(target));
|
|
targetEnvironments.activate(TARGET_LANGUAGE);
|
|
})
|
|
|
|
|
|
// Configure nunjucks rendering of docs via templates
|
|
.config(function(
|
|
renderDocsProcessor, templateFinder, templateEngine, getInjectables) {
|
|
|
|
// Where to find the templates for the doc rendering
|
|
templateFinder.templateFolders = [TEMPLATES_PATH];
|
|
|
|
// Standard patterns for matching docs to templates
|
|
templateFinder.templatePatterns = [
|
|
'${ doc.template }', '${ doc.id }.${ doc.docType }.template.html',
|
|
'${ doc.id }.template.html', '${ doc.docType }.template.html',
|
|
'${ doc.id }.${ doc.docType }.template.js', '${ doc.id }.template.js',
|
|
'${ doc.docType }.template.js', '${ doc.id }.${ doc.docType }.template.json',
|
|
'${ doc.id }.template.json', '${ doc.docType }.template.json', 'common.template.html'
|
|
];
|
|
|
|
// Nunjucks and Angular conflict in their template bindings so change Nunjucks
|
|
templateEngine.config.tags = {variableStart: '{$', variableEnd: '$}'};
|
|
|
|
templateEngine.filters =
|
|
templateEngine.filters.concat(getInjectables(requireFolder(__dirname, './rendering')));
|
|
|
|
// helpers are made available to the nunjucks templates
|
|
renderDocsProcessor.helpers.relativePath = function(from, to) {
|
|
return path.relative(from, to);
|
|
};
|
|
})
|
|
|
|
.config(function(copyContentAssetsProcessor) {
|
|
copyContentAssetsProcessor.assetMappings.push(
|
|
{ from: path.resolve(CONTENTS_PATH, 'images'), to: path.resolve(OUTPUT_PATH, 'images') }
|
|
);
|
|
})
|
|
|
|
// We are not going to be relaxed about ambiguous links
|
|
.config(function(getLinkInfo) {
|
|
getLinkInfo.useFirstAmbiguousLink = false;
|
|
})
|
|
|
|
|
|
|
|
.config(function(computePathsProcessor, generateKeywordsProcessor) {
|
|
|
|
generateKeywordsProcessor.outputFolder = 'app';
|
|
|
|
// Replace any path templates inherited from other packages
|
|
// (we want full and transparent control)
|
|
computePathsProcessor.pathTemplates = [
|
|
{docTypes: ['example-region'], getOutputPath: function() {}},
|
|
];
|
|
})
|
|
|
|
|
|
.config(function(postProcessHtml, addImageDimensions, autoLinkCode, filterPipes, filterAmbiguousDirectiveAliases, ignoreHttpInUrls, ignoreGenericWords) {
|
|
addImageDimensions.basePath = path.resolve(AIO_PATH, 'src');
|
|
autoLinkCode.customFilters = [ignoreGenericWords, ignoreHttpInUrls, filterPipes, filterAmbiguousDirectiveAliases];
|
|
autoLinkCode.failOnMissingDocPath = true;
|
|
postProcessHtml.plugins = [
|
|
require('./post-processors/autolink-headings'),
|
|
addImageDimensions,
|
|
require('./post-processors/h1-checker'),
|
|
autoLinkCode,
|
|
];
|
|
})
|
|
|
|
.config(function(convertToJsonProcessor) {
|
|
convertToJsonProcessor.docTypes = [];
|
|
});
|