Skip to content

Commit

Permalink
fest(@angular-devkit/build-angular): provide option to allow automati…
Browse files Browse the repository at this point in the history
…cally cleaning the terminal screen during rebuilds

When setting `"clearScreen": true` to the appliction builder during rebuilds the terminimal screen will be cleaned.

```json
{
  "projects": {
    "my-app": {
      "projectType": "application",
      "root": "",
      "sourceRoot": "src",
      "architect": {
        "build": {
          "builder": "@angular-devkit/build-angular:application",
          "options": {
            "clearScreen": true
          }
        }
      }
    }
  }
}
```

Closes angular#25699
  • Loading branch information
alan-agius4 committed Feb 1, 2024
1 parent 492b36d commit 1441a7e
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { BuilderOutput } from '@angular-devkit/architect';
import type { logging } from '@angular-devkit/core';
import { existsSync } from 'node:fs';
import path from 'node:path';
import { clearScreenDown, cursorTo } from 'node:readline';
import { BuildOutputFile } from '../../tools/esbuild/bundler-context';
import { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';
import { shutdownSassWorkerPool } from '../../tools/esbuild/stylesheets/sass-language';
Expand All @@ -19,6 +20,20 @@ import { shouldWatchRoot } from '../../utils/environment-options';
import { NormalizedCachedOptions } from '../../utils/normalize-cache';
import { NormalizedOutputOptions } from './options';

// Watch workspace for package manager changes
const packageWatchFiles = [
// manifest can affect module resolution
'package.json',
// npm lock file
'package-lock.json',
// pnpm lock file
'pnpm-lock.yaml',
// yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
'yarn.lock',
'.pnp.cjs',
'.pnp.data.json',
];

export async function* runEsBuildBuildAction(
action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>,
options: {
Expand All @@ -36,13 +51,15 @@ export async function* runEsBuildBuildAction(
poll?: number;
signal?: AbortSignal;
preserveSymlinks?: boolean;
clearScreen?: boolean;
},
): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput> {
const {
writeToFileSystemFilter,
writeToFileSystem,
watch,
poll,
clearScreen,
logger,
deleteOutputPath,
cacheOptions,
Expand Down Expand Up @@ -113,20 +130,6 @@ export async function* runEsBuildBuildAction(
watcher.add(projectRoot);
}

// Watch workspace for package manager changes
const packageWatchFiles = [
// manifest can affect module resolution
'package.json',
// npm lock file
'package-lock.json',
// pnpm lock file
'pnpm-lock.yaml',
// yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
'yarn.lock',
'.pnp.cjs',
'.pnp.data.json',
];

watcher.add(
packageWatchFiles
.map((file) => path.join(workspaceRoot, file))
Expand Down Expand Up @@ -164,6 +167,10 @@ export async function* runEsBuildBuildAction(
break;
}

if (clearScreen) {
clearTerminal();
}

if (verbose) {
logger.info(changes.toDebugString());
}
Expand Down Expand Up @@ -212,3 +219,12 @@ export async function* runEsBuildBuildAction(
shutdownSassWorkerPool();
}
}

function clearTerminal(): void {
const rowCount = process.stdout.rows - 2;
const clean = rowCount > 0 ? '\n'.repeat(rowCount) : '';
// eslint-disable-next-line no-console
console.log(clean);
cursorTo(process.stdout, 0, 0);
clearScreenDown(process.stdout);
}
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ export async function* buildApplicationInternal(
projectRoot: normalizedOptions.projectRoot,
workspaceRoot: normalizedOptions.workspaceRoot,
progress: normalizedOptions.progress,
clearScreen: normalizedOptions.clearScreen,
writeToFileSystem,
// For app-shell and SSG server files are not required by users.
// Omit these when SSR is not enabled.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -294,6 +294,7 @@ export async function normalizeOptions(
namedChunks,
budgets,
deployUrl,
clearScreen,
} = options;

// Return all the normalized options
Expand Down Expand Up @@ -348,6 +349,7 @@ export async function normalizeOptions(
loaderExtensions,
jsonLogs: useJSONBuildLogs,
colors: colors.enabled,
clearScreen,
};
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,11 @@
},
"default": []
},
"clearScreen": {
"type": "boolean",
"default": false,
"description": "Automatically clearing the terminal screen during rebuilds."
},
"optimization": {
"description": "Enables optimization of the build output. Including minification of scripts and styles, tree-shaking, dead-code elimination, inlining of critical CSS and fonts inlining. For more information, see https://angular.io/guide/workspace-config#optimization-configuration.",
"default": true,
Expand Down

0 comments on commit 1441a7e

Please sign in to comment.