Guarding is a guardians for code, architecture, layered. Using git hooks and DSL for design guard rules.
Inspired by ArchUnit
- install
cargo install guarding
- create
guarding.guarding
file
package(".")::file.len should < 200;
package(".")::file.len should > 50;
- run
guarding .
guarding_adapter
, FFI adapter, provide Guarding api,guarding_core
, core guarding model,guarding_ident
, identify different language: Java, JavaScript, Rustguarding_parser
parsing Guarding DSL
workflow:
- parsing guarding rules
- parsing source code to models
- capture rule with models
DSL capture logic:
- filter models from
rule_level
withrule_scope
- run expression
- run assert
Queries Samples: https://github.com/nvim-treesitter/nvim-treesitter/tree/master/queries
for packages:
class(implementation "BaseParser")::name should endsWith "Parser";
class("java.util.Map") only accessed(["com.phodal.pepper.refactor.staticclass"]);
class(implementation "BaseParser")::name should not contains "Lexer";
for Java, JavaScript
# 类::名 包含 "Controller";
# 中文分词:("..myapp..") 类名称中包含 "Controller"
class("..myapp..")::function.name should contains("Model");
# or
class("..myapp..")::function.name contains("");
for Rust and Golang
struct("..myapp..")::function.name should contains("Model");
# or
struct("..myapp..")::function.name contains("");
This code is distributed under the MIT license. See LICENSE
in this directory.