Files correlati : Commento : - Creazione nuova cartella per contenere tutte le librerie esterne - Aggiunta nuova libreria sqlapi per interfacciare campo a vari DB git-svn-id: svn://10.65.10.50/branches/R_10_00@24149 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			201 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			201 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Copyright (c) 1992, 2006, Oracle. All rights reserved.  */
 | |
| 
 | |
| /*
 | |
|    NAME
 | |
|      xa.h - <one-line expansion of the name>
 | |
|    DESCRIPTION
 | |
|      <short description of component this file declares/defines>
 | |
|    PUBLIC FUNCTION(S)
 | |
|      <list of external functions declared/defined - with one-line descriptions>
 | |
|    PRIVATE FUNCTION(S)
 | |
|      <list of static functions defined in .c file - with one-line descriptions>
 | |
|    RETURNS
 | |
|      <function return values, for .c file with single function>
 | |
|    NOTES
 | |
|      <other useful comments, qualifications, etc.>
 | |
|      
 | |
|      This is the public XA .h file
 | |
| 
 | |
|    MODIFIED   (MM/DD/YY)
 | |
|     yohu       08/27/06  - XA/RAC project changes: XAER_AFFINITY
 | |
|     dmukhin    06/29/05  - ANSI prototypes; miscellaneous cleanup 
 | |
|     whe        09/01/99 -  976457:check __cplusplus for C++ code
 | |
|     ntang      10/20/98 -  Remove TMCACHE & TMFORCL
 | |
|     abhide     08/04/97 -  implement xaoforcl
 | |
|     abhide     07/23/97 -  XA OTS project changes
 | |
|     schandra   02/20/96 -  lint
 | |
|     abhide     04/07/94 -  merge changes from branch 1.1.710.1
 | |
|     abhide     02/14/94 -  Creation
 | |
|     abhide     02/10/94 -  Creation
 | |
|     abhide     02/10/94 -  Creation
 | |
| */
 | |
| /*
 | |
|  * xa.h header
 | |
|  *      Typed in from X/Open doc of March 13, 1990
 | |
|  *      Updated to Parsippany II draft, March, 1991
 | |
|  *      Updated to Co Review draft, 19 Sep 1991
 | |
|  */
 | |
| 
 | |
| #ifndef XA_H
 | |
| #define XA_H
 | |
| 
 | |
| 
 | |
| /* 
 | |
|  * Transaction branch identification: XID and NULLXID:
 | |
|  */
 | |
| 
 | |
| 
 | |
| #define XIDDATASIZE 128         /* size in bytes */
 | |
| #define MAXGTRIDSIZE    64      /* maximum size in bytes of gtrid */
 | |
| #define MAXBQUALSIZE    64      /* maximum size in bytes of bqual */
 | |
| struct xid_t {
 | |
|     long        formatID;       /* format identifier */
 | |
|     long        gtrid_length;   /* value from 1 through 64 */
 | |
|     long        bqual_length;   /* value from 1 through 64 */
 | |
|     char        data[XIDDATASIZE];
 | |
| };
 | |
| typedef struct xid_t XID;
 | |
| 
 | |
| /*
 | |
|  * A value of -1 in formatID means that the XID is null.
 | |
|  */
 | |
| /*
 | |
|  * Declarations of routines by which RMs call TMs:
 | |
|  */
 | |
| 
 | |
| int ax_reg(int, XID *, long);
 | |
| int ax_unreg(int, long);
 | |
| /*
 | |
|  * XA Switch Data Structure
 | |
|  */
 | |
| #define RMNAMESZ 32             /* length of resource manager name, */
 | |
|                                 /* including the null terminator */
 | |
| #define MAXINFOSIZE 256         /* maximum size in bytes of xa_info strings, */
 | |
|                                 /* including the null terminator */
 | |
| struct xa_switch_t {
 | |
|     char name[RMNAMESZ];        /* name of resource manager */
 | |
|     long flags;                 /* resource manager specific options */
 | |
|     long version;               /* must be 0 */
 | |
| 
 | |
|     int  (*xa_open_entry)(char *, int, long);   /*xa_open function pointer*/
 | |
|     int  (*xa_close_entry)(char *, int, long);  /*xa_close function pointer*/
 | |
|     int  (*xa_start_entry)(XID *, int, long);   /*xa_start function pointer*/
 | |
|     int  (*xa_end_entry)(XID *, int, long);     /*xa_end function pointer*/
 | |
|     int  (*xa_rollback_entry)(XID *, int, long);
 | |
|                                                /*xa_rollback function pointer*/
 | |
|     int  (*xa_prepare_entry)(XID *, int, long); /*xa_prepare function pointer*/
 | |
|     int  (*xa_commit_entry)(XID *, int, long);  /*xa_commit function pointer*/
 | |
|     int  (*xa_recover_entry)(XID *, long, int, long);
 | |
|                                                 /*xa_recover function pointer*/
 | |
|     int  (*xa_forget_entry)(XID *, int, long);  /*xa_forget function pointer*/
 | |
|     int  (*xa_complete_entry)(int *, int *, int, long);
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Flag definition for the RM switch
 | |
|  */
 | |
| #define TMNOFLAGS       0x00000000L     /* no resource manager features
 | |
|                                            selected */  
 | |
| #define TMREGISTER      0x00000001L     /* resource manager dynamically
 | |
|                                            registers */
 | |
| #define TMNOMIGRATE     0x00000002L     /* resource manager does not support
 | |
|                                            association migration */
 | |
| #define TMUSEASYNC      0x00000004L     /* resource manager supports
 | |
|                                            asynchronous operations */
 | |
| /*
 | |
|  * Flag definitions for xa_ and ax_ routines
 | |
|  */
 | |
| /* Use TMNOFLAGS, defined above, when not specifying other flags */
 | |
| #define TMASYNC         0x80000000L     /* perform routine asynchronously */
 | |
| #define TMONEPHASE      0x40000000L     /* caller is using one-phase commit
 | |
|                                         optimisation */
 | |
| #define TMFAIL          0x20000000L     /* dissociates caller and marks
 | |
|                                            transaction branch rollback-only */
 | |
| #define TMNOWAIT        0x10000000L     /* return if blocking condition
 | |
|                                            exists */
 | |
| #define TMRESUME        0x08000000L     /* caller is resuming association
 | |
|                                            with suspended transaction branch */
 | |
| #define TMSUCCESS       0x04000000L     /* dissociate caller from transaction
 | |
|                                         branch */
 | |
| #define TMSUSPEND       0x02000000L     /* caller is suspending, not ending,
 | |
|                                            association */
 | |
| #define TMSTARTRSCAN    0x01000000L     /* start a recovery scan */
 | |
| #define TMENDRSCAN      0x00800000L     /* end a recovery scan */
 | |
| #define TMMULTIPLE      0x00400000L     /* wait for any asynchronous
 | |
|                                            operation */
 | |
| #define TMJOIN          0x00200000L     /* caller is joining existing
 | |
|                                         transaction branch */
 | |
| #define TMMIGRATE       0x00100000L     /* caller intends to perform
 | |
|                                         migration */
 | |
| 
 | |
| /* 
 | |
|  * ax_() return codes (transaction manager reports to resource manager)
 | |
|  */
 | |
| #define TM_JOIN         2       /* caller is joining existing transaction
 | |
|                                 branch */
 | |
| #define TM_RESUME       1       /* caller is resuming association with
 | |
|                                    suspended transaction branch */
 | |
| #define TM_OK   0               /* normal execution */
 | |
| #define TMER_TMERR      -1      /* an error occurred in the transaction
 | |
|                                 manager */
 | |
| #define TMER_INVAL      -2      /* invalid arguments were given */
 | |
| #define TMER_PROTO      -3      /* routine invoked in an improper context */
 | |
| 
 | |
| /* 
 | |
|  * xa_() return codes (resource manager reports to transaction manager)
 | |
|  */
 | |
| #define XA_RBBASE       100             /* The inclusive lower bound of the
 | |
|                                            rollback codes */
 | |
| #define XA_RBROLLBACK   XA_RBBASE       /* The rollback was caused by an
 | |
|                                            unspecified reason */
 | |
| #define XA_RBCOMMFAIL   XA_RBBASE+1     /* The rollback was caused by a
 | |
|                                            communication failure */
 | |
| #define XA_RBDEADLOCK   XA_RBBASE+2     /* A deadlock was detected */
 | |
| #define XA_RBINTEGRITY  XA_RBBASE+3     /* A condition that violates the
 | |
|                                            integrity of the resources was
 | |
|                                            detected */
 | |
| #define XA_RBOTHER      XA_RBBASE+4     /* The resource manager rolled back the
 | |
|                                            transaction for a reason not on this
 | |
|                                            list */
 | |
| #define XA_RBPROTO      XA_RBBASE+5     /* A protocal error occurred in the
 | |
|                                            resource manager */
 | |
| #define XA_RBTIMEOUT    XA_RBBASE+6     /* A transaction branch took too long*/
 | |
| #define XA_RBTRANSIENT  XA_RBBASE+7     /* May retry the transaction branch */
 | |
| #define XA_RBEND        XA_RBTRANSIENT  /* The inclusive upper bound of the
 | |
|                                            rollback codes */
 | |
| 
 | |
| #define XA_NOMIGRATE    9               /* resumption must occur where
 | |
|                                            suspension occurred */
 | |
| #define XA_HEURHAZ      8               /* the transaction branch may have been
 | |
|                                            heuristically completed */
 | |
| #define XA_HEURCOM      7               /* the transaction branch has been
 | |
|                                            heuristically comitted */
 | |
| #define XA_HEURRB       6               /* the transaction branch has been
 | |
|                                            heuristically rolled back */
 | |
| #define XA_HEURMIX      5               /* the transaction branch has been
 | |
|                                            heuristically committed and rolled
 | |
|                                            back */
 | |
| #define XA_RETRY        4               /* routine returned with no effect
 | |
|                                            and may be re-issued */
 | |
| #define XA_RDONLY       3               /* the transaction was read-only
 | |
|                                            and has been committed */
 | |
| #define XA_OK           0               /* normal execution */
 | |
| #define XAER_ASYNC      -2              /* asynchronous operation already
 | |
|                                            outstanding */
 | |
| #define XAER_RMERR      -3              /* a resource manager error occurred
 | |
|                                         in the transaction branch */
 | |
| #define XAER_NOTA       -4              /* the XID is not valid */
 | |
| #define XAER_INVAL      -5              /* invalid arguments were given */
 | |
| #define XAER_PROTO      -6              /* routine invoked in an improper
 | |
|                                            context */
 | |
| #define XAER_RMFAIL     -7              /* resource manager unavailable */
 | |
| #define XAER_DUPID      -8              /* the XID already exists */
 | |
| #define XAER_OUTSIDE    -9              /* resource manager doing work */
 | |
|                                         /* outside global transaction */
 | |
| 
 | |
| #define XAER_AFFINITY   -10             /* XA on RAC: resumption must occur on
 | |
|                                            RAC instance where the transaction
 | |
|                                            branch was created */
 | |
|                                           
 | |
| #endif /* ifndef XA_H */
 |