diff --git a/src/zmapView/zmapView.c b/src/zmapView/zmapView.c index 9916762999405289726a7431fd5be58e2e95fdd5..d11ab833b6c2c3617984b9efcb22d32c21d5e8bf 100755 --- a/src/zmapView/zmapView.c +++ b/src/zmapView/zmapView.c @@ -25,16 +25,16 @@ * Description: * Exported functions: See ZMap/zmapView.h * HISTORY: - * Last edited: Jan 20 11:53 2005 (edgrif) + * Last edited: Feb 1 16:24 2005 (edgrif) * Created: Thu May 13 15:28:26 2004 (edgrif) - * CVS info: $Id: zmapView.c,v 1.41 2005-01-24 11:49:45 edgrif Exp $ + * CVS info: $Id: zmapView.c,v 1.42 2005-02-02 14:52:48 edgrif Exp $ *------------------------------------------------------------------- */ #include <gtk/gtk.h> #include <ZMap/zmapUtils.h> #include <ZMap/zmapConfig.h> -#include <ZMap/zmapConn.h> +#include <ZMap/zmapServerProtocol.h> #include <ZMap/zmapWindow.h> #include <zmapView_P.h> @@ -74,7 +74,7 @@ static ZMapViewConnection createConnection(ZMapView zmap_view, char *machine, int port, char *protocol, int timeout, char *version, char *types_file, gboolean sequence_server, gboolean writeback_server, - char *sequence, int start, int end, gboolean load_features) ; + char *sequence, int start, int end) ; static void destroyConnection(ZMapViewConnection *view_conn) ; static void resetWindows(ZMapView zmap_view) ; @@ -87,7 +87,7 @@ static void destroyWindow(ZMapView zmap_view, ZMapViewWindow view_window) ; static void freeContext(ZMapFeatureContext feature_context) ; -static void getFeatures(ZMapView zmap_view, ZMapProtocolAny req_any) ; +static void getFeatures(ZMapView zmap_view, ZMapServerReqGetFeatures feature_req) ; @@ -156,8 +156,8 @@ ZMapView zMapViewCreate(char *sequence, int start, int end, void *app_data) /* Set up debugging for threads, we do it here so that user can change setting in config file * and next time they create a view the debugging will go on/off. */ - if (zMapUtilsConfigDebug(ZMAPTHR_CONFIG_DEBUG_STR, &debug)) - zmap_thr_debug_G = debug ; + if (zMapUtilsConfigDebug(ZMAPTHREAD_CONFIG_DEBUG_STR, &debug)) + zmap_thread_debug_G = debug ; zmap_view = createZMapView(sequence, start, end, app_data) ; @@ -222,7 +222,6 @@ ZMapViewWindow zMapViewCopyWindow(ZMapView zmap_view, GtkWidget *parent_widget, ZMapWindow copy_window) { ZMapViewWindow view_window = NULL ; - double zoom_factor; /* the view _must_ already have a window. */ zMapAssert(zmap_view && parent_widget @@ -309,9 +308,6 @@ gboolean zMapViewConnect(ZMapView zmap_view) { ZMapConfig config ; - /* this should be user settable.... */ - gboolean load_features = TRUE ; - zmapViewBusy(zmap_view, TRUE) ; /* We need to retrieve the connect data here from the config stuff.... */ @@ -393,8 +389,7 @@ gboolean zMapViewConnect(ZMapView zmap_view) timeout, version, types_file, sequence_server, writeback_server, zmap_view->sequence, - zmap_view->start, zmap_view->end, - load_features))) + zmap_view->start, zmap_view->end))) { /* Update now we have successfully created a connection. */ zmap_view->connection_list = g_list_append(zmap_view->connection_list, view_con) ; @@ -441,9 +436,6 @@ gboolean zMapViewConnect(ZMapView zmap_view) zmap_view->state = ZMAPVIEW_NOT_CONNECTED ; } - /* If we are loading features then we need to visually tell the user we are doing this. */ - if (!load_features) - zmapViewBusy(zmap_view, FALSE) ; } return result ; @@ -932,16 +924,21 @@ static gboolean checkStateConnections(ZMapView zmap_view) do { ZMapViewConnection view_con ; + +#ifdef ED_G_NEVER_INCLUDE_THIS_CODE ZMapConnection connection ; +#endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ + ZMapThread thread ; + ZMapThreadReply reply ; void *data = NULL ; char *err_msg = NULL ; view_con = list_item->data ; - connection = view_con->connection ; + thread = view_con->thread ; #ifdef ED_G_NEVER_INCLUDE_THIS_CODE - ZMAP_DEBUG("GUI: checking connection for thread %x\n", + ZMAP_DEBUG("GUI: checking connection for thread %lu\n", zMapConnGetThreadid(connection)) ; #endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ @@ -953,10 +950,10 @@ static gboolean checkStateConnections(ZMapView zmap_view) data = NULL ; err_msg = NULL ; - if (!(zMapConnGetReplyWithData(connection, &reply, &data, &err_msg))) + if (!(zMapThreadGetReplyWithData(thread, &reply, &data, &err_msg))) { - zMapDebug("GUI: thread %x, cannot access reply from thread - %s\n", - zMapConnGetThreadid(connection), err_msg) ; + zMapDebug("GUI: thread %lu, cannot access reply from thread - %s\n", + zMapThreadGetThreadid(thread), err_msg) ; /* should abort or dump here....or at least kill this connection. */ @@ -965,45 +962,54 @@ static gboolean checkStateConnections(ZMapView zmap_view) { #ifdef ED_G_NEVER_INCLUDE_THIS_CODE - zMapDebug("GUI: thread %x, thread reply = %s\n", - zMapConnGetThreadid(connection), + zMapDebug("GUI: thread %lu, thread reply = %s\n", + zMapThreadGetThreadid(thread), zMapVarGetReplyString(reply)) ; #endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ - if (reply == ZMAP_REPLY_WAIT) + if (reply == ZMAPTHREAD_REPLY_WAIT) { ; /* nothing to do. */ } - else if (reply == ZMAP_REPLY_GOTDATA) + else if (reply == ZMAPTHREAD_REPLY_GOTDATA) { - view_con->curr_request = ZMAP_REQUEST_WAIT ; + view_con->curr_request = ZMAPTHREAD_REQUEST_WAIT ; if (zmap_view->state == ZMAPVIEW_RUNNING) { - ZMapProtocolAny req_any = (ZMapProtocolAny)data ; + ZMapServerReqAny req_any = (ZMapServerReqAny)data ; - zMapDebug("GUI: thread %x, got data\n", - zMapConnGetThreadid(connection)) ; + zMapDebug("GUI: thread %lu, got data\n", + zMapThreadGetThreadid(thread)) ; /* Reset the reply from the slave. */ - zMapConnSetReply(connection, ZMAP_REPLY_WAIT) ; + zMapThreadSetReply(thread, ZMAPTHREAD_REPLY_WAIT) ; /* Process the different types of data coming back. */ - switch (req_any->request) + switch (req_any->type) { - case ZMAP_PROTOCOLREQUEST_FEATURES: - case ZMAP_PROTOCOLREQUEST_FEATURE_SEQUENCE: - case ZMAP_PROTOCOLREQUEST_SEQUENCE: + case ZMAP_SERVERREQ_OPENLOAD: + { + ZMapServerReqGetFeatures features + = (ZMapServerReqGetFeatures)&(((ZMapServerReqOpenLoad)req_any)->features) ; + + getFeatures(zmap_view, features) ; + + break ; + } + case ZMAP_SERVERREQ_FEATURES: + case ZMAP_SERVERREQ_FEATURE_SEQUENCE: + case ZMAP_SERVERREQ_SEQUENCE: { - getFeatures(zmap_view, req_any) ; + getFeatures(zmap_view, (ZMapServerReqGetFeatures)req_any) ; break ; } default: { - zMapLogFatal("Unknown request type: %d", req_any->request) ; /* Exit appl. */ + zMapLogFatal("Unknown request type: %d", req_any->type) ; /* Exit appl. */ break ; } } @@ -1012,27 +1018,28 @@ static gboolean checkStateConnections(ZMapView zmap_view) g_free(data) ; } else - zMapDebug("GUI: thread %x, got data but ZMap state is - %s\n", - zMapConnGetThreadid(connection), zMapViewGetStatus(zmap_view)) ; + zMapDebug("GUI: thread %lu, got data but ZMap state is - %s\n", + zMapThreadGetThreadid(thread), + zMapViewGetStatusStr(zMapViewGetStatus(zmap_view))) ; } - else if (reply == ZMAP_REPLY_REQERROR) + else if (reply == ZMAPTHREAD_REPLY_REQERROR) { if (err_msg) zMapWarning("%s", err_msg) ; - view_con->curr_request = ZMAP_REQUEST_WAIT ; + view_con->curr_request = ZMAPTHREAD_REQUEST_WAIT ; /* Reset the reply from the slave. */ - zMapConnSetReply(connection, ZMAP_REPLY_WAIT) ; + zMapThreadSetReply(thread, ZMAPTHREAD_REPLY_WAIT) ; /* This means the request failed for some reason. */ - zMapDebug("GUI: thread %x, request to server failed....\n", - zMapConnGetThreadid(connection)) ; + zMapDebug("GUI: thread %lu, request to server failed....\n", + zMapThreadGetThreadid(thread)) ; g_free(err_msg) ; } - else if (reply == ZMAP_REPLY_DIED) + else if (reply == ZMAPTHREAD_REPLY_DIED) { if (err_msg) zMapWarning("%s", err_msg) ; @@ -1040,8 +1047,8 @@ static gboolean checkStateConnections(ZMapView zmap_view) threads_have_died = TRUE ; /* This means the thread has failed for some reason and we should clean up. */ - zMapDebug("GUI: thread %x has died so cleaning up....\n", - zMapConnGetThreadid(connection)) ; + zMapDebug("GUI: thread %lu has died so cleaning up....\n", + zMapThreadGetThreadid(thread)) ; /* We are going to remove an item from the list so better move on from * this item. */ @@ -1050,15 +1057,15 @@ static gboolean checkStateConnections(ZMapView zmap_view) destroyConnection(&view_con) ; } - else if (reply == ZMAP_REPLY_CANCELLED) + else if (reply == ZMAPTHREAD_REPLY_CANCELLED) { /* I'm not sure we need to do anything here as now this loop is "inside" a * zmap, we should already chopping the zmap threads outside of this routine, * so I think logically this cannot happen...???? */ /* This means the thread was cancelled so we should clean up..... */ - zMapDebug("GUI: thread %x has been cancelled so cleaning up....\n", - zMapConnGetThreadid(connection)) ; + zMapDebug("GUI: thread %lu has been cancelled so cleaning up....\n", + zMapThreadGetThreadid(thread)) ; /* We are going to remove an item from the list so better move on from * this item. */ @@ -1156,21 +1163,26 @@ static void loadDataConnections(ZMapView zmap_view) do { ZMapViewConnection view_con ; + +#ifdef ED_G_NEVER_INCLUDE_THIS_CODE ZMapConnection connection ; - ZMapProtocolGetFeatures req_features ; +#endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ + ZMapThread thread ; + + ZMapServerReqGetFeatures req_features ; view_con = list_item->data ; - connection = view_con->connection ; + thread = view_con->thread ; /* Construct the request to get the features, if its the sequence server then * get the sequence as well. */ - req_features = g_new0(ZMapProtocolGetFeaturesStruct, 1) ; + req_features = g_new0(ZMapServerReqGetFeaturesStruct, 1) ; if (view_con->sequence_server) - req_features->request = ZMAP_PROTOCOLREQUEST_FEATURE_SEQUENCE ; + req_features->type = ZMAP_SERVERREQ_FEATURE_SEQUENCE ; else - req_features->request = ZMAP_PROTOCOLREQUEST_FEATURES ; + req_features->type = ZMAP_SERVERREQ_FEATURES ; - zMapConnRequest(connection, req_features) ; + zMapThreadRequest(thread, req_features) ; } while ((list_item = g_list_next(list_item))) ; } @@ -1233,14 +1245,18 @@ static void killConnections(ZMapView zmap_view) do { ZMapViewConnection view_con ; + +#ifdef ED_G_NEVER_INCLUDE_THIS_CODE ZMapConnection connection ; +#endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ + ZMapThread thread ; view_con = list_item->data ; - connection = view_con->connection ; + thread = view_con->thread ; /* NOTE, we do a _kill_ here, not a destroy. This just signals the thread to die, it * will actually die sometime later. */ - zMapConnKill(connection) ; + zMapThreadKill(thread) ; } while ((list_item = g_list_next(list_item))) ; @@ -1248,38 +1264,64 @@ static void killConnections(ZMapView zmap_view) } -/* Allocate and destroy ZMapViews record of a connection. */ +/* Allocate a connection and send over the request to get the sequence displayed. */ static ZMapViewConnection createConnection(ZMapView zmap_view, char *machine, int port, char *protocol, int timeout, char *version, char *types_file, gboolean sequence_server, gboolean writeback_server, - char *sequence, int start, int end, gboolean load_features) + char *sequence, int start, int end) { ZMapViewConnection view_con = NULL ; + +#ifdef ED_G_NEVER_INCLUDE_THIS_CODE ZMapConnection connection ; - ZMapProtocolGetFeatures initial_request = NULL ; - GData *types ; +#endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ + ZMapThread thread ; - /* If we need to autoload features then construct an initial request that will be given - * to the thread to get the features and maybe the sequence. */ - if (load_features) + /* Create the thread to service the connection requests, we give it a function that it will call + * to decode the requests we send it. */ + if ((thread = zMapThreadCreate(zMapServerRequestHandler))) { - initial_request = g_new0(ZMapProtocolGetFeaturesStruct, 1) ; + ZMapServerReqOpenLoad open_load = NULL ; + GData *types ; + + /* in the end the types files will be optional..... */ + types = zMapFeatureTypeGetFromFile(types_file) ; + + + /* Build the intial request. */ + open_load = g_new0(ZMapServerReqOpenLoadStruct, 1) ; + open_load->type = ZMAP_SERVERREQ_OPENLOAD ; + + open_load->open.machine = g_strdup(machine) ; + open_load->open.port = port ; + open_load->open.protocol = g_strdup(protocol) ; + open_load->open.timeout = timeout ; + open_load->open.version = g_strdup(version) ; + + open_load->context.sequence = g_strdup(sequence) ; + open_load->context.start = start ; + open_load->context.end = end ; + open_load->context.types = types ; + if (sequence_server) - initial_request->request = ZMAP_PROTOCOLREQUEST_FEATURE_SEQUENCE ; + open_load->features.type = ZMAP_SERVERREQ_FEATURE_SEQUENCE ; else - initial_request->request = ZMAP_PROTOCOLREQUEST_FEATURES ; - } + open_load->features.type = ZMAP_SERVERREQ_FEATURES ; - /* in the end the types files will be optional..... */ - types = zMapFeatureTypeGetFromFile(types_file) ; - if ((connection = zMapConnCreate(machine, port, protocol, timeout, version, - sequence, start, end, types, - (ZMapProtocolAny)initial_request))) - { + + +#ifdef ED_G_NEVER_INCLUDE_THIS_CODE + if ((thread = zMapThreadCreate(machine, port, protocol, timeout, version, + sequence, start, end, types, + (void *)open_load))) ; +#endif /* ED_G_NEVER_INCLUDE_THIS_CODE */ + + zMapThreadRequest(thread, (void *)open_load) ; + view_con = g_new0(ZMapViewConnectionStruct, 1) ; view_con->sequence_server = sequence_server ; @@ -1289,14 +1331,9 @@ static ZMapViewConnection createConnection(ZMapView zmap_view, view_con->parent_view = zmap_view ; - /* If we are asking the thread to get the features when it starts up then we must record - * that we have made a request. */ - if (load_features) - view_con->curr_request = ZMAP_REQUEST_GETDATA ; - else - view_con->curr_request = ZMAP_REQUEST_WAIT ; + view_con->curr_request = ZMAPTHREAD_REQUEST_EXECUTE ; - view_con->connection = connection ; + view_con->thread = thread ; } return view_con ; @@ -1306,7 +1343,7 @@ static void destroyConnection(ZMapViewConnection *view_conn_ptr) { ZMapViewConnection view_conn = *view_conn_ptr ; - zMapConnDestroy(view_conn->connection) ; + zMapThreadDestroy(view_conn->thread) ; /* Need to destroy the types array here....... */ @@ -1433,9 +1470,8 @@ static void freeContext(ZMapFeatureContext feature_context) * the diff we should not free the data but should free all our structs... * * */ -static void getFeatures(ZMapView zmap_view, ZMapProtocolAny req_any) +static void getFeatures(ZMapView zmap_view, ZMapServerReqGetFeatures feature_req) { - ZMapProtocolGetFeatures feature_req = (ZMapProtocolGetFeatures)req_any ; ZMapFeatureContext new_features = NULL, diff_context = NULL ; /* Merge new data with existing data (if any). */