X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/8e5967203f4ea512a321daeb1dafb5eac209d69a..b1a2e45431d13cdf45ec8b1c91bf7d6ca8377c9d:/src/bindings/ruby_bindings.h diff --git a/src/bindings/ruby_bindings.h b/src/bindings/ruby_bindings.h index 2b60085378..48821a9cba 100644 --- a/src/bindings/ruby_bindings.h +++ b/src/bindings/ruby_bindings.h @@ -25,7 +25,8 @@ #include "xbt/sysdep.h" #include "xbt/log.h" #include "xbt/asserts.h" -//#include "rb_msg_host.h" + +#include "simix/smx_context_private.h" /* Damn Ruby. They load their full config.h, which breaks since we also load ours. * So, we undef the offending defines @@ -38,13 +39,11 @@ #undef _GNU_SOURCE #include - - /* ********************* * * Context related stuff * * ********************* */ typedef struct s_smx_ctx_ruby { - SMX_CTX_BASE_T; + s_smx_ctx_base_t super; /* Fields of super implementation */ VALUE process; // The Ruby Process Instance //... }s_smx_ctx_ruby_t,*smx_ctx_ruby_t; @@ -69,7 +68,6 @@ void rb_process_join( VALUE ruby_process ); void rb_process_unschedule( VALUE ruby_process ); void rb_process_schedule( VALUE ruby_process ); - /* ********************************************** * * Function for Native Process (Bound) Management * * * @@ -100,11 +98,14 @@ VALUE rb_host_speed(VALUE Class,VALUE host); void rb_host_set_data(VALUE Class,VALUE host,VALUE data); VALUE rb_host_get_data(VALUE Class,VALUE host); VALUE rb_host_is_avail(VALUE Class,VALUE host); +VALUE rb_host_process(VALUE Class,VALUE process); /* Functions related to tasks */ void rb_task_free(m_task_t tk); // New Method >>> Data NULL VALUE rb_task_new(VALUE Class, VALUE name,VALUE comp_size,VALUE comm_size); +void rb_task_set_data(VALUE Class,VALUE task,VALUE data); // Data as a String +VALUE rb_task_get_data(VALUE Class,VALUE task); VALUE rb_task_comp(VALUE Class,VALUE task); // Get Computation Size VALUE rb_task_name(VALUE Class,VALUE task); VALUE rb_task_execute(VALUE Class,VALUE task); @@ -115,6 +116,8 @@ VALUE rb_task_sender(VALUE Class,VALUE task); VALUE rb_task_source(VALUE Class,VALUE task); VALUE rb_task_listen(VALUE Class,VALUE task,VALUE alias); //Listen From Alias (=mailbox) VALUE rb_task_listen_host(VALUE Class,VALUE task,VALUE alias,VALUE host); //Listen from Host +void rb_task_set_priority(VALUE Class,VALUE task,VALUE priority); // Set Priority +void rb_task_cancel(VALUE Class,VALUE task); // Cancel /* Upcalls for the application handler */ void rb_application_handler_on_start_document(void);