{"id":41824625,"url":"https://github.com/sasjs/lint","last_synced_at":"2026-01-25T08:07:04.338Z","repository":{"id":39285915,"uuid":"347907406","full_name":"sasjs/lint","owner":"sasjs","description":"Linting and formatting for SAS® code","archived":false,"fork":false,"pushed_at":"2025-05-01T08:17:08.000Z","size":700,"stargazers_count":27,"open_issues_count":7,"forks_count":5,"subscribers_count":3,"default_branch":"main","last_synced_at":"2025-08-04T07:54:33.825Z","etag":null,"topics":["formatting","lint","sas","sasjs","viya"],"latest_commit_sha":null,"homepage":"https://sasjs.io","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/sasjs.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2021-03-15T09:25:56.000Z","updated_at":"2025-03-30T15:07:55.000Z","dependencies_parsed_at":"2025-02-14T10:34:13.714Z","dependency_job_id":null,"html_url":"https://github.com/sasjs/lint","commit_stats":{"total_commits":204,"total_committers":10,"mean_commits":20.4,"dds":0.7254901960784313,"last_synced_commit":"8badfd9358d3374d1c5d34183769a252a7c898bc"},"previous_names":[],"tags_count":42,"template":false,"template_full_name":null,"purl":"pkg:github/sasjs/lint","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sasjs%2Flint","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sasjs%2Flint/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sasjs%2Flint/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sasjs%2Flint/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/sasjs","download_url":"https://codeload.github.com/sasjs/lint/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sasjs%2Flint/sbom","scorecard":{"id":801220,"data":{"date":"2025-08-11","repo":{"name":"github.com/sasjs/lint","commit":"6172b3a64125db6995509d4e5102f2c41b9e4294"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":4.2,"checks":[{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":4,"reason":"Found 5/11 approved changesets -- score normalized to 4","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/assign-reviewer.yml:1","Warn: no topLevel permission defined: .github/workflows/build.yml:1","Warn: no topLevel permission defined: .github/workflows/publish.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Pinned-Dependencies","score":3,"reason":"dependency not pinned by hash detected -- score normalized to 3","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/assign-reviewer.yml:10: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/assign-reviewer.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/assign-reviewer.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/assign-reviewer.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/publish.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/sasjs/lint/publish.yml/main?enable=pin","Warn: npmCommand not pinned by hash: .github/workflows/build.yml:33","Warn: npmCommand not pinned by hash: .github/workflows/publish.yml:23","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   2 third-party GitHubAction dependencies pinned","Info:   2 out of   4 npmCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 27 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":8,"reason":"2 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-968p-4wvh-cqc8","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-23T10:32:34.836Z","repository_id":39285915,"created_at":"2025-08-23T10:32:34.836Z","updated_at":"2025-08-23T10:32:34.836Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28748573,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-25T07:58:02.558Z","status":"ssl_error","status_checked_at":"2026-01-25T07:57:57.153Z","response_time":113,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["formatting","lint","sas","sasjs","viya"],"created_at":"2026-01-25T08:07:03.630Z","updated_at":"2026-01-25T08:07:04.330Z","avatar_url":"https://github.com/sasjs.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"![GitHub top language](https://img.shields.io/github/languages/top/sasjs/lint)\n[![GitHub closed issues](https://img.shields.io/github/issues-closed-raw/sasjs/lint)](https://github.com/sasjs/lint/issues?q=is%3Aissue+is%3Aclosed)\n[![GitHub issues](https://img.shields.io/github/issues-raw/sasjs/lint)](https://github.com/sasjs/lint/issues)\n![total lines](https://tokei.rs/b1/github/sasjs/lint)\n[![Gitpod ready-to-code](https://img.shields.io/badge/Gitpod-ready--to--code-908a85?logo=gitpod)](https://gitpod.io/#https://github.com/sasjs/lint)\n\n# SAS Code linting and formatting\n\nOur goal is to help SAS developers everywhere spend less time on code reviews, bug fixing and arguing about standards - and more time delivering extraordinary business value.\n\n*Note:* The SASjs project and its repositories are not affiliated with SAS Institute.\n\n# Linting\n\n@sasjs/lint is used by the following products:\n\n- [@sasjs/vscode-extension](https://github.com/sasjs/vscode-extension) - just download SASjs in the VSCode marketplace, and select view/problems in the menu bar.\n- [@sasjs/cli](https://cli.sasjs.io/lint) - run `sasjs lint` to get a list of all files with their problems, along with line and column indexes.\n\nConfiguration is via a `.sasjslint` file with the following structure (these are also the defaults if no .sasjslint file is found):\n\n```json\n{\n  \"hasDoxygenHeader\": true,\n  \"hasMacroNameInMend\": true,\n  \"hasMacroParentheses\": true,\n  \"hasRequiredMacroOptions\": false,\n  \"requiredMacroOptions\": [\"SECURE\", \"SRC\"],\n  \"ignoreList\": [\"sasjsbuild/\", \"sasjsresults/\"],\n  \"indentationMultiple\": 2,\n  \"lineEndings\": \"off\",\n  \"lowerCaseFileNames\": true,\n  \"maxDataLineLength\": 80,\n  \"maxHeaderLineLength\": 80,\n  \"maxLineLength\": 80,\n  \"noEncodedPasswords\": true,\n  \"noNestedMacros\": true,\n  \"noGremlins\": true,\n  \"noSpacesInFileNames\": true,\n  \"noTabs\": true,\n  \"noTrailingSpaces\": true,\n  \"defaultHeader\": \"/**{lineEnding}  @file{lineEnding}  @brief \u003cYour brief here\u003e{lineEnding}  \u003ch4\u003e SAS Macros \u003c/h4\u003e{lineEnding}**/\"\n}\n```\n\n## SAS Lint Settings\n\nEach setting can have three states:\n\n- OFF - usually by setting the value to `false` or 0. In this case, the rule won't be executed.\n- WARN - a warning is written to the log, but the return code will be 0\n- ERROR - an error is written to the log, and the return code is 1\n\nFor more details, and the default state, see the description of each rule below. It is also possible to change whether a rule returns ERROR or WARN using the `severityLevels` object.\n\nConfiguring a non-zero return code (ERROR) is helpful when running `sasjs lint` as part of a git pre-commit hook.  An example is available [here](https://github.com/sasjs/template_jobs/blob/main/.git-hooks/pre-commit).\n\n### allowedGremlins\n\nAn array of hex codes that represents allowed gremlins (invisible / undesirable characters). To allow all gremlins, you can also set the `noGremlins` rule to `false`.  The full gremlin list is [here](https://github.com/sasjs/lint/blob/main/src/utils/gremlinCharacters.ts).\n\nExample:\n\n```json\n{\n  \"noGremlins\": true,\n  \"allowedGremlins\": [\"0x0080\", \"0x3000\"]\n}\n```\n\n### defaultHeader\n\nThis isn't a rule, but a formatting setting, which applies to SAS program that do NOT begin with `/**`. It can be triggered by running `sasjs lint fix` in the SASjs CLI, or by hitting \"save\" when using the SASjs VS Code extension (with \"formatOnSave\" in place)\n\nThe default header is as follows:\n\n```sas\n/**\n  @file\n  @brief \u003cYour brief here\u003e\n  \u003ch4\u003e SAS Macros \u003c/h4\u003e\n**/\n```\n\nIf creating a new value, use `{lineEnding}` instead of `\\n`, eg as follows:\n\n```json\n{\n  \"defaultHeader\": \"/**{lineEnding}  @file{lineEnding}  @brief Our Company Brief{lineEnding}**/\"\n}\n```\n\n### hasDoxygenHeader\n\nThe SASjs framework recommends the use of Doxygen headers for describing all types of SAS program. This check will identify files where a doxygen header does not begin in the first line.\n\n- Default: true\n- Severity: WARNING\n\n### hasMacroNameInMend\n\nThe addition of the macro name in the `%mend` statement is optional, but can approve readability in large programs. A discussion on this topic can be found [here](https://www.linkedin.com/posts/allanbowe_sas-sasapps-sasjs-activity-6783413360781266945-1-7m). The default setting was the result of a poll with over 300 votes.\n\n- Default: true\n- Severity: WARNING\n\n### hasMacroParentheses\n\nAs per the example [here](https://github.com/sasjs/lint/issues/20), macros defined without parentheses cause problems if that macro is ever extended (it's not possible to reliably extend that macro without potentially breaking some code that has used the macro). It's better to always define parentheses, even if they are not used. This check will also throw a warning if there are spaces between the macro name and the opening parenthesis.\n\n- Default: true\n- Severity: WARNING\n\n### hasRequiredMacroOptions\n\nThis will require macros to have the options listed as \"requiredMacroOptions.\" This is helpful if you want to ensure all macros are SECURE.\n\n- Default: false\n- severity: WARNING\n\nExample\n```json\n{\n  \"hasRequiredMacroOptions\": true,\n  \"requiredMacroOptions\": [\"SECURE\", \"SRC\"]\n}\n```\n\n### ignoreList\n\nThere may be specific files (or folders) that are not good candidates for linting. Simply list them in this array and they will be ignored. In addition, any files in the project `.gitignore` file will also be ignored.\n\n### indentationMultiple\n\nThis will check each line to ensure that the count of leading spaces can be divided cleanly by this multiple.\n\n- Default: 2\n- Severity: WARNING\n\n### lineEndings\n\nThis setting ensures the line endings in a file to conform the configured type. Possible values are `lf`, `crlf` and `off` (off means rule is set to be off). If the value is missing, null or undefined then the check would also be switched off (no default applied).\n\n- Default: \"off\"\n- Severity: WARNING\n\nExample (to enforce unix line endings):\n\n```json\n{\n  \"lineEndings\": \"lf\"\n}\n```\n\n### lowerCaseFileNames\n\nOn *nix systems, it is imperative that autocall macros are in lowercase. When sharing code between windows and *nix systems, the difference in case sensitivity can also be a cause of lost developer time. For this reason, we recommend that sas filenames are always lowercase.\n\n- Default: true\n- Severity: WARNING\n\n### maxDataLineLength\n\nDatalines can be very wide, so to avoid the need to increase `maxLineLength` for the entire project, it is possible to raise the line length limit for the data records only. On a related note, as a developer, you should also be aware that code submitted in batch may have a default line length limit which is lower than you expect. See this [usage note](https://support.sas.com/kb/15/883.html) (and thanks to [sasutils for reminding us](https://github.com/sasjs/lint/issues/47#issuecomment-1064340104)).\n\nThis feature will work for the following statements:\n\n- cards\n- cards4\n- datalines\n- datalines4\n- parmcards\n- parmcards4\n\nThe `maxDataLineLength` setting is always the _higher_ of `maxDataLineLength` and `maxLineLength` (if you set a lower number, it is ignored).\n\n- Default: 80\n- Severity: WARNING\n\nSee also:\n\n- [hasDoxygenHeader](#hasdoxygenheader)\n- [maxHeaderLineLength](#maxheaderlinelength)\n- [maxLineLength](#maxlinelength)\n\n### maxHeaderLineLength\n\nIn a program header it can be necessary to insert items such as URLs or markdown tables, that cannot be split over multiple lines. To avoid the need to increase `maxLineLength` for the entire project, it is possible to raise the line length limit for the header section only.\n\nThe `maxHeaderLineLength` setting is always the _higher_ of `maxHeaderLineLength` and `maxLineLength` (if you set a lower number, it is ignored).\n\n- Default: 80\n- Severity: WARNING\n\nSee also:\n\n- [hasDoxygenHeader](#hasdoxygenheader)\n- [maxDataLineLength](#maxdatalinelength)\n- [maxLineLength](#maxlinelength)\n\n### maxLineLength\n\nCode becomes far more readable when line lengths are short. The most compelling reason for short line lengths is to avoid the need to scroll when performing a side-by-side 'compare' between two files (eg as part of a GIT feature branch review). A longer discussion on optimal code line length can be found [here](https://stackoverflow.com/questions/578059/studies-on-optimal-code-width)\n\nIn batch mode, long SAS code lines may also be truncated, causing hard-to-detect errors.\n\nWe strongly recommend a line length limit, and set the bar at 80. To turn this feature off, set the value to 0.\n\n- Default: 80\n- Severity: WARNING\n\nSee also:\n\n- [maxDataLineLength](#maxdatalinelength)\n- [maxHeaderLineLength](#maxheaderlinelength)\n\n### noEncodedPasswords\n\nThis rule will highlight any rows that contain a `{sas00X}` type password, or `{sasenc}`. These passwords (especially 001 and 002) are NOT secure, and should NEVER be pushed to source control or saved to the filesystem without special permissions applied.\n\n- Default: true\n- Severity: ERROR\n\n### noGremlins\n\nCapture zero-width whitespace and other non-standard characters. The logic is borrowed from the [VSCode Gremlins Extension](https://github.com/nhoizey/vscode-gremlins) - if you are looking for more advanced gremlin zapping capabilities, we highly recommend to use their extension instead.\n\nThe list of characters can be found in this file: [https://github.com/sasjs/lint/blob/main/src/utils/gremlinCharacters.ts](https://github.com/sasjs/lint/blob/main/src/utils/gremlinCharacters.ts)\n\n- Default: true\n- Severity: WARNING\n\n### noNestedMacros\n\nWhere macros are defined inside other macros, they are recompiled every time the outer macro is invoked. Hence, it is widely considered inefficient, and bad practice, to nest macro definitions.\n\n- Default: true\n- Severity: WARNING\n\n### noSpacesInFileNames\n\nThe 'beef' we have with spaces in filenames is twofold:\n\n- Loss of the in-built ability to 'click' a filepath and have the file open automatically\n- The need to quote such filepaths in order to use them in CLI commands\n\nIn addition, when such files are used in URLs, they are often padded with a messy \"%20\" type quotation. And of course, for macros (where the macro should match the filename) then spaces are simply not valid.\n\n- Default: true\n- Severity: WARNING\n\nAs an alternative (or in addition) to using a lint rule, you can also set the following in your `.gitignore` file to prevent files with spaces from being committed:\n\n```\n# prevent files/folders with spaces\n**\\ **\n```\n\n### noTabs\n\nWhilst there are some arguments for using tabs (such as the ability to set your own indentation width, and to reduce character count) there are many, many, many developers who think otherwise. We're in that camp. Sorry (not sorry).\n\n- Alias: noTabIndentation\n- Default: true\n- Severity: WARNING\n\n### noTrailingSpaces\n\nThis will highlight lines with trailing spaces. Trailing spaces serve no useful purpose in a SAS program.\n\n- Default: true\n- severity: WARNING\n\n\n## severityLevel\n\nThis setting allows the default severity to be adjusted. This is helpful when running the lint in a pipeline or git hook. Simply list the rules you would like to adjust along with the desired setting (\"warn\" or \"error\"), eg as follows:\n\n```json\n{\n  \"noTrailingSpaces\": true,\n  \"hasDoxygenHeader\": true,\n  \"maxLineLength\": 100,\n  \"severityLevel\": {\n    \"hasDoxygenHeader\": \"warn\",\n    \"maxLineLength\": \"error\",\n    \"noTrailingSpaces\": \"error\"\n  }\n}\n```\n\n- \"warn\" - show warning in the log (doesn’t affect exit code)\n- \"error\" - show error in the log (exit code is 1 when triggered)\n\n# SAS Formatter\n\nA formatter will automatically apply rules when you hit SAVE, which can save a LOT of time.\n\nWe've already implemented the following rules:\n\n- Add the macro name to the %mend statement\n- Add a doxygen header template if none exists\n- Remove trailing spaces\n\nWe're looking to implement the following rules:\n\n- Change tabs to spaces\n- zap gremlins\n- fix line endings\n\nWe are also investigating some harder stuff, such as automatic indentation and code layout\n\n# Further resources\n\n* Using the linter on terminal: https://vid.4gl.io/w/vmJspCjcBoc5QtzwZkZRvi\n* Longer intro to sasjs lint: https://vid.4gl.io/w/nDtkQFV1E8rtaa2BuM6U5s\n* CLI docs:  https://cli.sasjs.io/lint\n\n# Sponsorship \u0026 Contributions\n\nSASjs is an open source framework! Contributions are welcomed. If you would like to see a feature, because it would be useful in your project, but you don't have the requisite (Typescript) experience - then how about you engage us on a short project and we build it for you?\n\nContact [Allan Bowe](https://www.linkedin.com/in/allanbowe/) for further details.\n\n# Contributors ✨\n\n\u003c!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --\u003e\n[![All Contributors](https://img.shields.io/badge/all_contributors-9-orange.svg?style=flat-square)](#contributors-)\n\u003c!-- ALL-CONTRIBUTORS-BADGE:END --\u003e\n\nThanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):\n\n\u003c!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --\u003e\n\u003c!-- prettier-ignore-start --\u003e\n\u003c!-- markdownlint-disable --\u003e\n\u003ctable\u003e\n  \u003ctbody\u003e\n    \u003ctr\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/Carus11\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/4925828?v=4?s=100\" width=\"100px;\" alt=\"Carus Kyle\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eCarus Kyle\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"#ideas-Carus11\" title=\"Ideas, Planning, \u0026 Feedback\"\u003e🤔\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/allanbowe\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/4420615?v=4?s=100\" width=\"100px;\" alt=\"Allan Bowe\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eAllan Bowe\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=allanbowe\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=allanbowe\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3Aallanbowe\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e \u003ca href=\"#video-allanbowe\" title=\"Videos\"\u003e📹\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=allanbowe\" title=\"Documentation\"\u003e📖\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://www.erudicat.com/\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/25773492?v=4?s=100\" width=\"100px;\" alt=\"Yury Shkoda\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eYury Shkoda\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=YuryShkoda\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=YuryShkoda\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"#projectManagement-YuryShkoda\" title=\"Project Management\"\u003e📆\u003c/a\u003e \u003ca href=\"#video-YuryShkoda\" title=\"Videos\"\u003e📹\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=YuryShkoda\" title=\"Documentation\"\u003e📖\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://krishna-acondy.io/\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/2980428?v=4?s=100\" width=\"100px;\" alt=\"Krishna Acondy\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eKrishna Acondy\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=krishna-acondy\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=krishna-acondy\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3Akrishna-acondy\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e \u003ca href=\"#infra-krishna-acondy\" title=\"Infrastructure (Hosting, Build-Tools, etc)\"\u003e🚇\u003c/a\u003e \u003ca href=\"#platform-krishna-acondy\" title=\"Packaging/porting to new platform\"\u003e📦\u003c/a\u003e \u003ca href=\"#maintenance-krishna-acondy\" title=\"Maintenance\"\u003e🚧\u003c/a\u003e \u003ca href=\"#content-krishna-acondy\" title=\"Content\"\u003e🖋\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/saadjutt01\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/8914650?v=4?s=100\" width=\"100px;\" alt=\"Muhammad Saad \"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eMuhammad Saad \u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=saadjutt01\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=saadjutt01\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3Asaadjutt01\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e \u003ca href=\"#mentoring-saadjutt01\" title=\"Mentoring\"\u003e🧑‍🏫\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=saadjutt01\" title=\"Documentation\"\u003e📖\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/sabhas\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/82647447?v=4?s=100\" width=\"100px;\" alt=\"Sabir Hassan\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eSabir Hassan\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=sabhas\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=sabhas\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3Asabhas\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e \u003ca href=\"#ideas-sabhas\" title=\"Ideas, Planning, \u0026 Feedback\"\u003e🤔\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/medjedovicm\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/18329105?v=4?s=100\" width=\"100px;\" alt=\"Mihajlo Medjedovic\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eMihajlo Medjedovic\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=medjedovicm\" title=\"Code\"\u003e💻\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/commits?author=medjedovicm\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3Amedjedovicm\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e \u003ca href=\"#infra-medjedovicm\" title=\"Infrastructure (Hosting, Build-Tools, etc)\"\u003e🚇\u003c/a\u003e\u003c/td\u003e\n    \u003c/tr\u003e\n    \u003ctr\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/VladislavParhomchik\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/83717836?v=4?s=100\" width=\"100px;\" alt=\"Vladislav Parhomchik\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eVladislav Parhomchik\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=VladislavParhomchik\" title=\"Tests\"\u003e⚠️\u003c/a\u003e \u003ca href=\"https://github.com/sasjs/lint/pulls?q=is%3Apr+reviewed-by%3AVladislavParhomchik\" title=\"Reviewed Pull Requests\"\u003e👀\u003c/a\u003e\u003c/td\u003e\n      \u003ctd align=\"center\" valign=\"top\" width=\"14.28%\"\u003e\u003ca href=\"https://github.com/McGwire-Jones\"\u003e\u003cimg src=\"https://avatars.githubusercontent.com/u/51411005?v=4?s=100\" width=\"100px;\" alt=\"McGwire-Jones\"/\u003e\u003cbr /\u003e\u003csub\u003e\u003cb\u003eMcGwire-Jones\u003c/b\u003e\u003c/sub\u003e\u003c/a\u003e\u003cbr /\u003e\u003ca href=\"https://github.com/sasjs/lint/commits?author=McGwire-Jones\" title=\"Code\"\u003e💻\u003c/a\u003e\u003c/td\u003e\n    \u003c/tr\u003e\n  \u003c/tbody\u003e\n\u003c/table\u003e\n\n\u003c!-- markdownlint-restore --\u003e\n\u003c!-- prettier-ignore-end --\u003e\n\n\u003c!-- ALL-CONTRIBUTORS-LIST:END --\u003e\n\nThis project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsasjs%2Flint","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsasjs%2Flint","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsasjs%2Flint/lists"}