good morning!!!!

Skip to content
Snippets Groups Projects
Commit bf67796b authored by José Carlos Nieto's avatar José Carlos Nieto
Browse files

Splitting db.go into main.go, error.go and wrapper.go.

parent 443bffc0
Branches
Tags
No related merge requests found
error.go 0 → 100644
/*
Copyright (c) 2012-2014 José Carlos Nieto, https://menteslibres.net/xiam
Permission is hereby granted, free of charge, to any person obtaining
a copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package db
import (
"errors"
)
// Application error messages.
var (
ErrExpectingPointer = errors.New(`Expecting a pointer destination (dst interface{}).`)
ErrExpectingSlicePointer = errors.New(`Expecting a pointer to an slice (dst interface{}).`)
ErrExpectingSliceMapStruct = errors.New(`Expecting a pointer to an slice of maps or structs (dst interface{}).`)
ErrExpectingMapOrStruct = errors.New(`Expecting either a pointer to a map or a pointer to a struct.`)
ErrNoMoreRows = errors.New(`There are no more rows in this result set.`)
ErrNotConnected = errors.New(`You're currently not connected.`)
ErrMissingDatabaseName = errors.New(`Missing database name.`)
ErrCollectionDoesNotExists = errors.New(`Collection does not exists.`)
ErrSockerOrHost = errors.New(`You can connect either to a socket or a host but not both.`)
ErrQueryLimitParam = errors.New(`A query can accept only one db.Limit() parameter.`)
ErrQuerySortParam = errors.New(`A query can accept only one db.Sort{} parameter.`)
ErrQueryOffsetParam = errors.New(`A query can accept only one db.Offset() parameter.`)
ErrMissingConditions = errors.New(`Missing selector conditions.`)
ErrQueryIsPending = errors.New(`Can't execute this instruction while the result set is still open.`)
ErrUnsupportedDestination = errors.New(`Unsupported destination type.`)
)
...@@ -25,12 +25,6 @@ ...@@ -25,12 +25,6 @@
// different databases using a reduced instruction set. // different databases using a reduced instruction set.
package db package db
import (
"errors"
"fmt"
"reflect"
)
/* /*
The db.Cond{} expression is used to define conditions in a query, it can be The db.Cond{} expression is used to define conditions in a query, it can be
viewed as a replacement for the SQL "WHERE" clause. viewed as a replacement for the SQL "WHERE" clause.
...@@ -205,68 +199,6 @@ type Result interface { ...@@ -205,68 +199,6 @@ type Result interface {
Close() error Close() error
} }
// Error messages
var (
ErrExpectingPointer = errors.New(`Expecting a pointer destination (dst interface{}).`)
ErrExpectingSlicePointer = errors.New(`Expecting a pointer to an slice (dst interface{}).`)
ErrExpectingSliceMapStruct = errors.New(`Expecting a pointer to an slice of maps or structs (dst interface{}).`)
ErrExpectingMapOrStruct = errors.New(`Expecting either a pointer to a map or a pointer to a struct.`)
ErrNoMoreRows = errors.New(`There are no more rows in this result set.`)
ErrNotConnected = errors.New(`You're currently not connected.`)
ErrMissingDatabaseName = errors.New(`Missing a database name.`)
ErrCollectionDoesNotExists = errors.New(`Collection does not exists.`)
ErrSockerOrHost = errors.New(`You can connect either to a socket or a host but not both.`)
ErrQueryLimitParam = errors.New(`A query can accept only one db.Limit() parameter.`)
ErrQuerySortParam = errors.New(`A query can accept only one db.Sort{} parameter.`)
ErrQueryOffsetParam = errors.New(`A query can accept only one db.Offset() parameter.`)
ErrMissingConditions = errors.New(`Missing selector conditions.`)
ErrQueryIsPending = errors.New(`Can't execute this instruction while the result set is still open.`)
ErrUnsupportedDestination = errors.New(`Unsupported destination type.`)
)
var ( var (
EnvEnableDebug = `UPPERIO_DB_DEBUG` EnvEnableDebug = `UPPERIO_DB_DEBUG`
) )
// Registered wrappers.
var wrappers = make(map[string]Database)
// Registers a database wrapper with a unique name.
func Register(name string, driver Database) {
if name == "" {
panic("Missing wrapper name.")
}
if _, ok := wrappers[name]; ok != false {
panic("Register called twice for driver " + name)
}
wrappers[name] = driver
}
// Configures a connection to a database using the named adapter and the given
// settings.
func Open(name string, settings Settings) (Database, error) {
driver, ok := wrappers[name]
if ok == false {
// Using panic instead of returning error because attemping to use an
// nonexistent adapter will never result in a successful connection,
// therefore should be considered a developer's mistake and must be catched
// at compilation time.
panic(fmt.Sprintf("Open: Unknown adapter %s. (see: https://upper.io/db#database-adapters)", name))
}
// Creating a new connection everytime Open() is called.
driverType := reflect.ValueOf(driver).Elem().Type()
newAdapter := reflect.New(driverType).Interface().(Database)
// Setting up the connection.
err := newAdapter.Setup(settings)
if err != nil {
return nil, err
}
return newAdapter, nil
}
File moved
/*
Copyright (c) 2012-2014 José Carlos Nieto, https://menteslibres.net/xiam
Permission is hereby granted, free of charge, to any person obtaining
a copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package db
import (
"fmt"
"reflect"
)
// Registered wrappers.
var wrappers = make(map[string]Database)
// Registers a database wrapper with a unique name.
func Register(name string, driver Database) {
if name == "" {
panic("Missing wrapper name.")
}
if _, ok := wrappers[name]; ok != false {
panic("Register called twice for driver " + name)
}
wrappers[name] = driver
}
// Configures a connection to a database using the named adapter and the given
// settings.
func Open(name string, settings Settings) (Database, error) {
driver, ok := wrappers[name]
if ok == false {
// Using panic instead of returning error because attemping to use an
// nonexistent adapter will never result in a successful connection,
// therefore should be considered a developer's mistake and must be catched
// at compilation time.
panic(fmt.Sprintf("Open: Unknown adapter %s. (see: https://upper.io/db#database-adapters)", name))
}
// Creating a new connection everytime Open() is called.
driverType := reflect.ValueOf(driver).Elem().Type()
newAdapter := reflect.New(driverType).Interface().(Database)
// Setting up the connection.
err := newAdapter.Setup(settings)
if err != nil {
return nil, err
}
return newAdapter, nil
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment