A Crystal shard that implements the bracket pattern for safe resource management. This pattern ensures that resources are properly initialized and cleaned up, similar to Python's context managers or Haskell's bracket pattern.
-
Add the dependency to your
shard.yml
:dependencies: bracket: github: wizzardx/bracket
-
Run
shards install
require "bracket"
# Simple example with a string resource
setup = -> { "my resource" }
teardown = ->(resource : String) { puts "Cleaning up #{resource}"; nil }
Bracket.with_resource(setup, teardown) do |resource|
puts "Using #{resource}"
end
# Example with server resource
server_setup = -> {
port = find_available_port
server = start_server(port)
{server, port}
}
server_teardown = ->(resource : Tuple(Server, Int32)) {
server, port = resource
server.stop
nil
}
Bracket.with_resource(server_setup, server_teardown) do |resource|
server, port = resource
# Use server...
end
- Guarantees resource cleanup even if an exception occurs
- Type-safe resource handling
- Simple, functional interface
- Works with any resource type
Run tests:
crystal spec
- Fork it (https://github.com/wizzardx/bracket/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- David Purdy - creator and maintainer