bindings/ruby/rblm-message.c
author Mikael Hallendal <micke@imendio.com>
Thu, 10 Apr 2008 15:40:20 +0200
changeset 379 bc14607827e8
parent 369 a416922c533d
child 385 b27d2a2b37a1
permissions -rw-r--r--
Added port, port=, username, username= to LmProxy ruby bindings

#include "rblm.h"
#include "rblm-private.h"

/* How to handle type, sub_type and root node*/

VALUE lm_cMessage;

static LmMessage *
rb_lm_message_from_ruby_object (VALUE obj)
{
	LmMessage *m;

	if (!rb_lm__is_kind_of (obj, lm_cMessage)) {
		rb_raise (rb_eTypeError, "not a LmMessage");
	}

	Data_Get_Struct (obj, LmMessage, m);

	return m;
}

void
msg_free (LmMessage *m)
{
	lm_message_unref (m);
}

VALUE
msg_allocate (VALUE klass)
{
	return Data_Wrap_Struct (klass, NULL, msg_free, NULL);
}

VALUE
msg_initialize (int argc, VALUE *argv, VALUE self)
{
	LmMessage  *m;
	VALUE       to, type, sub_type;
	char       *to_str = NULL;

	rb_scan_args (argc, argv, "21", &to, &type, &sub_type);

	/* To can be nil */
	if (!NIL_P (to)) {
		if (!rb_respond_to (to, rb_intern ("to_s"))) {
			rb_raise (rb_eArgError, "to should respond to to_s");
		} else {
			VALUE str_val = rb_funcall (to, rb_intern ("to_s"), 0);
			to_str = StringValuePtr (str_val);
		}
	} 

	if (NIL_P (sub_type)) {
		/* Without sub_type */
		m = lm_message_new (to_str, FIX2INT (type));
	} else {
		m = lm_message_new_with_sub_type (to_str,
						  FIX2INT (type),
						  FIX2INT (sub_type));
	}

	DATA_PTR (self) = m;

	return self;
}

VALUE
msg_get_type (VALUE self)
{
	LmMessage *m = rb_lm_message_from_ruby_object (self);

	return INT2FIX (lm_message_get_type (m));
}

VALUE
msg_get_sub_type (VALUE self)
{
	LmMessage *m = rb_lm_message_from_ruby_object (self);

	return INT2FIX (lm_message_get_sub_type (m));
}

VALUE
msg_get_root_node (VALUE self)
{
	/* How to? */
	return Qnil;
}

extern void 
Init_lm_message (VALUE lm_mLM)
{
	lm_cMessage = rb_define_class_under (lm_mLM, "Message", rb_cObject);

	rb_define_alloc_func (lm_cMessage, msg_allocate);
	
	rb_define_method (lm_cMessage, "initialize", msg_initialize, -1);
	rb_define_method (lm_cMessage, "type", msg_get_type, 0);
	rb_define_method (lm_cMessage, "sub_type", msg_get_sub_type, 0);
	rb_define_method (lm_cMessage, "root_node", msg_get_root_node, 0);
}