/* Add plugins */
gras_trp_plugin_new("file",gras_trp_file_setup);
gras_trp_plugin_new("sg",gras_trp_sg_setup);
-
- /* buf is composed, so it must come after the others */
- gras_trp_plugin_new("buf", gras_trp_buf_setup);
+ gras_trp_plugin_new("tcp", gras_trp_tcp_setup);
}
_gras_trp_started++;
void
gras_trp_exit(void){
- xbt_dynar_t sockets = gras_socketset_get();
+ xbt_dynar_t sockets = ((gras_trp_procdata_t) gras_libdata_by_id(gras_trp_libdata_id))->sockets;
gras_socket_t sock_iter;
int cursor;
*dst = sock;
- xbt_dynar_push(gras_socketset_get(),dst);
+ xbt_dynar_push(((gras_trp_procdata_t) gras_libdata_by_id(gras_trp_libdata_id))->sockets,dst);
XBT_OUT;
}
void gras_socket_close(gras_socket_t sock) {
- xbt_dynar_t sockets = gras_socketset_get();
+ xbt_dynar_t sockets = ((gras_trp_procdata_t) gras_libdata_by_id(gras_trp_libdata_id))->sockets;
gras_socket_t sock_iter;
int cursor;
return xbt_dict_get(_gras_trp_plugins,name);
}
-int gras_socket_my_port (gras_socket_t sock) {
+int gras_socket_my_port (gras_socket_t sock) {
return sock->port;
}
int gras_socket_peer_port(gras_socket_t sock) {
static void *gras_trp_procdata_new() {
gras_trp_procdata_t res = xbt_new(s_gras_trp_procdata_t,1);
+ res->name = xbt_strdup("gras_trp");
+ res->name_len = 0;
res->sockets = xbt_dynar_new(sizeof(gras_socket_t*), NULL);
return (void*)res;
/*
* Module registration
*/
+int gras_trp_libdata_id;
void gras_trp_register() {
- gras_procdata_add("gras_trp",gras_trp_procdata_new, gras_trp_procdata_free);
+ gras_trp_libdata_id = gras_procdata_add("gras_trp",gras_trp_procdata_new, gras_trp_procdata_free);
}
-
-xbt_dynar_t
-gras_socketset_get(void) {
- /* FIXME: KILLME */
- return ((gras_trp_procdata_t) gras_libdata_get("gras_trp"))->sockets;
-}