Commit 3415a54c authored by gwenn's avatar gwenn Committed by GitHub

Merge pull request #13 from navytux/y/ctx-nocancel

driver: Don't waste resources setting/being-notified up in progress handler if context cannot be canceled
parents 79ff27e8 a7ad1297
...@@ -140,8 +140,10 @@ func (c *conn) ExecContext(ctx context.Context, query string, args []driver.Name ...@@ -140,8 +140,10 @@ func (c *conn) ExecContext(ctx context.Context, query string, args []driver.Name
if c.c.IsClosed() { if c.c.IsClosed() {
return nil, driver.ErrBadConn return nil, driver.ErrBadConn
} }
c.c.ProgressHandler(progressHandler, 100, ctx) if ctx.Done() != nil {
defer c.c.ProgressHandler(nil, 0, nil) c.c.ProgressHandler(progressHandler, 100, ctx)
defer c.c.ProgressHandler(nil, 0, nil)
}
if len(args) == 0 { if len(args) == 0 {
if query == "unwrap" { if query == "unwrap" {
return nil, ConnError{c: c.c} return nil, ConnError{c: c.c}
...@@ -254,8 +256,10 @@ func (s *stmt) ExecContext(ctx context.Context, args []driver.NamedValue) (drive ...@@ -254,8 +256,10 @@ func (s *stmt) ExecContext(ctx context.Context, args []driver.NamedValue) (drive
if err := s.s.bindNamedValue(args); err != nil { if err := s.s.bindNamedValue(args); err != nil {
return nil, err return nil, err
} }
s.s.c.ProgressHandler(progressHandler, 100, ctx) if ctx.Done() != nil {
defer s.s.c.ProgressHandler(nil, 0, nil) s.s.c.ProgressHandler(progressHandler, 100, ctx)
defer s.s.c.ProgressHandler(nil, 0, nil)
}
if err := s.s.exec(); err != nil { if err := s.s.exec(); err != nil {
return nil, ctxError(ctx, err) return nil, ctxError(ctx, err)
} }
...@@ -270,7 +274,9 @@ func (s *stmt) QueryContext(ctx context.Context, args []driver.NamedValue) (driv ...@@ -270,7 +274,9 @@ func (s *stmt) QueryContext(ctx context.Context, args []driver.NamedValue) (driv
return nil, err return nil, err
} }
s.rowsRef = true s.rowsRef = true
s.s.c.ProgressHandler(progressHandler, 100, ctx) if ctx.Done() != nil {
s.s.c.ProgressHandler(progressHandler, 100, ctx)
}
return &rowsImpl{s, nil, ctx}, nil return &rowsImpl{s, nil, ctx}, nil
} }
...@@ -308,7 +314,9 @@ func (r *rowsImpl) Next(dest []driver.Value) error { ...@@ -308,7 +314,9 @@ func (r *rowsImpl) Next(dest []driver.Value) error {
} }
func (r *rowsImpl) Close() error { func (r *rowsImpl) Close() error {
r.s.s.c.ProgressHandler(nil, 0, nil) if r.ctx.Done() != nil {
r.s.s.c.ProgressHandler(nil, 0, nil)
}
r.s.rowsRef = false r.s.rowsRef = false
if r.s.pendingClose { if r.s.pendingClose {
return r.s.Close() return r.s.Close()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment