code cleanup
This commit is contained in:
parent
6c7b908367
commit
a580c8ab8d
@ -11,7 +11,7 @@ module.exports = {
|
|||||||
defaults: defaults
|
defaults: defaults
|
||||||
}
|
}
|
||||||
|
|
||||||
//lazy require native as it may not have been built
|
//lazy require native module...the c++ may not have been compiled
|
||||||
module.exports.__defineGetter__("native", function() {
|
module.exports.__defineGetter__("native", function() {
|
||||||
return require(__dirname + '/native');
|
return require(__dirname + '/native');
|
||||||
})
|
})
|
||||||
|
@ -8,34 +8,6 @@ var types = require(__dirname + "/types");
|
|||||||
var Connection = binding.Connection;
|
var Connection = binding.Connection;
|
||||||
var p = Connection.prototype;
|
var p = Connection.prototype;
|
||||||
|
|
||||||
var add = function(params, config, paramName) {
|
|
||||||
var value = config[paramName];
|
|
||||||
if(value) {
|
|
||||||
params.push(paramName+"='"+value+"'");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var getLibpgConString = function(config, callback) {
|
|
||||||
if(typeof config == 'object') {
|
|
||||||
var params = []
|
|
||||||
add(params, config, 'user');
|
|
||||||
add(params, config, 'password');
|
|
||||||
add(params, config, 'port');
|
|
||||||
if(config.database) {
|
|
||||||
params.push("dbname='" + config.database + "'");
|
|
||||||
}
|
|
||||||
if(config.host) {
|
|
||||||
if(config.host != 'localhost' && config.host != '127.0.0.1') {
|
|
||||||
throw new Error("Need to use node to do async DNS on host");
|
|
||||||
}
|
|
||||||
params.push("hostaddr=127.0.0.1 ");
|
|
||||||
}
|
|
||||||
callback(params.join(" "));
|
|
||||||
} else {
|
|
||||||
throw new Error("Unrecognized config type for connection");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var nativeConnect = p.connect;
|
var nativeConnect = p.connect;
|
||||||
|
|
||||||
p.connect = function() {
|
p.connect = function() {
|
||||||
@ -148,12 +120,13 @@ var NativeQuery = function(text, values, callback) {
|
|||||||
var item = this.values[i];
|
var item = this.values[i];
|
||||||
if(item instanceof Date) {
|
if(item instanceof Date) {
|
||||||
this.values[i] = JSON.stringify(item);
|
this.values[i] = JSON.stringify(item);
|
||||||
|
} else {
|
||||||
|
this.values[i] = item.toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EventEmitter.call(this);
|
EventEmitter.call(this);
|
||||||
this._translateValues();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
sys.inherits(NativeQuery, EventEmitter);
|
sys.inherits(NativeQuery, EventEmitter);
|
||||||
@ -194,12 +167,32 @@ p.handleReadyForQuery = function() {
|
|||||||
this.emit('end');
|
this.emit('end');
|
||||||
};
|
};
|
||||||
|
|
||||||
//translates values into strings
|
var add = function(params, config, paramName) {
|
||||||
p._translateValues = function() {
|
var value = config[paramName];
|
||||||
if(this.values) {
|
if(value) {
|
||||||
this.values = this.values.map(function(val) {
|
params.push(paramName+"='"+value+"'");
|
||||||
return val.toString();
|
}
|
||||||
});
|
}
|
||||||
|
|
||||||
|
//connection string helper
|
||||||
|
var getLibpgConString = function(config, callback) {
|
||||||
|
if(typeof config == 'object') {
|
||||||
|
var params = []
|
||||||
|
add(params, config, 'user');
|
||||||
|
add(params, config, 'password');
|
||||||
|
add(params, config, 'port');
|
||||||
|
if(config.database) {
|
||||||
|
params.push("dbname='" + config.database + "'");
|
||||||
|
}
|
||||||
|
if(config.host) {
|
||||||
|
if(config.host != 'localhost' && config.host != '127.0.0.1') {
|
||||||
|
throw new Error("Need to use node to do async DNS on host");
|
||||||
|
}
|
||||||
|
params.push("hostaddr=127.0.0.1 ");
|
||||||
|
}
|
||||||
|
callback(params.join(" "));
|
||||||
|
} else {
|
||||||
|
throw new Error("Unrecognized config type for connection");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,9 +9,6 @@ var Query = function(config) {
|
|||||||
this.rows = config.rows;
|
this.rows = config.rows;
|
||||||
this.types = config.types;
|
this.types = config.types;
|
||||||
this.name = config.name;
|
this.name = config.name;
|
||||||
//for code clarity purposes we'll declare this here though it's not
|
|
||||||
//set or used until a rowDescription message comes in
|
|
||||||
this.rowDescription = null;
|
|
||||||
this.callback = config.callback;
|
this.callback = config.callback;
|
||||||
this._fieldNames = [];
|
this._fieldNames = [];
|
||||||
this._fieldConverters = [];
|
this._fieldConverters = [];
|
||||||
@ -125,7 +122,7 @@ p.prepare = function(connection) {
|
|||||||
connection.parsedStatements[this.name] = true;
|
connection.parsedStatements[this.name] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
//TODO is there some btter way to prepare values for the database?
|
//TODO is there some better way to prepare values for the database?
|
||||||
if(self.values) {
|
if(self.values) {
|
||||||
self.values = self.values.map(function(val) {
|
self.values = self.values.map(function(val) {
|
||||||
return (val instanceof Date) ? JSON.stringify(val) : val;
|
return (val instanceof Date) ? JSON.stringify(val) : val;
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
//binary data writer tuned for creating
|
||||||
|
//postgres message packets as effeciently as possible by reusing the
|
||||||
|
//same buffer to avoid memcpy and limit memory allocations
|
||||||
var Writer = function(size) {
|
var Writer = function(size) {
|
||||||
this.size = size || 1024;
|
this.size = size || 1024;
|
||||||
this.buffer = new Buffer(this.size + 5);
|
this.buffer = new Buffer(this.size + 5);
|
||||||
|
Loading…
Reference in New Issue
Block a user