X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=conversation.pyx;h=588f29a1feeaf894d42090dbe7e4e897135b11cb;hp=ecb00bcb93537e090ddf5ff7d00768790f0cefce;hb=1ebedbc8928e2e85faccc07f84da6b422040fb3e;hpb=7f9bbfa5e0f087ba5a5c1367ab1bea72f53573d0 diff --git a/conversation.pyx b/conversation.pyx index ecb00bc..588f29a 100644 --- a/conversation.pyx +++ b/conversation.pyx @@ -17,18 +17,58 @@ # along with this program. If not, see . # +cimport purple + cdef class Conversation: """ Conversation class """ - cdef PurpleConversation *__conv + cdef conversation.PurpleConversation *__conv + cdef Account __acc + + cdef object __name + + def __init__(self): + conversation.c_purple_conversations_init() + self.__name = None - def __cinit__(self): - purple_conversations_init() + def __get_account(self): + return self.__acc + def __set_account(self, acc): + self.__acc = acc + account = property(__get_account, __set_account) - def conversation_new(self, type, acc, const_char_ptr name): - self.__conv = purple_conversation_new(type, acc.__account, name) + def __get_name(self): + return self.__name + def __set_name(self, name): + self.__name = name + name = property(__get_name, __set_name) + + def initialize(self, acc, type, char *name): + self.__acc = acc + self.__name = name + + if type == "UNKNOWN": + self.__conv =\ + conversation.c_purple_conversation_new(conversation.PURPLE_CONV_TYPE_UNKNOWN,\ + self.__acc.c_account, self.__name) + elif type == "IM": + self.__conv =\ + conversation.c_purple_conversation_new(conversation.PURPLE_CONV_TYPE_IM,\ + self.__acc.c_account, self.__name) + elif type == "CHAT": + self.__conv =\ + conversation.c_purple_conversation_new(conversation.PURPLE_CONV_TYPE_CHAT,\ + self.__acc.c_account, self.__name) + elif type == "MISC": + self.__conv =\ + conversation.c_purple_conversation_new(conversation.PURPLE_CONV_TYPE_MISC,\ + self.__acc.c_account, self.__name) + elif type == "ANY": + self.__conv =\ + conversation.c_purple_conversation_new(conversation.PURPLE_CONV_TYPE_ANY,\ + self.__acc.c_account, self.__name) def conversation_set_ui_ops(self): - cdef PurpleConversationUiOps c_conv_ui_ops + cdef conversation.PurpleConversationUiOps c_conv_ui_ops c_conv_ui_ops.create_conversation = NULL c_conv_ui_ops.destroy_conversation = NULL c_conv_ui_ops.write_chat = NULL @@ -45,18 +85,14 @@ cdef class Conversation: c_conv_ui_ops.custom_smiley_close = NULL c_conv_ui_ops.send_confirm = NULL - purple_conversation_set_ui_ops(self.__conv, &c_conv_ui_ops) - - def conversation_write(self, const_char_ptr message): - purple_conv_im_send(purple_conversation_get_im_data(self.__conv), message) + conversation.c_purple_conversation_set_ui_ops(self.__conv, &c_conv_ui_ops) - def conversation_destroy(self): - purple_conversation_destroy(self.__conv) + def write(self, char *message): + conversation.c_purple_conv_im_send(conversation.c_purple_conversation_get_im_data(self.__conv), message) - def conversation_get_handle(self): - purple_conversations_get_handle() + def get_handle(self): + conversation.c_purple_conversations_get_handle() - def send_message(self, buddy, const_char_ptr message): - self.conversation_new(1, buddy.account, buddy.name) - self.conversation_set_ui_ops() - self.conversation_write(message) + def destroy(self): + print "[DEBUG]: Destroy conversation: %s" % self.__name + conversation.c_purple_conversation_destroy(self.__conv)