59 lines
2.0 KiB
JavaScript
59 lines
2.0 KiB
JavaScript
/*
|
|
Copyright (c) 2013, Oracle and/or its affiliates. All rights
|
|
reserved.
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; version 2 of
|
|
the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
|
02110-1301 USA
|
|
*/
|
|
|
|
/**********************
|
|
This is the standard TypeConverter class used with TIME columns
|
|
in the Ndb Adapter.
|
|
|
|
On the JavaScript side, this converter takes a string formatted as
|
|
"HH:MM:SS.sss" with optional sign +/-, and precision after the decimal
|
|
point up to six digits.
|
|
|
|
On the database side, TIME columns are read and written using a MySQLTime
|
|
structure. MySQL TIME is a signed type, and the sign is preserved.
|
|
In MySQL 5.6, MySQL TIME can also support up to microsecond precision.
|
|
|
|
An application can override this converter and use MySQLTime directly:
|
|
sessionFactory.registerTypeConverter("TIME", null);
|
|
|
|
Or replace this converter with a custom one:
|
|
sessionFactory.registerTypeConverter("TIME", myConverterClass);
|
|
|
|
************************/
|
|
|
|
// TODO: default values? undefined?
|
|
|
|
var path = require("path"),
|
|
MySQLTime = require(path.join(mynode.fs.spi_dir,"common","MySQLTime.js")),
|
|
udebug = unified_debug.getLogger("NdbTimeConverter.js");
|
|
|
|
exports.toDB = function(jsValue) {
|
|
var dbtime = null;
|
|
if(typeof jsValue === 'string') {
|
|
dbtime = new MySQLTime().initializeFromTimeString(jsValue);
|
|
}
|
|
return dbtime;
|
|
};
|
|
|
|
exports.fromDB = function(dbTime) {
|
|
return MySQLTime.initializeFromNdb(dbTime).toTimeString();
|
|
};
|
|
|