Annotation For xvfs-core.h

Origin for each line in xvfs-core.h from check-in 5583d77f1c:

3e44e1def1 2019-05-02    1: #ifndef XVFS_CORE_H_1B4B28D60EBAA11D5FF85642FA7CA22C29E8E817
3e44e1def1 2019-05-02    2: #define XVFS_CORE_H_1B4B28D60EBAA11D5FF85642FA7CA22C29E8E817 1
f74a2e47ab 2019-05-02    3: 
f74a2e47ab 2019-05-02    4: #include <tcl.h>
1ecab39ce5 2019-05-02    5: 
1ecab39ce5 2019-05-02    6: #define XVFS_PROTOCOL_VERSION 1
f74a2e47ab 2019-05-02    7: 
32b55a907b 2019-05-02    8: typedef const char **(*xvfs_proc_getChildren_t)(const char *path, Tcl_WideInt *count);
32b55a907b 2019-05-02    9: typedef const unsigned char *(*xvfs_proc_getData_t)(const char *path, Tcl_WideInt start, Tcl_WideInt *length);
daf25f5222 2019-05-03   10: typedef int (*xvfs_proc_getStat_t)(const char *path, Tcl_StatBuf *statBuf);
e5b6962adf 2019-05-02   11: 
149aa89b7d 2019-09-13   12: /*
149aa89b7d 2019-09-13   13:  * Interface for the filesystem to fill out before registering.
149aa89b7d 2019-09-13   14:  * The protocolVersion is provided first so that if this
149aa89b7d 2019-09-13   15:  * needs to change over time it can be appropriately handled.
149aa89b7d 2019-09-13   16:  */
e5b6962adf 2019-05-02   17: struct Xvfs_FSInfo {
e5b6962adf 2019-05-02   18: 	int                      protocolVersion;
d121970301 2019-05-02   19: 	const char               *name;
e5b6962adf 2019-05-02   20: 	xvfs_proc_getChildren_t  getChildrenProc;
e5b6962adf 2019-05-02   21: 	xvfs_proc_getData_t      getDataProc;
daf25f5222 2019-05-03   22: 	xvfs_proc_getStat_t      getStatProc;
e5b6962adf 2019-05-02   23: };
149aa89b7d 2019-09-13   24: 
149aa89b7d 2019-09-13   25: /*
149aa89b7d 2019-09-13   26:  * Error codes for various calls.  This is part of the ABI and must
149aa89b7d 2019-09-13   27:  * not be changed.
149aa89b7d 2019-09-13   28:  */
149aa89b7d 2019-09-13   29: #define XVFS_RV_ERR_ENOENT   (-8192)
149aa89b7d 2019-09-13   30: #define XVFS_RV_ERR_EINVAL   (-8193)
149aa89b7d 2019-09-13   31: #define XVFS_RV_ERR_EISDIR   (-8194)
149aa89b7d 2019-09-13   32: #define XVFS_RV_ERR_ENOTDIR  (-8195)
149aa89b7d 2019-09-13   33: #define XVFS_RV_ERR_EFAULT   (-8196)
5583d77f1c 2019-09-14   34: #define XVFS_RV_ERR_INTERNAL (-16383)
3e44e1def1 2019-05-02   35: 
3e44e1def1 2019-05-02   36: #define XVFS_REGISTER_INTERFACE(name) int name(Tcl_Interp *interp, struct Xvfs_FSInfo *fsInfo);
3e44e1def1 2019-05-02   37: 
3e44e1def1 2019-05-02   38: #if defined(XVFS_MODE_STANDALONE)
3e44e1def1 2019-05-02   39: /*
3e44e1def1 2019-05-02   40:  * In standalone mode, we just redefine calls to
3e44e1def1 2019-05-02   41:  * Xvfs_Register() to go to the xvfs_standalone_register()
3e44e1def1 2019-05-02   42:  * function
3e44e1def1 2019-05-02   43:  */
3e44e1def1 2019-05-02   44: #  define Xvfs_Register xvfs_standalone_register
b8cca3a6b4 2019-05-08   45: static XVFS_REGISTER_INTERFACE(Xvfs_Register)
3e44e1def1 2019-05-02   46: 
3e44e1def1 2019-05-02   47: #elif defined(XVFS_MODE_FLEXIBLE)
3e44e1def1 2019-05-02   48: /*
b8cca3a6b4 2019-05-08   49:  * In flexible mode, we just redefine calls to
b8cca3a6b4 2019-05-08   50:  * Xvfs_Register() to go to the xvfs_flexible_register()
b8cca3a6b4 2019-05-08   51:  * function which will either dispatch to a common
b8cca3a6b4 2019-05-08   52:  * core XVFS or use the xvfs_standalone_register()
b8cca3a6b4 2019-05-08   53:  * function as a standalone would.
3e44e1def1 2019-05-02   54:  */
3e44e1def1 2019-05-02   55: #  define Xvfs_Register xvfs_flexible_register
b8cca3a6b4 2019-05-08   56: static XVFS_REGISTER_INTERFACE(Xvfs_Register)
3e44e1def1 2019-05-02   57: 
3e44e1def1 2019-05-02   58: #elif defined(XVFS_MODE_CLIENT)
3e44e1def1 2019-05-02   59: /*
3e44e1def1 2019-05-02   60:  * In client mode we declare an external symbol named
3e44e1def1 2019-05-02   61:  * Xvfs_Register() that must be provided by the environment
3e44e1def1 2019-05-02   62:  * we are loaded into
3e44e1def1 2019-05-02   63:  */
3e44e1def1 2019-05-02   64: extern XVFS_REGISTER_INTERFACE(Xvfs_Register)
3e44e1def1 2019-05-02   65: 
3e44e1def1 2019-05-02   66: #elif defined(XVFS_MODE_SERVER)
3e44e1def1 2019-05-02   67: /*
3e44e1def1 2019-05-02   68:  * In server mode we are going to implementing Xvfs_Register()
3e44e1def1 2019-05-02   69:  * for flexible/client modes, just forward declare it
3e44e1def1 2019-05-02   70:  */
3e44e1def1 2019-05-02   71: XVFS_REGISTER_INTERFACE(Xvfs_Register)
3e44e1def1 2019-05-02   72: 
3e44e1def1 2019-05-02   73: #else
3e44e1def1 2019-05-02   74: #  error Unsupported XVFS_MODE
acfc5037c6 2019-05-02   75: #endif
acfc5037c6 2019-05-02   76: 
b8cca3a6b4 2019-05-08   77: /*
b8cca3a6b4 2019-05-08   78:  * In flexible or standalone mode, directly include what
b8cca3a6b4 2019-05-08   79:  * would otherwise be a separate translation unit, to
b8cca3a6b4 2019-05-08   80:  * avoid symbols leaking
b8cca3a6b4 2019-05-08   81:  */
b8cca3a6b4 2019-05-08   82: #if defined(XVFS_MODE_FLEXIBLE) || defined(XVFS_MODE_STANDALONE)
b8cca3a6b4 2019-05-08   83: #include <xvfs-core.c>
b8cca3a6b4 2019-05-08   84: #endif
1ecab39ce5 2019-05-02   85: 
1ecab39ce5 2019-05-02   86: #endif