44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// +build go1.10
 | 
						|
 | 
						|
package pq
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"database/sql/driver"
 | 
						|
)
 | 
						|
 | 
						|
// Connector represents a fixed configuration for the pq driver with a given
 | 
						|
// name. Connector satisfies the database/sql/driver Connector interface and
 | 
						|
// can be used to create any number of DB Conn's via the database/sql OpenDB
 | 
						|
// function.
 | 
						|
//
 | 
						|
// See https://golang.org/pkg/database/sql/driver/#Connector.
 | 
						|
// See https://golang.org/pkg/database/sql/#OpenDB.
 | 
						|
type connector struct {
 | 
						|
	name string
 | 
						|
}
 | 
						|
 | 
						|
// Connect returns a connection to the database using the fixed configuration
 | 
						|
// of this Connector. Context is not used.
 | 
						|
func (c *connector) Connect(_ context.Context) (driver.Conn, error) {
 | 
						|
	return (&Driver{}).Open(c.name)
 | 
						|
}
 | 
						|
 | 
						|
// Driver returnst the underlying driver of this Connector.
 | 
						|
func (c *connector) Driver() driver.Driver {
 | 
						|
	return &Driver{}
 | 
						|
}
 | 
						|
 | 
						|
var _ driver.Connector = &connector{}
 | 
						|
 | 
						|
// NewConnector returns a connector for the pq driver in a fixed configuration
 | 
						|
// with the given name. The returned connector can be used to create any number
 | 
						|
// of equivalent Conn's. The returned connector is intended to be used with
 | 
						|
// database/sql.OpenDB.
 | 
						|
//
 | 
						|
// See https://golang.org/pkg/database/sql/driver/#Connector.
 | 
						|
// See https://golang.org/pkg/database/sql/#OpenDB.
 | 
						|
func NewConnector(name string) (driver.Connector, error) {
 | 
						|
	return &connector{name: name}, nil
 | 
						|
}
 |