Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@cplace/asc
Advanced tools
cplace-asc
is the new cplace assets compiler toolchain used to compile TypeScript and LESS sources into their JavaScript and CSS counterparts as well as compress multiple CSS files into a single file.
Just run the following command which will install the assets compiler globally:
$ npm install -g @cplace/asc
The assets compiler supports multiple parameters:
$ cplace-asc --help
⇢ Checking whether newer version is available... ✓
cplace assets compiler
Usage:
$ cplace-asc
Options:
--plugin, -p <plugin> Run for specified plugin (and dependencies)
--watch, -w Enable watching of source files (continuous compilation)
--onlypre, -o Run only preprocessing steps (like create tsconfig.json files)
--clean, -c Clean generated output folders at the beginning
--threads, -t Maximum number of threads to run in parallel
--localonly, -l Enable to not scan other directories than CWD for plugins
--verbose, -v Enable verbose logging
--production, -P Enable production mode (ignores test dependencies)
Option | Type (Default) | Description |
---|---|---|
--plugin / -p
| string (*empty*) | Specify the name of a single plugin for which the assets compiler should be started. Will also compile dependencies of this plugin. |
--watch / -w
| boolean (false ) | When enabled the compiler will watch for changes in any source files and trigger recompilation. All plugins that depend on the modified plugin will also be recompiled. |
--onlypre / -o
| boolean (false ) | When active only preprocessing steps like generating the tsconfig.json files or cleaning the output directories (--clean ) will be executed but no compilation. |
--clean / -c
| boolean (false ) | When enabled the assets compiler will first clean any output directories where compiled assets are placed (e.g. generated_js and generated_css ). |
--production / -P
| boolean (false ) | When enabled the assets compiler will ignore dependencies that are marked as TEST scoped. Furthermore, no source maps will be generated. |
--verbose / -v
| boolean (false ) | When enabled verbose logging statements are output in order to facilitate debugging. |
The tool will automatically check for updates on every run so you will be prompted with a large message when a newer version is available:
$ cplace-asc --help
⇢ Checking whether newer version is available... ✓
!---------------------------------------------!
! A newer version of @cplace/asc is available !
! -> Please update to the latest version: !
! npm install -g @cplace/asc !
!---------------------------------------------!
...
For each plugin there must be one main entry file assets/ts/app.ts
which will be used as entry point for bundling. As such any other source file must be imported (transitively) by that file.
If you have additional dependencies to typings files that are placed locally in your plugin you have to include an extra-types.json
file. This file can have the following strucutre:
{
"declarations": [
"relative/path/to/typings/file",
"..."
],
"externals": {
"nameOfImport": "_variableName"
}
}
As you can see you can specify the relative path (taken from the location of the extra-types.json
file) to any typings definitions (.d.ts
) file which will then be taken into account by the TypeScript compiler. Furthermore, in order for Webpack to complete the bundling process you most likely will also have to specify the externals that this typings file provides. These are given in the externals
object. The key must equal to the name of the import in TypeScript (e.g. for import * as myXs from 'xs'
the key would be xs
). The value is equal to the global variable name to be resolved by Webpack.
For each plugin there must be one main entry file: either assets/less/plugin.less
or assets/less/cplace.less
. The generated CSS file will be called assets/generated_css/plugin.css
or assets/generated_css/cplace.css
respectively.
For each plugin there must be one main entry file assets/css/imports.css
which will be used as entry point for combining and compressing CSS code.
X
number of compile processes in parallel where X
equals the number of cores available on the system.main
repository's node_modules
directory.clean-css
compiler is the one located in the main
repository's node_modules
directory.As of version 3.4 the TypeScript compiler supports incremental compilation. As such it tracks which files have to be recompiled due to changes of other source files. However, this does not cover implicit dependencies. See the following example:
types.ts:
export interface IComputationResult {
status: number;
content: string;
}
utils.ts
import { IComputationResult } from './types';
export function computeValue(input: string): IComputationResult {
let result: IComputationResult;
// does some magic
// ...
return result;
}
component.ts
import { computeValue } from './utils';
export function componentLogic(): void {
// does some things...
const result = computeValue('my complex input');
console.log(result.status, result.content);
}
As you can see in the example above, component.ts
has an implicit dependency on types.ts
as it has the result
variable with an inferred type of IComputationResult
. Changing the IComputationResult
, e.g. by renaming content to output
, will not cause a compilation error if the TypeScript compiler is running in watch mode with incremental compilation (default behavior). Only a full recompilation will result in the error to be detected.
In order to mitigate this issue you could use the following workaround by explicitly declaring the type of the variable you store the method result in (IntelliJ provides a quickfix for this: "Specify type explicitly"):
component.ts
import { computeValue } from './utils';
// !! See the new import making the dependency explicit
import { IComputationResult } from './types';
export function componentLogic(): void {
// does some things...
// !! See the explicit variable type
const result: IComputationResult = computeValue('my complex input');
console.log(result.status, result.content);
}
FAQs
cplace assets compiler
We found that @cplace/asc demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.