🧪 Skills
Solidity LSP
Solidity language server providing smart contract development support including compilation, linting, security analysis, and code intelligence for .sol files. Use when working with Ethereum smart cont
v1.0.0
Description
name: solidity-lsp description: Solidity language server providing smart contract development support including compilation, linting, security analysis, and code intelligence for .sol files. Use when working with Ethereum smart contracts, Substrate pallets, or any Solidity code that needs compilation, security checks, gas optimization, or code navigation. Essential for ClawChain pallet development.
Solidity LSP
Solidity language server integration providing comprehensive smart contract development support through solc (Solidity compiler) and solhint (linter).
Capabilities
- Compilation: Compile Solidity smart contracts with solc
- Linting: Static analysis with solhint for best practices and security
- Security: Detect common vulnerabilities (reentrancy, overflow, etc.)
- Gas optimization: Identify expensive operations
- Code intelligence: Syntax highlighting, error detection
- Supported extensions:
.sol
Installation
Install Solidity compiler and linter:
# Solidity compiler
npm install -g solc
# Solidity linter
npm install -g solhint
Verify installation:
solcjs --version
solhint --version
Usage
Compile Solidity Contract
solcjs --bin --abi contract.sol
Compile with optimization:
solcjs --optimize --bin --abi contract.sol
Lint Contract
Run solhint on a file:
solhint contracts/MyContract.sol
Run on entire project:
solhint 'contracts/**/*.sol'
Security Analysis
solhint includes security rules by default. For advanced security analysis, consider:
# Install slither (requires Python)
pip3 install slither-analyzer
# Run security analysis
slither contracts/
Configuration
solhint Configuration
Create .solhint.json in project root:
{
"extends": "solhint:recommended",
"rules": {
"compiler-version": ["error", "^0.8.0"],
"func-visibility": ["warn", {"ignoreConstructors": true}],
"max-line-length": ["warn", 120],
"not-rely-on-time": "warn",
"avoid-low-level-calls": "warn",
"no-inline-assembly": "warn"
}
}
Hardhat/Foundry Integration
For full development environments, see references/frameworks.md.
Integration Pattern
When developing smart contracts:
- Write: Edit Solidity code
- Lint: Run
solhintto catch issues early - Compile: Use
solcjsto verify compilation - Analyze: Run security tools before deployment
- Test: Write comprehensive unit tests
Common Issues
- Compiler version mismatch: Specify pragma version in contract
- Gas optimization: Use
view/purewhere possible - Security: Never use
tx.originfor authentication - Best practices: Follow Checks-Effects-Interactions pattern
More Information
- Solidity Documentation
- Solhint GitHub
- Solidity Security Best Practices
- See
references/frameworks.mdfor Hardhat/Foundry setup
Reviews (0)
Sign in to write a review.
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!