* Copyright (c) 1995-2004, Index Data
* See the file LICENSE for details.
*
- * $Id: client.c,v 1.242 2004-05-03 09:00:29 adam Exp $
+ * $Id: client.c,v 1.245 2004-07-30 08:37:52 adam Exp $
*/
#include <stdio.h>
/* add newline if not already added ... */
if (i <= 0 || buf[i-1] != '\n')
printf ("\n");
+ if (marc_file)
+ fwrite (buf, 1, len, marc_file);
}
static void display_record(Z_External *r)
odr_malloc (out, sizeof(*req->deleteFunction));
if (req->num_resultSetList > 0)
{
- *req->deleteFunction = Z_DeleteRequest_list;
+ *req->deleteFunction = Z_DeleteResultSetRequest_list;
req->resultSetList = (char **)
odr_malloc (out, sizeof(*req->resultSetList)*
req->num_resultSetList);
}
else
{
- *req->deleteFunction = Z_DeleteRequest_all;
+ *req->deleteFunction = Z_DeleteResultSetRequest_all;
req->resultSetList = 0;
}
printf("Target doesn't support cancel (trigger resource ctrl)\n");
return 0;
}
- *req->requestedAction = Z_TriggerResourceCtrl_cancel;
+ *req->requestedAction = Z_TriggerResourceControlRequest_cancel;
req->resultSetWanted = &rfalse;
+ req->referenceId = set_refid (out);
send_apdu(apdu);
printf("Sent cancel request\n");
return 2;
}
+
+int cmd_cancel_find(const char *arg) {
+ int fres;
+ fres=cmd_find(arg);
+ if( fres > 0 ) {
+ return cmd_cancel("");
+ };
+ return fres;
+}
+
int send_scanrequest(const char *query, int pp, int num, const char *term)
{
Z_APDU *apdu = zget_APDU(out, Z_APDU_scanRequest);
printf("Received SortResponse: status=");
switch (*res->sortStatus)
{
- case Z_SortStatus_success:
+ case Z_SortResponse_success:
printf ("success"); break;
- case Z_SortStatus_partial_1:
+ case Z_SortResponse_partial_1:
printf ("partial"); break;
- case Z_SortStatus_failure:
+ case Z_SortResponse_failure:
printf ("failure"); break;
default:
printf ("unknown (%d)", *res->sortStatus);
{
/* first should open the file and read one line at a time.. */
FILE* includeFile;
- char line[1024], *cp;
+ char line[102400], *cp;
if(strlen(arg)<1) {
fprintf(stderr,"Error in source command use a filename\n");
printf (" schema=%s", rec->recordSchema);
printf ("\n");
if (rec->recordData_buf && rec->recordData_len)
+ {
fwrite(rec->recordData_buf, 1, rec->recordData_len, stdout);
+ if (marc_file)
+ fwrite (rec->recordData_buf, 1, rec->recordData_len, marc_file);
+ }
else
printf ("No data!");
printf("\n");
{"status", cmd_status, "",NULL,0,NULL},
{"setnames", cmd_setnames, "",NULL,0,NULL},
{"cancel", cmd_cancel, "",NULL,0,NULL},
+ {"cancel_find", cmd_cancel_find, "<query>",NULL,0,NULL},
{"format", cmd_format, "<recordsyntax>",complete_format,0,NULL},
{"schema", cmd_schema, "<schema>",complete_schema,0,NULL},
{"elements", cmd_elements, "<elementSetName>",NULL,0,NULL},
void process_cmd_line(char* line)
{
int i,res;
- char word[32], arg[1024];
+ char word[32], arg[10240];
#if HAVE_GETTIMEOFDAY
gettimeofday (&tv_start, 0);
#endif
- if ((res = sscanf(line, "%31s %1023[^;]", word, arg)) <= 0)
+ if ((res = sscanf(line, "%31s %10239[^;]", word, arg)) <= 0)
{
strcpy(word, last_cmd);
*arg = '\0';
rl_attempted_completion_over = 1;
return res;
} else {
- char arg[1024],word[32];
+ char arg[10240],word[32];
int i=0 ,res;
- if ((res = sscanf(rl_line_buffer, "%31s %1023[^;]", word, arg)) <= 0) {
+ if ((res = sscanf(rl_line_buffer, "%31s %10239[^;]", word, arg)) <= 0) {
rl_attempted_completion_over = 1;
return NULL;
}
static void client(void)
{
- char line[1024];
+ char line[10240];
- line[1023] = '\0';
+ line[10239] = '\0';
#if HAVE_GETTIMEOFDAY
gettimeofday (&tv_start, 0);
if (*line_in)
add_history(line_in);
#endif
- strncpy(line, line_in, 1023);
+ strncpy(line, line_in, 10239);
free (line_in);
}
#endif
char *end_p;
printf (C_PROMPT);
fflush(stdout);
- if (!fgets(line, 1023, stdin))
+ if (!fgets(line, 10239, stdin))
break;
if ((end_p = strchr (line, '\n')))
*end_p = '\0';