1
0
mirror of https://github.com/svg/svgo.git synced 2025-04-19 10:22:15 +03:00

ci: add spellcheck (#2101)

This commit is contained in:
Seth Falco 2025-04-12 16:47:32 +01:00 committed by GitHub
parent d06fffbb2d
commit 9c8768f64d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
19 changed files with 125 additions and 34 deletions

13
.github/workflows/spellcheck.yml vendored Normal file
View File

@ -0,0 +1,13 @@
name: Check spelling
on:
pull_request:
jobs:
spellcheck:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: streetsidesoftware/cspell-action@v6
with:
incremental_files_only: true

79
cspell.jsonc Normal file
View File

@ -0,0 +1,79 @@
{
"$schema": "https://raw.githubusercontent.com/streetsidesoftware/cspell/main/cspell.schema.json",
"version": "0.2",
"words": [
"Bézier",
"crosspoint",
"deoptimizations",
"deoptimize",
"deoptimized",
"fontawesome",
"Fontello",
"Fonticons",
"frontends",
"inlines",
"opencollective",
"subpoint",
"subselector",
"xast",
"Xlink",
// Abbreviations
"elems", // elements
"unenc", // unencoded
// SVG Keywords
"currentcolor",
// SVG Nodes / Attributes and CSS Properties, including plurals
"bbox",
"hkern",
"horiz",
"hrefs",
"mpath",
"onbegin",
"onrepeat",
"panose",
"stemh",
"stemv",
"vkern",
// Software
"grunt-svgmin",
"Inkscape",
"SVGOMG",
// NPM Packages
"csstree",
"csswhat",
// Names
"André",
"Baranovskiy",
"Dmitry",
"Keerthi",
],
"ignorePaths": ["*.svg.txt", "*.svg", "cspell.jsonc", "LICENSE"],
"ignoreRegExpList": [
"-moz", // Mozilla Firefox CSS prefix
"'.+?.svg',", // path to file with .svg extension
"(?:xlink|sodipodi)(?::[a-z]+)?", // Common SVG namespaces
"[a-z]+: '#[a-f\\d]+',", // Color names in _collection.js
"[a-z]+…", // Words that have been cut off by an ellipsis
"@author .+", // JSDoc author tag line, usually names
"\"name\": .+", // package.json author name property
"\\*\\*SVG O\\*\\*ptimizer", // README
"\\b[aprs]data\\b",
"&.+?;", // HTML entity
"^svgo .+", // Command-line example of SVGO
"<svg.+>", // Inline SVG in code
"Atrule", // At-rule
"data:image/.+", // Data URI
"datauri", // Data URI
"descs", // Abbreviation of "descriptions"
"ENOCLS|ENOATTRS",
"id=([\"']).+?\\1", // ID attribute of inline SVG
"import .+", // Import statements in Javascript
"newres",
"nums", // Abbreviation of "numbers"
"onwarn", // Rollup API,
"QRAB|QRCD",
"rrggbb",
"sax\\..+", // Any properties of the sax API
"shorthex", // Parameter of convertColors plugin
],
}

View File

@ -16,7 +16,7 @@ svgo:
description: Elements with an ID that starts with one of these prefixes will be ignored.
default: []
force:
description: This plugin normally does nothing if a `<script>` or `<style>` element is found. Setting this to true will bypass that behaviour, which may result in destructive changes.
description: This plugin normally does nothing if a `<script>` or `<style>` element is found. Setting this to true will bypass that behavior, which may result in destructive changes.
default: false
defaultPlugin: true
---

View File

@ -16,7 +16,7 @@ svgo:
description: If to convert curve commands that are effectively straight lines to line commands.
default: true
convertToQ:
description: If to convert cubic beziers to quadratic beziers when they effectively are.
description: If to convert cubic Bézier curves to quadratic Bézier curves when they effectively are.
default: true
lineShorthands:
description: If to convert regular lines to an explicit horizontal or vertical line where possible.
@ -63,7 +63,7 @@ You can get more context on path commands on [MDN Web Docs](https://developer.mo
This plugin uses multiple techniques to either reduce the number of instructions or reduce the attribute length:
- Convert between relative or absolute coordinates, whichever is shortest.
- Convert between commands. For example, a bézier curve that behaves like a straight line might as well use a line instruction.
- Convert between commands. For example, a Bézier curve that behaves like a straight line might as well use a line instruction.
- Remove redundant commands. For example, a command that moves to the current position can be removed.
- Trim redundant delimiters and leading zeros.
- Round numeric values using conventional rounding rules.

View File

@ -11,7 +11,6 @@
* @typedef {import('./types.js').XastChild} XastChild
*/
// @ts-ignore sax will be replaced with something else later
import SAX from 'sax';
import { textElems } from '../plugins/_collections.js';

2
lib/svgo.d.ts vendored
View File

@ -67,7 +67,7 @@ export declare const builtinPlugins: Array<
>;
export type Config = {
/** Can be used by plugins, for example prefixids */
/** Can be used by plugins, for example prefixIds */
path?: string;
/** Pass over SVGs multiple times to ensure all optimizations are applied. */
multipass?: boolean;

View File

@ -1,10 +1,6 @@
import { jest } from '@jest/globals';
import { optimize } from './svgo.js';
/**
* @typedef {import('../lib/types.js').Plugin} Plugin
*/
test('allow to setup default preset', () => {
const svg = `
<?xml version="1.0" encoding="utf-8"?>
@ -353,9 +349,6 @@ test('slices long line in error code snippet', () => {
test('multipass option should trigger plugins multiple times', () => {
const svg = `<svg id="abcdefghijklmnopqrstuvwxyz"></svg>`;
const list = [];
/**
* @type {Plugin<void>}
*/
const testPlugin = {
name: 'testPlugin',
fn: (_root, _params, info) => {

View File

@ -89,7 +89,7 @@ export const cleanupOutData = (data, params, command) => {
// no extra space in front of first number
if (i == 0) delimiter = '';
// no extra space after 'arcto' command flags(large-arc and sweep flags)
// no extra space after arc command flags (large-arc and sweep flags)
// a20 60 45 0 1 30 20 → a20 60 45 0130 20
if (params.noSpaceAfterFlags && (command == 'A' || command == 'a')) {
var pos = i % 7;

View File

@ -2397,7 +2397,7 @@ export const pseudoClasses = {
'disabled',
'enabled',
'in-range',
'indetermined',
'indeterminate',
'invalid',
'optional',
'out-of-range',

View File

@ -564,7 +564,7 @@ function gatherPoints(pathData) {
case 'A':
if (basePoint != null) {
// Convert the arc to bezier curves and use the same approximation
// Convert the arc to zier curves and use the same approximation
// @ts-ignore no idea what's going on here
var curves = a2c.apply(0, basePoint.concat(data));
for (

View File

@ -19,7 +19,7 @@ export const fn = (root, params) => {
enter: (node) => {
for (const name of Object.keys(node.attributes)) {
if (newlines) {
// new line which requires a space instead of themself
// new line which requires a space instead
node.attributes[name] = node.attributes[name].replace(
regNewlinesNeedSpace,
(match, p1, p2) => p1 + ' ' + p2,

View File

@ -1006,8 +1006,8 @@ function convertToMixed(path, params) {
}
/**
* Checks if curve is convex. Control points of such a curve must form
* a convex quadrilateral with diagonals crosspoint inside of it.
* Checks if curve is convex. Control points of such a curve must form a convex
* quadrilateral with diagonals crosspoint inside of it.
*
* @type {(data: number[]) => boolean}
*/

View File

@ -12,9 +12,16 @@ const g = (...args) => {
const stylingProps = attrsGroups.presentation;
const rEscape = '\\\\(?:[0-9a-f]{1,6}\\s?|\\r\\n|.)'; // Like \" or \2051. Code points consume one space.
const rAttr = '\\s*(' + g('[^:;\\\\]', rEscape) + '*?)\\s*'; // attribute name like fill
const rSingleQuotes = "'(?:[^'\\n\\r\\\\]|" + rEscape + ")*?(?:'|$)"; // string in single quotes: 'smth'
const rQuotes = '"(?:[^"\\n\\r\\\\]|' + rEscape + ')*?(?:"|$)'; // string in double quotes: "smth"
/** Pattern to match attribute name like: 'fill' */
const rAttr = '\\s*(' + g('[^:;\\\\]', rEscape) + '*?)\\s*';
/** Pattern to match string in single quotes like: 'foo' */
const rSingleQuotes = "'(?:[^'\\n\\r\\\\]|" + rEscape + ")*?(?:'|$)";
/** Pattern to match string in double quotes like: "foo" */
const rQuotes = '"(?:[^"\\n\\r\\\\]|' + rEscape + ')*?(?:"|$)';
const rQuotedString = new RegExp('^' + g(rSingleQuotes, rQuotes) + '$');
// Parentheses, E.g.: url(...).
// ':' and ';' inside of it should be treated as is. (Just like in strings.)

View File

@ -21,8 +21,8 @@ export const description = 'inline styles (additional options)';
* :future, or :hover, but there are other pseudo-classes that we can evaluate
* during optimization.
*
* The list of pseudo-classes that we can evaluate during optimization, and
* shouldn't be toggled conditionally through the `usePseudos` parameter.
* Pseudo-classes that we can evaluate during optimization, and shouldn't be
* toggled conditionally through the `usePseudos` parameter.
*
* @see https://developer.mozilla.org/docs/Web/CSS/Pseudo-classes
*/

View File

@ -58,7 +58,7 @@ export const fn = (_root, { usage, ...params }) => {
return {
element: {
enter: (node, parentNode) => {
// detect deoptimisations
// detect deoptimizations
if (hasScripts(node)) {
deoptimized = true;
}
@ -115,7 +115,7 @@ export const fn = (_root, { usage, ...params }) => {
}
// preserve cdata if necessary
// TODO split cdata -> text optimisation into separate plugin
// TODO split cdata -> text optimization into separate plugin
if (cssText.indexOf('>') >= 0 || cssText.indexOf('<') >= 0) {
styleNode.children[0].type = 'cdata';
styleNode.children[0].value = minified;

View File

@ -108,13 +108,13 @@ type DefaultPlugins = {
minifyStyles: {
/**
* Disable or enable a structure optimisations.
* Disable or enable a structure optimizations.
* @default true
*/
restructure?: boolean;
/**
* Enables merging of @media rules with the same media query split by other rules.
* The optimisation is unsafe in general, but should work fine in most cases. Use it on your own risk.
* Unsafe in general, but should work fine in most cases. Use it on your own risk.
* @default false
*/
forceMediaMerge?: boolean;

View File

@ -8,10 +8,10 @@ import { intersects } from './_path.js';
export const name = 'removeOffCanvasPaths';
export const description =
'removes elements that are drawn outside of the viewbox (disabled by default)';
'removes elements that are drawn outside of the viewBox (disabled by default)';
/**
* Remove elements that are drawn outside of the viewbox.
* Remove elements that are drawn outside of the viewBox.
*
* @author JoshyPHP
*
@ -35,7 +35,7 @@ export const fn = () => {
enter: (node, parentNode) => {
if (node.name === 'svg' && parentNode.type === 'root') {
let viewBox = '';
// find viewbox
// find viewBox
if (node.attributes.viewBox != null) {
// remove commas and plus signs, normalize and trim whitespace
viewBox = node.attributes.viewBox;
@ -46,7 +46,7 @@ export const fn = () => {
viewBox = `0 0 ${node.attributes.width} ${node.attributes.height}`;
}
// parse viewbox
// parse viewBox
// remove commas and plus signs, normalize and trim whitespace
viewBox = viewBox
.replace(/[,+]|px/g, ' ')

View File

@ -20,7 +20,7 @@ export const fn = (root, params) => {
removeNone = false,
} = params;
// style and script elements deoptimise this plugin
// style and script elements deoptimize this plugin
let hasStyleOrScript = false;
visit(root, {
element: {
@ -40,7 +40,7 @@ export const fn = (root, params) => {
return {
element: {
enter: (node, parentNode) => {
// id attribute deoptimise the whole subtree
// id attribute deoptimize the whole subtree
if (node.attributes.id != null) {
return visitSkip;
}

View File

@ -54,7 +54,7 @@ const findPrefixedAttrs = (node, prefixes, attr) => {
* Removes XLink namespace prefixes and converts references to XLink attributes
* to the native SVG equivalent.
*
* The XLink namespace is deprecated in SVG 2.
* XLink namespace is deprecated in SVG 2.
*
* @type {import('./plugins-types.js').Plugin<'removeXlink'>}
* @see https://developer.mozilla.org/docs/Web/SVG/Attribute/xlink:href