* Technology
* For copying and distribution information, please see the file
* <mit-copyright.h>.
- *
+ *
* This routine is part of the client library. It handles
* the protocol operations: invoking an update and getting the
* MR message of the day.
/* Invoke a DCM update. */
-int mr_do_update()
+int mr_do_update(void)
{
- int status;
- mr_params param_st;
- struct mr_params *params = NULL;
- struct mr_params *reply = NULL;
-
- CHECK_CONNECTED;
- params = ¶m_st;
- params->mr_version_no = sending_version_no;
- params->mr_procno = MR_DO_UPDATE;
- params->mr_argc = 0;
- params->mr_argl = NULL;
- params->mr_argv = NULL;
-
- if ((status = mr_do_call(params, &reply)) == 0)
- status = reply->mr_status;
-
- mr_destroy_reply(reply);
+ int status;
+ mr_params param_st;
+ struct mr_params *params = NULL;
+ struct mr_params *reply = NULL;
- return status;
+ CHECK_CONNECTED;
+ params = ¶m_st;
+ params->mr_version_no = sending_version_no;
+ params->mr_procno = MR_DO_UPDATE;
+ params->mr_argc = 0;
+ params->mr_argl = NULL;
+ params->mr_argv = NULL;
+
+ if ((status = mr_do_call(params, &reply)) == 0)
+ status = reply->mr_status;
+
+ mr_destroy_reply(reply);
+
+ return status;
}
* point to NULL or the motd in a static buffer.
*/
-int mr_motd(motd)
-char **motd;
+int mr_motd(char **motd)
{
- int status;
- mr_params param_st;
- struct mr_params *params = NULL;
- struct mr_params *reply = NULL;
- static char buffer[1024];
-
- *motd = NULL;
- CHECK_CONNECTED;
- params = ¶m_st;
- params->mr_version_no = sending_version_no;
- params->mr_procno = MR_MOTD;
- params->mr_argc = 0;
- params->mr_argl = NULL;
- params->mr_argv = NULL;
-
- if ((status = mr_do_call(params, &reply)))
- goto punt;
-
- while ((status = reply->mr_status) == MR_MORE_DATA) {
- if (reply->mr_argc > 0) {
- strncpy(buffer, reply->mr_argv[0], sizeof(buffer));
- *motd = buffer;
+ int status;
+ mr_params param_st;
+ struct mr_params *params = NULL;
+ struct mr_params *reply = NULL;
+ static char buffer[1024];
+
+ *motd = NULL;
+ CHECK_CONNECTED;
+ params = ¶m_st;
+ params->mr_version_no = sending_version_no;
+ params->mr_procno = MR_MOTD;
+ params->mr_argc = 0;
+ params->mr_argl = NULL;
+ params->mr_argv = NULL;
+
+ if ((status = mr_do_call(params, &reply)))
+ goto punt;
+
+ while ((status = reply->mr_status) == MR_MORE_DATA)
+ {
+ if (reply->mr_argc > 0)
+ {
+ strncpy(buffer, reply->mr_argv[0], sizeof(buffer));
+ *motd = buffer;
}
- mr_destroy_reply(reply);
- reply = NULL;
-
- initialize_operation(_mr_recv_op, mr_start_recv, &reply,
- (int (*)())NULL);
- queue_operation(_mr_conn, CON_INPUT, _mr_recv_op);
-
- mr_complete_operation(_mr_recv_op);
- if (OP_STATUS(_mr_recv_op) != OP_COMPLETE) {
- mr_disconnect();
- status = MR_ABORTED;
- return(status);
+ mr_destroy_reply(reply);
+ reply = NULL;
+
+ initialize_operation(_mr_recv_op, mr_start_recv, &reply, NULL);
+ queue_operation(_mr_conn, CON_INPUT, _mr_recv_op);
+
+ mr_complete_operation(_mr_recv_op);
+ if (OP_STATUS(_mr_recv_op) != OP_COMPLETE)
+ {
+ mr_disconnect();
+ status = MR_ABORTED;
+ return status;
}
- }
- punt:
- mr_destroy_reply(reply);
- /* for backwards compatability */
- if (status == MR_UNKNOWN_PROC)
- return(0);
- else
- return(status);
+ }
+punt:
+ mr_destroy_reply(reply);
+ /* for backwards compatability */
+ if (status == MR_UNKNOWN_PROC)
+ return 0;
+ else
+ return status;
}
static int mr_alternate_input = 0;
static int (*mr_alternate_handler)();
-int mr_set_alternate_input(fd, proc)
-int fd;
-int (*proc)();
+int mr_set_alternate_input(int fd, int (*proc)())
{
- if (mr_alternate_input != 0)
- return(MR_ALREADY_CONNECTED);
- mr_alternate_input = fd;
- mr_alternate_handler = proc;
- return(MR_SUCCESS);
+ if (mr_alternate_input != 0)
+ return MR_ALREADY_CONNECTED;
+ mr_alternate_input = fd;
+ mr_alternate_handler = proc;
+ return MR_SUCCESS;
}
* handles alternate input streams (such as X) as well.
*/
-mr_complete_operation(op)
-OPERATION op;
+int mr_complete_operation(OPERATION op)
{
- long infd, outfd, exfd;
- int rc;
-
- gdb_progress(); /* try for an immediate completion */
-
- if (mr_alternate_input == 0)
- return(complete_operation(op));
-
- infd = (1<<mr_alternate_input);
- outfd = exfd = 0;
-
- while(op->status != OP_COMPLETE && op->status != OP_CANCELLED) {
- rc = con_select(mr_alternate_input, (fd_set *)&infd, (fd_set *)&outfd,
- (fd_set *)&exfd, (struct timeval *)NULL);
- if (rc > 0 && mr_alternate_handler) {
- (*mr_alternate_handler)();
- }
+ long infd, outfd, exfd;
+ int rc;
+
+ gdb_progress(); /* try for an immediate completion */
+
+ if (mr_alternate_input == 0)
+ return complete_operation(op);
+
+ infd = 1 << mr_alternate_input;
+ outfd = exfd = 0;
+
+ while (op->status != OP_COMPLETE && op->status != OP_CANCELLED)
+ {
+ rc = con_select(mr_alternate_input, (fd_set *)&infd, (fd_set *)&outfd,
+ (fd_set *)&exfd, NULL);
+ if (rc > 0 && mr_alternate_handler)
+ (*mr_alternate_handler)();
}
- return(op->status);
+ return op->status;
}