Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
aa10789f
Commit
aa10789f
authored
Dec 11, 2020
by
Olivier Bertrand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
BSON development
parent
4eeadedc
Changes
6
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
249 additions
and
103 deletions
+249
-103
storage/connect/bson.h
storage/connect/bson.h
+1
-1
storage/connect/bsonudf.cpp
storage/connect/bsonudf.cpp
+0
-1
storage/connect/filamtxt.cpp
storage/connect/filamtxt.cpp
+169
-31
storage/connect/filamtxt.h
storage/connect/filamtxt.h
+12
-13
storage/connect/tabbson.cpp
storage/connect/tabbson.cpp
+64
-57
storage/connect/tabdos.cpp
storage/connect/tabdos.cpp
+3
-0
No files found.
storage/connect/bson.h
View file @
aa10789f
...
...
@@ -145,7 +145,7 @@ class BJSON : public BLOCK {
void
SetBigint
(
PBVAL
vlp
,
longlong
ll
);
void
SetFloat
(
PBVAL
vlp
,
double
f
);
void
SetBool
(
PBVAL
vlp
,
bool
b
);
void
Clear
(
PBVAL
vlp
)
{
vlp
->
N
=
0
;
vlp
->
Nd
=
0
;
vlp
->
Next
=
0
;
vlp
->
Type
=
TYPE_NULL
;
}
void
Clear
(
PBVAL
vlp
)
{
vlp
->
N
=
0
;
vlp
->
Nd
=
0
;
vlp
->
Next
=
0
;
}
bool
IsValueNull
(
PBVAL
vlp
);
bool
IsJson
(
PBVAL
vlp
)
{
return
(
vlp
->
Type
==
TYPE_JAR
||
vlp
->
Type
==
TYPE_JOB
);}
...
...
storage/connect/bsonudf.cpp
View file @
aa10789f
...
...
@@ -1737,7 +1737,6 @@ char *bfile_bjson(UDF_INIT *initid, UDF_ARGS *args, char *result,
ssize_t
len
,
newloc
;
size_t
lrecl
,
binszp
;
PBVAL
jsp
;
PBJNX
bnxp
;
PGLOBAL
g
=
(
PGLOBAL
)
initid
->
ptr
;
BDOC
doc
(
g
);
...
...
storage/connect/filamtxt.cpp
View file @
aa10789f
This diff is collapsed.
Click to expand it.
storage/connect/filamtxt.h
View file @
aa10789f
...
...
@@ -215,16 +215,16 @@ class DllExport BLKFAM : public DOSFAM {
/* This is the DOS/UNIX Access Method class declaration for binary */
/* files with variable record format (BJSON) */
/***********************************************************************/
class
DllExport
BINFAM
:
public
TXT
FAM
{
class
DllExport
BINFAM
:
public
DOS
FAM
{
public:
// Constructor
BINFAM
(
PDOSDEF
tdp
)
:
TXTFAM
(
tdp
)
{
BStream
=
NULL
;
Recsize
=
0
;}
BINFAM
(
PBINFAM
txfp
)
:
TXTFAM
(
txfp
)
{
BStream
=
txfp
->
BStream
;}
BINFAM
(
PDOSDEF
tdp
)
:
DOSFAM
(
tdp
)
{
Recsize
=
0
;}
BINFAM
(
PBINFAM
txfp
)
:
DOSFAM
(
txfp
)
{
Recsize
=
txfp
->
Recsize
;}
// Implementation
virtual
AMT
GetAmType
(
void
)
{
return
TYPE_AM_BIN
;}
virtual
int
GetPos
(
void
);
virtual
int
GetNextPos
(
void
);
//
virtual int GetPos(void);
//
virtual int GetNextPos(void);
virtual
PTXF
Duplicate
(
PGLOBAL
g
)
{
return
(
PTXF
)
new
(
g
)
BINFAM
(
this
);
}
// Methods
...
...
@@ -233,23 +233,22 @@ class DllExport BINFAM : public TXTFAM {
virtual
int
Cardinality
(
PGLOBAL
g
);
virtual
int
MaxBlkSize
(
PGLOBAL
g
,
int
s
)
{
return
s
;}
virtual
bool
AllocateBuffer
(
PGLOBAL
g
);
virtual
int
GetRowID
(
void
);
virtual
bool
RecordPos
(
PGLOBAL
g
);
virtual
bool
SetPos
(
PGLOBAL
g
,
int
recpos
);
//
virtual int GetRowID(void);
//
virtual bool RecordPos(PGLOBAL g);
//
virtual bool SetPos(PGLOBAL g, int recpos);
virtual
int
SkipRecord
(
PGLOBAL
g
,
bool
header
)
{
return
0
;}
virtual
bool
OpenTableFile
(
PGLOBAL
g
);
//
virtual bool OpenTableFile(PGLOBAL g);
virtual
int
ReadBuffer
(
PGLOBAL
g
);
virtual
int
WriteBuffer
(
PGLOBAL
g
);
virtual
int
DeleteRecords
(
PGLOBAL
g
,
int
irc
)
{
return
RC_FX
;}
//virtual int DeleteRecords(PGLOBAL g, int irc);
virtual
void
CloseTableFile
(
PGLOBAL
g
,
bool
abort
);
virtual
void
Rewind
(
void
);
protected:
//
protected:
//virtual int InitDelete(PGLOBAL g, int fpos, int spos);
// Members
FILE
*
BStream
;
// Points to Bin file structure
size_t
Recsize
;
// Length of last read record
size_t
Recsize
;
// Length of last read or next written record
};
// end of class BINFAM
#endif // __FILAMTXT_H
storage/connect/tabbson.cpp
View file @
aa10789f
...
...
@@ -1012,7 +1012,7 @@ PBVAL BCUTIL::GetRow(PGLOBAL g)
PBVAL
nwr
,
row
=
Tp
->
Row
;
for
(
int
i
=
0
;
i
<
nod
&&
row
;
i
++
)
{
if
(
nodes
[
i
+
1
].
Op
==
OP_XX
)
if
(
i
<
nod
-
1
&&
nodes
[
i
+
1
].
Op
==
OP_XX
)
break
;
else
switch
(
row
->
Type
)
{
case
TYPE_JOB
:
...
...
@@ -1411,28 +1411,30 @@ int TDBBSN::EstimatedLength(void)
/***********************************************************************/
bool
TDBBSN
::
OpenDB
(
PGLOBAL
g
)
{
TUSE
use
=
Use
;
if
(
Pretty
<
0
&&
Mode
==
MODE_UPDATE
)
{
sprintf
(
g
->
Message
,
"Mode %d NIY for Bjson"
,
Mode
);
return
true
;
}
// endif Mode
if
(
Use
==
USE_OPEN
)
{
/*******************************************************************/
/* Table already open replace it at its beginning.
*/
/* Table already open replace it at its beginning.
???
*/
/*******************************************************************/
Fpos
=
-
1
;
NextSame
=
0
;
SameRow
=
0
;
}
else
{
/*******************************************************************/
/* First opening. */
/*******************************************************************/
if
(
Mode
==
MODE_INSERT
)
switch
(
Jmode
)
{
case
MODE_OBJECT
:
Row
=
Bp
->
NewVal
(
TYPE_JOB
);
break
;
case
MODE_ARRAY
:
Row
=
Bp
->
NewVal
(
TYPE_JAR
);
break
;
case
MODE_VALUE
:
Row
=
Bp
->
NewVal
(
TYPE_JVAL
);
break
;
default:
sprintf
(
g
->
Message
,
"Invalid Jmode %d"
,
Jmode
);
}
// endif Use
/*********************************************************************/
/* Open according to logical input/output mode required. */
/*********************************************************************/
if
(
TDBDOS
::
OpenDB
(
g
))
return
true
;
}
// endswitch Jmode
}
// endif Use
if
(
use
==
USE_OPEN
)
return
false
;
if
(
Pretty
<
0
)
{
/*******************************************************************/
...
...
@@ -1441,45 +1443,45 @@ bool TDBBSN::OpenDB(PGLOBAL g)
xtrc
(
1
,
"JSN OpenDB: tdbp=%p tdb=R%d use=%d mode=%d
\n
"
,
this
,
Tdb_No
,
Use
,
Mode
);
if
(
Use
==
USE_OPEN
)
{
/*******************************************************************/
/* Table already open, just replace it at its beginning. */
/*******************************************************************/
if
(
!
To_Kindex
)
{
Txfp
->
Rewind
();
// see comment in Work.log
}
else
// Table is to be accessed through a sorted index table
To_Kindex
->
Reset
();
// TODO: NIY
return
false
;
}
// endif use
/*********************************************************************/
/* Open according to logical input/output mode required. */
/* Use conventionnal input/output functions. */
/*********************************************************************/
if
(
Txfp
->
OpenTableFile
(
g
))
return
true
;
Use
=
USE_OPEN
;
// Do it now in case we are recursively called
/*********************************************************************/
/* Lrecl is Ok. */
/*********************************************************************/
size_t
linelen
=
Lrecl
;
// Buffer
should be the first allocated thing in
G->Sarea
// Buffer
must be set to
G->Sarea
Txfp
->
AllocateBuffer
(
Bp
->
G
);
if
(
Mode
==
MODE_INSERT
)
Bp
->
SubSet
(
true
);
else
Bp
->
MemSave
();
To_Line
=
Txfp
->
GetBuf
();
memset
(
To_Line
,
0
,
linelen
);
Bp
->
MemSave
();
xtrc
(
1
,
"OpenJSN: R%hd mode=%d To_Line=%p
\n
"
,
Tdb_No
,
Mode
,
To_Line
);
}
else
if
(
TDBDOS
::
OpenDB
(
g
))
}
// endif Pretty
/***********************************************************************/
/* First opening. */
/***********************************************************************/
if
(
Mode
==
MODE_INSERT
)
{
switch
(
Jmode
)
{
case
MODE_OBJECT
:
Row
=
Bp
->
NewVal
(
TYPE_JOB
);
break
;
case
MODE_ARRAY
:
Row
=
Bp
->
NewVal
(
TYPE_JAR
);
break
;
case
MODE_VALUE
:
Row
=
Bp
->
NewVal
(
TYPE_JVAL
);
break
;
default:
sprintf
(
g
->
Message
,
"Invalid Jmode %d"
,
Jmode
);
return
true
;
}
// endswitch Jmode
Bp
->
MemSave
();
}
// endif Mode
if
(
Xcol
)
To_Filter
=
NULL
;
// Imcompatible
return
false
;
}
// end of OpenDB
/***********************************************************************/
...
...
@@ -1564,6 +1566,7 @@ int TDBBSN::ReadDB(PGLOBAL g)
/***********************************************************************/
bool
TDBBSN
::
PrepareWriting
(
PGLOBAL
g
)
{
if
(
Pretty
>=
0
)
{
PSZ
s
;
if
(
!
(
Top
=
Bp
->
MakeTopTree
(
g
,
Row
)))
...
...
@@ -1583,7 +1586,10 @@ bool TDBBSN::PrepareWriting(PGLOBAL g)
return
false
;
}
else
return
true
;
}
else
((
BINFAM
*
)
Txfp
)
->
Recsize
=
((
size_t
)
PlugSubAlloc
(
Bp
->
G
,
NULL
,
0
)
-
(
size_t
)
To_Line
);
return
false
;
}
// end of PrepareWriting
/***********************************************************************/
...
...
@@ -2034,6 +2040,7 @@ void BSONCOL::WriteColumn(PGLOBAL g)
else
Cp
->
AddArrayValue
(
row
,
jsp
);
break
;
case
TYPE_JOB
:
if
(
Nodes
[
Nod
-
1
].
Key
)
Cp
->
SetKeyValue
(
row
,
jsp
,
Nodes
[
Nod
-
1
].
Key
);
...
...
storage/connect/tabdos.cpp
View file @
aa10789f
...
...
@@ -2148,6 +2148,9 @@ bool TDBDOS::OpenDB(PGLOBAL g)
}
// endif use
if
(
Mode
==
MODE_DELETE
&&
!
Next
&&
Txfp
->
GetAmType
()
!=
TYPE_AM_DOS
#if defined(BSON_SUPPORT)
&&
Txfp
->
GetAmType
()
!=
TYPE_AM_BIN
#endif // BSON_SUPPORT
&&
Txfp
->
GetAmType
()
!=
TYPE_AM_MGO
)
{
// Delete all lines. Not handled in MAP or block mode
Txfp
=
new
(
g
)
DOSFAM
((
PDOSDEF
)
To_Def
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment