add initial support for connecting with options
This commit is contained in:
parent
cb9eb5a188
commit
82e2a1de21
|
@ -1,36 +1,86 @@
|
||||||
#include "mysql2_ext.h"
|
#include "mysql2_ext.h"
|
||||||
|
|
||||||
/* Mysql2::Client */
|
/* Mysql2::Client */
|
||||||
static VALUE rb_mysql_client_new(VALUE klass) {
|
static VALUE rb_mysql_client_new(int argc, VALUE * argv, VALUE klass) {
|
||||||
MYSQL * client;
|
MYSQL * client;
|
||||||
VALUE obj;
|
VALUE obj, opts;
|
||||||
|
VALUE rb_host, rb_socket, rb_port, rb_database,
|
||||||
|
rb_username, rb_password, rb_reconnect;
|
||||||
|
char *host = "localhost", *socket = NULL, *username = NULL,
|
||||||
|
*password = NULL, *database = NULL;
|
||||||
|
unsigned int port = 3306;
|
||||||
|
my_bool reconnect = 0;
|
||||||
|
|
||||||
obj = Data_Make_Struct(klass, MYSQL, NULL, rb_mysql_client_free, client);
|
obj = Data_Make_Struct(klass, MYSQL, NULL, rb_mysql_client_free, client);
|
||||||
|
|
||||||
|
if (rb_scan_args(argc, argv, "01", &opts) == 1) {
|
||||||
|
Check_Type(opts, T_HASH);
|
||||||
|
|
||||||
|
if ((rb_host = rb_hash_aref(opts, sym_host)) != Qnil) {
|
||||||
|
Check_Type(rb_host, T_STRING);
|
||||||
|
host = RSTRING_PTR(rb_host);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_socket = rb_hash_aref(opts, sym_socket)) != Qnil) {
|
||||||
|
Check_Type(rb_socket, T_STRING);
|
||||||
|
socket = RSTRING_PTR(rb_socket);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_port = rb_hash_aref(opts, sym_port)) != Qnil) {
|
||||||
|
Check_Type(rb_port, T_FIXNUM);
|
||||||
|
port = FIX2INT(rb_port);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_username = rb_hash_aref(opts, sym_username)) != Qnil) {
|
||||||
|
Check_Type(rb_username, T_STRING);
|
||||||
|
username = RSTRING_PTR(rb_username);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_password = rb_hash_aref(opts, sym_password)) != Qnil) {
|
||||||
|
Check_Type(rb_password, T_STRING);
|
||||||
|
password = RSTRING_PTR(rb_password);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_database = rb_hash_aref(opts, sym_database)) != Qnil) {
|
||||||
|
Check_Type(rb_database, T_STRING);
|
||||||
|
database = RSTRING_PTR(rb_database);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((rb_reconnect = rb_hash_aref(opts, sym_reconnect)) != Qnil) {
|
||||||
|
reconnect = rb_reconnect == Qtrue ? 1 : 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!mysql_init(client)) {
|
if (!mysql_init(client)) {
|
||||||
// TODO: warning - not enough memory?
|
// TODO: warning - not enough memory?
|
||||||
rb_raise(rb_eStandardError, "%s", mysql_error(client));
|
rb_raise(rb_eStandardError, "%s", mysql_error(client));
|
||||||
return Qnil;
|
return Qnil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mysql_options(client, MYSQL_OPT_RECONNECT, &reconnect) != 0) {
|
||||||
|
// TODO: warning - unable to set charset
|
||||||
|
rb_warn("%s", mysql_error(client));
|
||||||
|
}
|
||||||
|
|
||||||
|
// force the encoding to utf8
|
||||||
if (mysql_options(client, MYSQL_SET_CHARSET_NAME, "utf8") != 0) {
|
if (mysql_options(client, MYSQL_SET_CHARSET_NAME, "utf8") != 0) {
|
||||||
// TODO: warning - unable to set charset
|
// TODO: warning - unable to set charset
|
||||||
rb_warn("%s", mysql_error(client));
|
rb_warn("%s", mysql_error(client));
|
||||||
}
|
}
|
||||||
|
|
||||||
// HACK
|
// HACK
|
||||||
if (!mysql_real_connect(client, "localhost", "root", NULL, NULL, 0, NULL, 0)) {
|
if (!mysql_real_connect(client, host, username, password, database, port, socket, 0)) {
|
||||||
// unable to connect
|
// unable to connect
|
||||||
rb_raise(rb_eStandardError, "%s", mysql_error(client));
|
rb_raise(rb_eStandardError, "%s", mysql_error(client));
|
||||||
return Qnil;
|
return Qnil;
|
||||||
}
|
}
|
||||||
// HACK
|
// HACK
|
||||||
|
|
||||||
rb_obj_call_init(obj, 0, NULL);
|
rb_obj_call_init(obj, argc, argv);
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
static VALUE rb_mysql_client_init(VALUE self) {
|
static VALUE rb_mysql_client_init(VALUE self, int argc, VALUE * argv) {
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -252,8 +302,8 @@ void Init_mysql2_ext() {
|
||||||
VALUE mMysql2 = rb_define_module("Mysql2");
|
VALUE mMysql2 = rb_define_module("Mysql2");
|
||||||
|
|
||||||
VALUE cMysql2Client = rb_define_class_under(mMysql2, "Client", rb_cObject);
|
VALUE cMysql2Client = rb_define_class_under(mMysql2, "Client", rb_cObject);
|
||||||
rb_define_singleton_method(cMysql2Client, "new", rb_mysql_client_new, 0);
|
rb_define_singleton_method(cMysql2Client, "new", rb_mysql_client_new, -1);
|
||||||
rb_define_method(cMysql2Client, "initialize", rb_mysql_client_init, 0);
|
rb_define_method(cMysql2Client, "initialize", rb_mysql_client_init, -1);
|
||||||
rb_define_method(cMysql2Client, "query", rb_mysql_client_query, 1);
|
rb_define_method(cMysql2Client, "query", rb_mysql_client_query, 1);
|
||||||
rb_define_method(cMysql2Client, "escape", rb_mysql_client_escape, 1);
|
rb_define_method(cMysql2Client, "escape", rb_mysql_client_escape, 1);
|
||||||
|
|
||||||
|
@ -266,6 +316,13 @@ void Init_mysql2_ext() {
|
||||||
// intern_new = rb_intern("new");
|
// intern_new = rb_intern("new");
|
||||||
|
|
||||||
sym_symbolize_keys = ID2SYM(rb_intern("symbolize_keys"));
|
sym_symbolize_keys = ID2SYM(rb_intern("symbolize_keys"));
|
||||||
|
sym_reconnect = ID2SYM(rb_intern("reconnect"));
|
||||||
|
sym_database = ID2SYM(rb_intern("database"));
|
||||||
|
sym_username = ID2SYM(rb_intern("username"));
|
||||||
|
sym_password = ID2SYM(rb_intern("password"));
|
||||||
|
sym_host = ID2SYM(rb_intern("host"));
|
||||||
|
sym_port = ID2SYM(rb_intern("port"));
|
||||||
|
sym_socket = ID2SYM(rb_intern("socket"));
|
||||||
|
|
||||||
#ifdef HAVE_RUBY_ENCODING_H
|
#ifdef HAVE_RUBY_ENCODING_H
|
||||||
utf8Encoding = rb_enc_find_index("UTF-8");
|
utf8Encoding = rb_enc_find_index("UTF-8");
|
||||||
|
|
|
@ -15,8 +15,8 @@ int utf8Encoding, binaryEncoding;
|
||||||
|
|
||||||
/* Mysql2::Client */
|
/* Mysql2::Client */
|
||||||
#define GetMysql2Client(obj, sval) (sval = (MYSQL*)DATA_PTR(obj));
|
#define GetMysql2Client(obj, sval) (sval = (MYSQL*)DATA_PTR(obj));
|
||||||
static VALUE rb_mysql_client_new(VALUE klass);
|
static VALUE rb_mysql_client_new(int argc, VALUE * argv, VALUE klass);
|
||||||
static VALUE rb_mysql_client_init(VALUE self);
|
static VALUE rb_mysql_client_init(VALUE self, int argc, VALUE * argv);
|
||||||
static VALUE rb_mysql_client_query(VALUE self, VALUE query);
|
static VALUE rb_mysql_client_query(VALUE self, VALUE query);
|
||||||
static VALUE rb_mysql_client_escape(VALUE self, VALUE str);
|
static VALUE rb_mysql_client_escape(VALUE self, VALUE str);
|
||||||
void rb_mysql_client_free(void * client);
|
void rb_mysql_client_free(void * client);
|
||||||
|
@ -24,7 +24,7 @@ void rb_mysql_client_free(void * client);
|
||||||
/* Mysql2::Result */
|
/* Mysql2::Result */
|
||||||
#define GetMysql2Result(obj, sval) (sval = (MYSQL_RES*)DATA_PTR(obj));
|
#define GetMysql2Result(obj, sval) (sval = (MYSQL_RES*)DATA_PTR(obj));
|
||||||
VALUE cMysql2Result;
|
VALUE cMysql2Result;
|
||||||
static ID sym_symbolize_keys;
|
static ID sym_symbolize_keys, sym_socket, sym_host, sym_port, sym_username, sym_password, sym_database, sym_reconnect;
|
||||||
static VALUE rb_mysql_result_to_obj(MYSQL_RES * res);
|
static VALUE rb_mysql_result_to_obj(MYSQL_RES * res);
|
||||||
static VALUE rb_mysql_result_fetch_row(int argc, VALUE * argv, VALUE self);
|
static VALUE rb_mysql_result_fetch_row(int argc, VALUE * argv, VALUE self);
|
||||||
static VALUE rb_mysql_result_each(int argc, VALUE * argv, VALUE self);
|
static VALUE rb_mysql_result_each(int argc, VALUE * argv, VALUE self);
|
||||||
|
|
Loading…
Reference in New Issue