/*
- * Copyright (C) 1995-1998, Index Data I/S
+ * Copyright (C) 1995-1999, Index Data
* See the file LICENSE for details.
* Sebastian Hammer, Adam Dickmeiss
*
* $Log: session.h,v $
- * Revision 1.14 1998-02-10 11:03:57 adam
+ * Revision 1.19 1999-04-20 09:56:48 adam
+ * Added 'name' paramter to encoder/decoder routines (typedef Odr_fun).
+ * Modified all encoders/decoders to reflect this change.
+ *
+ * Revision 1.18 1998/08/03 10:23:57 adam
+ * Fixed bug regarding Options for Sort.
+ *
+ * Revision 1.17 1998/07/20 12:38:43 adam
+ * Implemented delete result set service to server API.
+ *
+ * Revision 1.16 1998/03/31 11:07:45 adam
+ * Furhter work on UNIverse resource report.
+ * Added Extended Services handling in frontend server.
+ *
+ * Revision 1.15 1998/02/11 11:53:36 adam
+ * Changed code so that it compiles as C++.
+ *
+ * Revision 1.14 1998/02/10 11:03:57 adam
* Added support for extended handlers in backend server interface.
*
* Revision 1.13 1998/01/29 13:30:23 adam
#include <sys/types.h>
#include "eventl.h"
+typedef enum {
+ REQUEST_IDLE, /* the request is just sitting in the queue */
+ REQUEST_PENDING /* operation pending (b'end processing or network I/O*/
+ /* this list will have more elements when acc/res control is added */
+} request_state;
+
typedef struct request
{
int len_refid; /* length of referenceid */
char *refid; /* referenceid */
- enum {
- REQUEST_IDLE, /* the request is just sitting in the queue */
- REQUEST_PENDING /* operation pending (b'end processing or network I/O*/
- /* this list will have more elements when acc/res control is added */
- } state;
+ request_state state;
Z_APDU *request; /* Current request */
NMEM request_mem; /* memory handle for request */
/*
* association state.
*/
+typedef enum
+{
+ ASSOC_NEW, /* not initialized yet */
+ ASSOC_UP, /* normal operation */
+ ASSOC_DEAD /* dead. Close if input arrives */
+} association_state;
+
typedef struct association
{
IOCHAN client_chan; /* event-loop control */
void *backend; /* backend handle */
request_q incoming; /* Q of incoming PDUs */
request_q outgoing; /* Q of outgoing data buffers (enc. PDUs) */
- enum
- {
- ASSOC_NEW, /* not initialized yet */
- ASSOC_UP, /* normal operation */
- ASSOC_DEAD /* dead. Close if input arrives */
- } state;
+ association_state state;
/* session parameters */
int preferredMessageSize;
int (*bend_sort) ();
int (*bend_search) ();
int (*bend_present) ();
+ int (*bend_esrequest) ();
+ int (*bend_delete) ();
} association;
association *create_association(IOCHAN channel, COMSTACK link);
void request_enq(request_q *q, request *r);
request *request_head(request_q *q);
request *request_deq(request_q *q);
+request *request_deq_x(request_q *q, request *r);
void request_initq(request_q *q);
void request_delq(request_q *q);
request *request_get(request_q *q);