Don't use tap so return value is that of `yield`

This commit is contained in:
Ary Borenszweig 2016-06-29 16:54:16 -03:00
parent 72431bb1d8
commit 038ffef33a
3 changed files with 12 additions and 23 deletions

View File

@ -102,12 +102,11 @@ module DB
# Same as `#open` but the database is yielded and closed automatically.
def self.open(uri : URI | String, &block)
build_database(uri).tap do |db|
begin
yield db
ensure
db.close
end
db = build_database(uri)
begin
yield db
ensure
db.close
end
end

View File

@ -31,13 +31,8 @@ module DB
# The `ResultSet` is closed automatically.
def query(query, *args)
# CHECK prepare(query).query(*args, &block)
query(query, *args).tap do |rs|
begin
yield rs
ensure
rs.close
end
end
rs = query(query, *args)
yield rs ensure rs.close
end
# Performs the `query` and returns an `ExecResult`

View File

@ -69,19 +69,14 @@ module DB
# See `QueryMethods#query`
def query(*args)
query(*args).tap do |rs|
begin
yield rs
ensure
rs.close
end
end
rs = query(*args)
yield rs ensure rs.close
end
private def perform_exec_and_release(args : Enumerable) : ExecResult
perform_exec(args).tap do
release_connection
end
res = perform_exec(args)
release_connection
res
end
protected abstract def perform_query(args : Enumerable) : ResultSet