diff --git a/crates/sema/src/ast_passes.rs b/crates/sema/src/ast_passes.rs index 58e77ac8..a1073462 100644 --- a/crates/sema/src/ast_passes.rs +++ b/crates/sema/src/ast_passes.rs @@ -220,6 +220,23 @@ impl<'ast> Visit<'ast> for AstValidator<'_, 'ast> { contract: &'ast ast::ItemContract<'ast>, ) -> ControlFlow { self.contract = Some(contract); + + if contract.kind.is_library() { + if !contract.bases.is_empty() { + self.dcx().err("library is not allowed to inherit").span(contract.name.span).emit(); + } + for item in contract.body.iter() { + if let ast::ItemKind::Variable(var) = &item.kind { + if !var.mutability.is_some_and(|m| m == ast::VarMut::Constant) { + self.dcx() + .err("library cannot have non-constant state variable") + .span(var.span) + .emit(); + } + } + } + } + let r = self.walk_item_contract(contract); self.contract = None; r diff --git a/tests/ui/resolve/library_requirements.sol b/tests/ui/resolve/library_requirements.sol new file mode 100644 index 00000000..c532c28a --- /dev/null +++ b/tests/ui/resolve/library_requirements.sol @@ -0,0 +1,8 @@ +library A{} + +library B is A {} //~ERROR: library is not allowed to inherit + +library C { + uint256 constant x = 1; + uint256 y; //~ERROR: library cannot have non-constant state variable +} diff --git a/tests/ui/resolve/library_requirements.stderr b/tests/ui/resolve/library_requirements.stderr new file mode 100644 index 00000000..4f100428 --- /dev/null +++ b/tests/ui/resolve/library_requirements.stderr @@ -0,0 +1,16 @@ +error: library is not allowed to inherit + --> ROOT/tests/ui/resolve/library_requirements.sol:LL:CC + | +LL | library B is A {} + | ^ + | + +error: library cannot have non-constant state variable + --> ROOT/tests/ui/resolve/library_requirements.sol:LL:CC + | +LL | uint256 y; + | ^^^^^^^^^^ + | + +error: aborting due to 2 previous errors +