Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Philogy/safeconsole
https://github.com/Philogy/safeconsole
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/Philogy/safeconsole
- Owner: Philogy
- License: mit
- Created: 2023-04-03T14:57:55.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-05-12T09:37:07.000Z (over 1 year ago)
- Last Synced: 2024-05-19T05:50:37.722Z (8 months ago)
- Language: Solidity
- Size: 64.5 KB
- Stars: 50
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-foundry - Foundry Safer Log - The safelog library provides a foundry/hardhat like console logging interface whereby the individual log functions do not modify the state of memory. (Templates & Libraries)
README
# Foundry Memory-Preserving Logging Library
The [`safeconsole`](src/safeconsole.sol) library provides a foundry/hardhat-like console logging interface whereby
the individual `log` functions **do not** modify the state of memory. This is important for
debugging low-level assembly that may touch on and rely on the free memory pointer and the
consistent state of memory beyond the free memory pointer. To ensure that the Solidity compiler does
not allocate any memory unexpectedly the `safeconsole.log` functions accept `bytes32` arguments instead
of `string`s as they are kept on the stack. This means that the string part of log messages will
have to be resricted to 32-character chunks.**`logMemory`**
Besides the standard logging functions that can take various combinations of up to 4 `bytes32`,
`bool`, `address` and `uint256` arguments `safeconsole` also has a `logMemory(uint256 offset, uint256 length)`
function that allows you to log a chunk of memory without modifying the state of memory:```solidity
assembly {
mstore(0x00, 1)
mstore(0x20, 2)
}
safeconsole.logMemory(0x00, 0x40);// > 0x00000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000002
```## Installation
### Foundry
1. Install the library
```
forge install philogy/safeconsole --no-commit
```2. Just import the lib and use:
**Example:**
```solidity
import {safeconsole} from "safeconsole/safeconsole.sol";// Some example uses
safeconsole.log("My number: %d", 34);
safeconsole.log("Caller: %s", msg.sender);
safeconsole.log("Where in loop %d-%d", i, j);
```### Hardhat
1. Install Foundry (I mean come on it's 2023)
2. Check Foundry installation instructions### Truffle
Lmao ngmi. (Jk just install Hardhat and then check Hardhat installation instructions)
## Caveats
- certain `safeconsole.log` functions will increase `msize`, no function will modify `msize` if it's
already larger than `0x1a0`
- `safeconsole.log` will treat all `bytes32` arguments as strings and truncate them at their first `0x00`-byte (.e.g `hex"6162630064"` will result in the string `"abc"` of length 3)
- `safeconsole.logMemory` will increase `msize` if the `offset` argument is below `0x60`