2015-01-19 18:55:25 +01:00
|
|
|
/*************** tabjson H Declares Source Code File (.H) **************/
|
2015-03-18 13:30:14 +01:00
|
|
|
/* Name: tabjson.h Version 1.1 */
|
2015-01-19 18:55:25 +01:00
|
|
|
/* */
|
|
|
|
/* (C) Copyright to the author Olivier BERTRAND 2014 - 2015 */
|
|
|
|
/* */
|
|
|
|
/* This file contains the JSON classes declares. */
|
|
|
|
/***********************************************************************/
|
|
|
|
#include "osutil.h"
|
|
|
|
#include "block.h"
|
|
|
|
#include "colblk.h"
|
|
|
|
#include "json.h"
|
|
|
|
|
|
|
|
enum JMODE {MODE_OBJECT, MODE_ARRAY, MODE_VALUE};
|
|
|
|
|
|
|
|
typedef class JSONDEF *PJDEF;
|
|
|
|
typedef class TDBJSON *PJTDB;
|
|
|
|
typedef class JSONCOL *PJCOL;
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* The JSON tree node. Can be an Object or an Array. */
|
|
|
|
/***********************************************************************/
|
|
|
|
typedef struct _jnode {
|
|
|
|
PSZ Key; // The key used for object
|
|
|
|
OPVAL Op; // Operator used for this node
|
|
|
|
PVAL CncVal; // To cont value used for OP_CNC
|
2015-01-30 10:57:00 +01:00
|
|
|
PVAL Valp; // The internal array VALUE
|
2015-01-19 18:55:25 +01:00
|
|
|
int Rank; // The rank in array
|
2015-05-01 15:59:12 +02:00
|
|
|
int Rx; // Read row number
|
|
|
|
int Nx; // Next to read row number
|
2015-01-19 18:55:25 +01:00
|
|
|
} JNODE, *PJNODE;
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* JSON table. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class JSONDEF : public DOSDEF { /* Table description */
|
|
|
|
friend class TDBJSON;
|
|
|
|
friend class TDBJSN;
|
2015-03-18 13:30:14 +01:00
|
|
|
friend class TDBJCL;
|
2015-05-26 01:02:33 +02:00
|
|
|
friend PQRYRES JSONColumns(PGLOBAL, char*, PTOS, bool);
|
2015-01-19 18:55:25 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
JSONDEF(void);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual const char *GetType(void) {return "JSON";}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual bool DefineAM(PGLOBAL g, LPCSTR am, int poff);
|
|
|
|
virtual PTDB GetTable(PGLOBAL g, MODE m);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Members
|
|
|
|
JMODE Jmode; /* MODE_OBJECT by default */
|
|
|
|
char *Objname; /* Name of first level object */
|
|
|
|
char *Xcol; /* Name of expandable column */
|
|
|
|
int Limit; /* Limit of multiple values */
|
|
|
|
int Pretty; /* Depends on file structure */
|
2015-03-18 13:30:14 +01:00
|
|
|
int Level; /* Used for catalog table */
|
2015-05-17 15:22:42 +02:00
|
|
|
int Base; /* Tne array index base */
|
2015-01-19 18:55:25 +01:00
|
|
|
bool Strict; /* Strict syntax checking */
|
|
|
|
}; // end of JSONDEF
|
|
|
|
|
|
|
|
/* -------------------------- TDBJSN class --------------------------- */
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the JSN Access Method class declaration. */
|
|
|
|
/* The table is a DOS file, each record being a JSON object. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class TDBJSN : public TDBDOS {
|
|
|
|
friend class JSONCOL;
|
2015-12-08 16:39:13 +01:00
|
|
|
friend class JSONDEF;
|
|
|
|
public:
|
2015-01-19 18:55:25 +01:00
|
|
|
// Constructor
|
|
|
|
TDBJSN(PJDEF tdp, PTXF txfp);
|
|
|
|
TDBJSN(TDBJSN *tdbp);
|
|
|
|
|
|
|
|
// Implementation
|
2015-04-17 20:05:41 +02:00
|
|
|
virtual AMT GetAmType(void) {return TYPE_AM_JSN;}
|
|
|
|
virtual bool SkipHeader(PGLOBAL g);
|
|
|
|
virtual PTDB Duplicate(PGLOBAL g) {return (PTDB)new(g) TDBJSN(this);}
|
2016-12-12 10:57:19 +01:00
|
|
|
PJSON GetRow(void) {return Row;}
|
|
|
|
void SetG(PGLOBAL g) {G = g;}
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Methods
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual PTDB Clone(PTABS t);
|
2015-04-17 20:05:41 +02:00
|
|
|
virtual PCOL MakeCol(PGLOBAL g, PCOLDEF cdp, PCOL cprec, int n);
|
2015-05-09 17:30:20 +02:00
|
|
|
virtual PCOL InsertSpecialColumn(PCOL colp);
|
2015-04-17 20:05:41 +02:00
|
|
|
virtual int RowNumber(PGLOBAL g, bool b = FALSE)
|
2015-05-17 15:22:42 +02:00
|
|
|
{return (b) ? M : N;}
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Database routines
|
2015-04-17 20:05:41 +02:00
|
|
|
virtual int Cardinality(PGLOBAL g);
|
|
|
|
virtual int GetMaxSize(PGLOBAL g);
|
|
|
|
virtual bool OpenDB(PGLOBAL g);
|
|
|
|
virtual int ReadDB(PGLOBAL g);
|
2015-12-08 16:39:13 +01:00
|
|
|
virtual bool PrepareWriting(PGLOBAL g);
|
|
|
|
virtual int WriteDB(PGLOBAL g);
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
protected:
|
2015-04-17 20:05:41 +02:00
|
|
|
PJSON FindRow(PGLOBAL g);
|
|
|
|
int MakeTopTree(PGLOBAL g, PJSON jsp);
|
|
|
|
|
2015-01-19 18:55:25 +01:00
|
|
|
// Members
|
2015-12-08 16:39:13 +01:00
|
|
|
PGLOBAL G; // Support of parse memory
|
|
|
|
PJSON Top; // The top JSON tree
|
|
|
|
PJSON Row; // The current row
|
|
|
|
PJSON Val; // The value of the current row
|
|
|
|
PJCOL Colp; // The multiple column
|
|
|
|
JMODE Jmode; // MODE_OBJECT by default
|
|
|
|
char *Objname; // The table object name
|
|
|
|
char *Xcol; // Name of expandable column
|
|
|
|
int Fpos; // The current row index
|
|
|
|
int N; // The current Rownum
|
|
|
|
int M; // Index of multiple value
|
|
|
|
int Limit; // Limit of multiple values
|
|
|
|
int Pretty; // Depends on file structure
|
|
|
|
int NextSame; // Same next row
|
|
|
|
int SameRow; // Same row nb
|
|
|
|
int Xval; // Index of expandable array
|
|
|
|
int B; // Array index base
|
|
|
|
bool Strict; // Strict syntax checking
|
|
|
|
bool Comma; // Row has final comma
|
2015-01-19 18:55:25 +01:00
|
|
|
}; // end of class TDBJSN
|
|
|
|
|
|
|
|
/* -------------------------- JSONCOL class -------------------------- */
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* Class JSONCOL: JSON access method column descriptor. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class JSONCOL : public DOSCOL {
|
|
|
|
friend class TDBJSN;
|
|
|
|
friend class TDBJSON;
|
|
|
|
public:
|
|
|
|
// Constructors
|
|
|
|
JSONCOL(PGLOBAL g, PCOLDEF cdp, PTDB tdbp, PCOL cprec, int i);
|
|
|
|
JSONCOL(JSONCOL *colp, PTDB tdbp); // Constructor used in copy process
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual int GetAmType(void) {return Tjp->GetAmType();}
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
virtual bool SetBuffer(PGLOBAL g, PVAL value, bool ok, bool check);
|
|
|
|
bool ParseJpath(PGLOBAL g);
|
|
|
|
virtual void ReadColumn(PGLOBAL g);
|
|
|
|
virtual void WriteColumn(PGLOBAL g);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
bool CheckExpand(PGLOBAL g, int i, PSZ nm, bool b);
|
|
|
|
bool SetArrayOptions(PGLOBAL g, char *p, int i, PSZ nm);
|
2015-02-11 21:39:41 +01:00
|
|
|
PVAL GetColumnValue(PGLOBAL g, PJSON row, int i);
|
|
|
|
PVAL ExpandArray(PGLOBAL g, PJAR arp, int n);
|
|
|
|
PVAL CalculateArray(PGLOBAL g, PJAR arp, int n);
|
|
|
|
PVAL MakeJson(PGLOBAL g, PJSON jsp);
|
2015-01-19 18:55:25 +01:00
|
|
|
void SetJsonValue(PGLOBAL g, PVAL vp, PJVAL val, int n);
|
2015-01-30 10:57:00 +01:00
|
|
|
PJSON GetRow(PGLOBAL g);
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Default constructor not to be used
|
|
|
|
JSONCOL(void) {}
|
|
|
|
|
|
|
|
// Members
|
2015-12-08 16:39:13 +01:00
|
|
|
PGLOBAL G; // Support of parse memory
|
|
|
|
TDBJSN *Tjp; // To the JSN table block
|
2015-01-19 18:55:25 +01:00
|
|
|
PVAL MulVal; // To value used by multiple column
|
|
|
|
char *Jpath; // The json path
|
2015-01-30 10:57:00 +01:00
|
|
|
JNODE *Nodes; // The intermediate objects
|
2015-01-19 18:55:25 +01:00
|
|
|
int Nod; // The number of intermediate objects
|
2015-01-30 10:57:00 +01:00
|
|
|
int Xnod; // Index of multiple values
|
2015-01-19 18:55:25 +01:00
|
|
|
bool Xpd; // True for expandable column
|
|
|
|
bool Parsed; // True when parsed
|
|
|
|
}; // end of class JSONCOL
|
|
|
|
|
|
|
|
/* -------------------------- TDBJSON class -------------------------- */
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the JSON Access Method class declaration. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class TDBJSON : public TDBJSN {
|
2015-12-08 16:39:13 +01:00
|
|
|
friend class JSONDEF;
|
|
|
|
friend class JSONCOL;
|
2015-01-19 18:55:25 +01:00
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
TDBJSON(PJDEF tdp, PTXF txfp);
|
|
|
|
TDBJSON(PJTDB tdbp);
|
|
|
|
|
|
|
|
// Implementation
|
|
|
|
virtual AMT GetAmType(void) {return TYPE_AM_JSON;}
|
|
|
|
virtual PTDB Duplicate(PGLOBAL g) {return (PTDB)new(g) TDBJSON(this);}
|
2015-04-17 20:05:41 +02:00
|
|
|
PJAR GetDoc(void) {return Doc;}
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Methods
|
2017-02-16 18:01:48 +01:00
|
|
|
virtual PTDB Clone(PTABS t);
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Database routines
|
|
|
|
virtual int Cardinality(PGLOBAL g);
|
|
|
|
virtual int GetMaxSize(PGLOBAL g);
|
|
|
|
virtual void ResetSize(void);
|
2015-02-25 11:59:00 +01:00
|
|
|
virtual int GetProgCur(void) {return N;}
|
2015-02-28 23:01:55 +01:00
|
|
|
virtual int GetRecpos(void);
|
|
|
|
virtual bool SetRecpos(PGLOBAL g, int recpos);
|
2015-01-19 18:55:25 +01:00
|
|
|
virtual bool OpenDB(PGLOBAL g);
|
|
|
|
virtual int ReadDB(PGLOBAL g);
|
|
|
|
virtual bool PrepareWriting(PGLOBAL g) {return false;}
|
|
|
|
virtual int WriteDB(PGLOBAL g);
|
|
|
|
virtual int DeleteDB(PGLOBAL g, int irc);
|
|
|
|
virtual void CloseDB(PGLOBAL g);
|
2015-04-17 20:05:41 +02:00
|
|
|
int MakeDocument(PGLOBAL g);
|
2015-01-19 18:55:25 +01:00
|
|
|
|
|
|
|
// Optimization routines
|
|
|
|
virtual int MakeIndex(PGLOBAL g, PIXDEF pxdf, bool add);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
int MakeNewDoc(PGLOBAL g);
|
|
|
|
|
|
|
|
// Members
|
|
|
|
PJAR Doc; // The document array
|
|
|
|
int Multiple; // 0: No 1: DIR 2: Section 3: filelist
|
|
|
|
bool Done; // True when document parsing is done
|
|
|
|
bool Changed; // After Update, Insert or Delete
|
|
|
|
}; // end of class TDBJSON
|
2015-03-18 13:30:14 +01:00
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the class declaration for the JSON catalog table. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class TDBJCL : public TDBCAT {
|
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
TDBJCL(PJDEF tdp);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Specific routines
|
|
|
|
virtual PQRYRES GetResult(PGLOBAL g);
|
|
|
|
|
|
|
|
// Members
|
2015-05-26 01:02:33 +02:00
|
|
|
PTOS Topt;
|
|
|
|
char *Db;
|
2015-03-18 13:30:14 +01:00
|
|
|
}; // end of class TDBJCL
|