Skip to content

Commit

Permalink
Add custom validator for comma errors #141
Browse files Browse the repository at this point in the history
  • Loading branch information
ronilaukkarinen committed Nov 10, 2024
1 parent f19d221 commit 72d3793
Show file tree
Hide file tree
Showing 7 changed files with 59 additions and 26 deletions.
10 changes: 2 additions & 8 deletions .github/workflows/styles.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,17 +33,11 @@ jobs:
@ronilaukkarinen/stylelint-a11y@^1.2.7 \
@ronilaukkarinen/stylelint-declaration-strict-value@^1.9.2 \
@ronilaukkarinen/stylelint-value-no-unknown-custom-properties@^4.0.1 \
[email protected] \
postcss-cli@^10.1.0 \
postcss-safe-parser@^6.0.0
[email protected]
- name: Run stylelint
run: |
npx stylelint *.css --max-warnings 0 --config .stylelintrc
- name: Validate CSS syntax
run: |
for file in *.css; do
echo "Validating $file"
npx postcss "$file" --parser postcss-safe-parser
done
run: node validate-css.js
32 changes: 20 additions & 12 deletions .stylelintrc
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,16 @@
"defaultSeverity": "warning",
"plugins": [
"@ronilaukkarinen/stylelint-value-no-unknown-custom-properties",
"stylelint-order"
"stylelint-order",
"stylelint-csstree-validator"
],
"extends": [
"stylelint-config-standard"
"stylelint-config-standard",
"stylelint-config-recommended"
],
"rules": {
"csstree/validator": true,
"declaration-block-single-line-max-declarations": 1,
"order/order": [
{
"type": "at-rule",
Expand Down Expand Up @@ -47,21 +51,14 @@
"declaration-empty-line-before": null,
"font-family-no-missing-generic-family-keyword": true,
"font-family-name-quotes": "always-where-required",
"at-rule-no-unknown": null,
"no-invalid-position-at-import-rule": null,
"declaration-no-important": true,
"comment-empty-line-before": null,
"function-url-quotes": "always",
"unit-no-unknown": true,
"property-no-unknown": true,
"no-duplicate-selectors": true,
"length-zero-no-unit": null,
"font-weight-notation": "numeric",
"number-max-precision": null,
"number-leading-zero": null,
"string-quotes": null,
"max-line-length": null,
"max-empty-lines": null,
"selector-class-pattern": null,
"selector-max-class": 7,
"selector-max-combinators": 7,
Expand All @@ -71,10 +68,8 @@
"property-no-vendor-prefix": true,
"selector-no-vendor-prefix": true,
"selector-no-qualifying-type": null,
"declaration-block-no-duplicate-properties": true,
"no-unknown-animations": true,
"shorthand-property-no-redundant-values": true,
"declaration-block-single-line-max-declarations": 1,
"value-keyword-case": null,
"csstools/value-no-unknown-custom-properties": [
true,
Expand Down Expand Up @@ -140,6 +135,19 @@
"property-disallowed-list": [
"font",
"background"
]
],
"declaration-block-no-duplicate-properties": true,
"declaration-block-no-shorthand-property-overrides": true,
"property-no-unknown": true,
"selector-pseudo-class-no-unknown": true,
"selector-pseudo-element-no-unknown": true,
"selector-type-no-unknown": true,
"media-feature-name-no-unknown": true,
"at-rule-no-unknown": true,
"comment-no-empty": true,
"no-duplicate-selectors": true,
"no-empty-source": true,
"no-invalid-double-slash-comments": true,
"no-irregular-whitespace": true
}
}
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
### 2.0.5rc: 2024-11-10

* Add unit test to test for CSS syntax errors #141
* Add custom validator for comma errors #141

### 2.0.4: 2024-10-18

Expand Down
1 change: 0 additions & 1 deletion layout-multiple-columns.css
Original file line number Diff line number Diff line change
Expand Up @@ -4043,7 +4043,6 @@ body.embed .entry .detailed-status {
/* Threaded line, actually */
.layout-multiple-columns .status__line {
border-inline-start: 2px solid var(--color-thread-line);
-webkit-border-start: 2px solid var(--color-thread-line);
}

.layout-multiple-columns .status__line--full::before {
Expand Down
1 change: 0 additions & 1 deletion layout-single-column.css
Original file line number Diff line number Diff line change
Expand Up @@ -4347,7 +4347,6 @@ body.embed .entry .detailed-status {
/* Threaded line, actually */
.layout-single-column .status__line {
border-inline-start: 2px solid var(--color-thread-line);
-webkit-border-start: 2px solid var(--color-thread-line);
}

.layout-single-column .status__line--full::before {
Expand Down
12 changes: 8 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,13 @@
"@ronilaukkarinen/stylelint-a11y": "^1.2.7",
"@ronilaukkarinen/stylelint-declaration-strict-value": "^1.9.2",
"@ronilaukkarinen/stylelint-value-no-unknown-custom-properties": "^4.0.1",
"postcss": "^8.4.21",
"stylelint": "^15.2.0",
"postcss": "^8.4.47",
"postcss-cli": "^11.0.0",
"stylelint": "^15.11.0",
"stylelint-config-recommended": "^14.0.1",
"stylelint-config-standard": "^30.0.1",
"stylelint-csstree-validator": "^3.0.0",
"stylelint-order": "^6.0.3"
}
}
},
"dependencies": {}
}
28 changes: 28 additions & 0 deletions validate-css.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
// Custom script to validate CSS syntax by Rolle
// https://github.com/stylelint/stylelint/issues/3053
const fs = require('fs');
const path = require('path');

const cssFiles = fs.readdirSync('.').filter(file => file.endsWith('.css'));
let errorFound = false;

cssFiles.forEach(file => {
const lines = fs.readFileSync(file, 'utf8').split('\n');
lines.forEach((line, index) => {
// Check if the line ends with a comma and the next line starts with "{"
const trimmedLine = line.trim();
const nextLine = lines[index + 1] ? lines[index + 1].trim() : '';
if (trimmedLine.endsWith(',') && nextLine.startsWith('{')) {
errorFound = true;
console.error(`❌ Trailing comma error in file ${file} on line ${index + 1}`);
}
});
});

if (!errorFound) {
console.log('✅ No trailing comma errors found. CSS validation passed.');
process.exit(0);
} else {
console.error('❌ CSS validation failed due to trailing commas.');
process.exit(1);
}

0 comments on commit 72d3793

Please sign in to comment.