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
0b624deb
Commit
0b624deb
authored
Jan 09, 2020
by
Olivier Bertrand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update to version 1.07 (as for MariaDB 10.2)
parent
0043593b
Changes
33
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
33 changed files
with
913 additions
and
721 deletions
+913
-721
storage/connect/CMakeLists.txt
storage/connect/CMakeLists.txt
+32
-21
storage/connect/array.cpp
storage/connect/array.cpp
+2
-2
storage/connect/connect.cc
storage/connect/connect.cc
+36
-33
storage/connect/connect.h
storage/connect/connect.h
+2
-0
storage/connect/csort.cpp
storage/connect/csort.cpp
+11
-11
storage/connect/ha_connect.cc
storage/connect/ha_connect.cc
+31
-43
storage/connect/jdbconn.cpp
storage/connect/jdbconn.cpp
+8
-3
storage/connect/mycat.cc
storage/connect/mycat.cc
+8
-103
storage/connect/mycat.h
storage/connect/mycat.h
+2
-2
storage/connect/myconn.cpp
storage/connect/myconn.cpp
+6
-6
storage/connect/odbconn.cpp
storage/connect/odbconn.cpp
+1
-1
storage/connect/plgdbsem.h
storage/connect/plgdbsem.h
+18
-11
storage/connect/reldef.cpp
storage/connect/reldef.cpp
+197
-81
storage/connect/reldef.h
storage/connect/reldef.h
+6
-3
storage/connect/restget.cpp
storage/connect/restget.cpp
+19
-23
storage/connect/tabcmg.cpp
storage/connect/tabcmg.cpp
+14
-9
storage/connect/tabdos.cpp
storage/connect/tabdos.cpp
+16
-7
storage/connect/tabdos.h
storage/connect/tabdos.h
+0
-1
storage/connect/tabfix.cpp
storage/connect/tabfix.cpp
+1
-1
storage/connect/tabfmt.cpp
storage/connect/tabfmt.cpp
+3
-2
storage/connect/tabjson.cpp
storage/connect/tabjson.cpp
+27
-17
storage/connect/tabmysql.cpp
storage/connect/tabmysql.cpp
+7
-2
storage/connect/tabodbc.cpp
storage/connect/tabodbc.cpp
+4
-2
storage/connect/tabrest.cpp
storage/connect/tabrest.cpp
+98
-26
storage/connect/tabrest.h
storage/connect/tabrest.h
+21
-0
storage/connect/tabutil.cpp
storage/connect/tabutil.cpp
+14
-2
storage/connect/tabutil.h
storage/connect/tabutil.h
+2
-1
storage/connect/tabvct.cpp
storage/connect/tabvct.cpp
+3
-0
storage/connect/tabxml.cpp
storage/connect/tabxml.cpp
+3
-1
storage/connect/valblk.cpp
storage/connect/valblk.cpp
+5
-3
storage/connect/value.cpp
storage/connect/value.cpp
+294
-289
storage/connect/xindex.cpp
storage/connect/xindex.cpp
+18
-14
storage/connect/xtable.h
storage/connect/xtable.h
+4
-1
No files found.
storage/connect/CMakeLists.txt
View file @
0b624deb
...
@@ -40,6 +40,10 @@ user_connect.h valblk.h value.h xindex.h xobject.h xtable.h)
...
@@ -40,6 +40,10 @@ user_connect.h valblk.h value.h xindex.h xobject.h xtable.h)
add_definitions
(
-DMARIADB -DFORCE_INIT_OF_VARS -Dconnect_EXPORTS
)
add_definitions
(
-DMARIADB -DFORCE_INIT_OF_VARS -Dconnect_EXPORTS
)
add_definitions
(
-DHUGE_SUPPORT -DGZ_SUPPORT
)
add_definitions
(
-DHUGE_SUPPORT -DGZ_SUPPORT
)
macro
(
DISABLE_WARNING W
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-error=
${
W
}
"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-
${
W
}
"
DEBUG
)
endmacro
()
#
#
# OS specific C flags, definitions and source files.
# OS specific C flags, definitions and source files.
...
@@ -47,14 +51,15 @@ add_definitions( -DHUGE_SUPPORT -DGZ_SUPPORT )
...
@@ -47,14 +51,15 @@ add_definitions( -DHUGE_SUPPORT -DGZ_SUPPORT )
IF
(
UNIX
)
IF
(
UNIX
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wall -Wmissing-declarations"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wall -Wmissing-declarations"
)
if
(
NOT WITH_WARNINGS
)
if
(
NOT WITH_WARNINGS
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-unused-function"
)
DISABLE_WARNING
(
"unused-function"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-unused-variable"
)
DISABLE_WARNING
(
"unused-variable"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-unused-value"
)
DISABLE_WARNING
(
"unused-value"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-parentheses"
)
DISABLE_WARNING
(
"parentheses"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-strict-aliasing"
)
DISABLE_WARNING
(
"strict-aliasing"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-misleading-indentation"
)
DISABLE_WARNING
(
"misleading-indentation"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-format-truncation"
)
DISABLE_WARNING
(
"format-truncation"
)
MY_CHECK_AND_SET_COMPILER_FLAG
(
"-Wno-implicit-fallthrough"
)
DISABLE_WARNING
(
"implicit-fallthrough"
)
DISABLE_WARNING
(
"type-limits"
)
endif
(
NOT WITH_WARNINGS
)
endif
(
NOT WITH_WARNINGS
)
add_definitions
(
-DUNIX -DLINUX -DUBUNTU
)
add_definitions
(
-DUNIX -DLINUX -DUBUNTU
)
...
@@ -68,10 +73,6 @@ ELSE(NOT UNIX)
...
@@ -68,10 +73,6 @@ ELSE(NOT UNIX)
tabwmi.cpp tabwmi.h tabmac.cpp tabmac.h macutil.cpp macutil.h
)
tabwmi.cpp tabwmi.h tabmac.cpp tabmac.h macutil.cpp macutil.h
)
# Add exception handling to the CONNECT project)
# Add exception handling to the CONNECT project)
SET
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
/EHsc"
)
SET
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
/EHsc"
)
SET
(
CMAKE_CXX_FLAGS_RELEASE
"
${
CMAKE_CXX_FLAGS_RELEASE
}
/MD"
)
SET
(
CMAKE_CXX_FLAGS_DEBUG
"
${
CMAKE_CXX_FLAGS_DEBUG
}
/MDd"
)
SET
(
CMAKE_CXX_FLAGS_RELWITHDEBINFO
"
${
CMAKE_CXX_FLAGS_RELWITHDEBINFO
}
/MD"
)
SET
(
CMAKE_CXX_FLAGS_MINSIZEREL
"
${
CMAKE_CXX_FLAGS_MINSIZEREL
}
/MD"
)
SET
(
IPHLPAPI_LIBRARY iphlpapi.lib
)
SET
(
IPHLPAPI_LIBRARY iphlpapi.lib
)
IF
(
MSVC
AND
(
CMAKE_CXX_COMPILER_ID MATCHES Clang
))
IF
(
MSVC
AND
(
CMAKE_CXX_COMPILER_ID MATCHES Clang
))
# Connect does not work with clang-cl
# Connect does not work with clang-cl
...
@@ -171,7 +172,8 @@ IF(CONNECT_WITH_ODBC)
...
@@ -171,7 +172,8 @@ IF(CONNECT_WITH_ODBC)
# the library 'libiodbc' gets compiled with 'sql'h.
# the library 'libiodbc' gets compiled with 'sql'h.
# This will also need changes in the sources (e.g. #include <isql.h>).
# This will also need changes in the sources (e.g. #include <isql.h>).
find_path
(
ODBC_INCLUDE_DIR sql.h
find_file
(
ODBC_INCLUDES sql.h
PATHS
/usr/include
/usr/include
/usr/include/odbc
/usr/include/odbc
/usr/local/include
/usr/local/include
...
@@ -181,7 +183,7 @@ IF(CONNECT_WITH_ODBC)
...
@@ -181,7 +183,7 @@ IF(CONNECT_WITH_ODBC)
#"C:/Program Files/Microsoft SDKs/Windows/v7.0A/include"
#"C:/Program Files/Microsoft SDKs/Windows/v7.0A/include"
#"C:/Program Files/Microsoft SDKs/Windows/v6.0a/include"
#"C:/Program Files/Microsoft SDKs/Windows/v6.0a/include"
#"C:/Program Files (x86)/Microsoft SDKs/Windows/v7.0A/include"
#"C:/Program Files (x86)/Microsoft SDKs/Windows/v7.0A/include"
DOC
"Specify the
directory containing
sql.h."
DOC
"Specify the
path to
sql.h."
)
)
find_library
(
ODBC_LIBRARY
find_library
(
ODBC_LIBRARY
...
@@ -200,9 +202,10 @@ IF(CONNECT_WITH_ODBC)
...
@@ -200,9 +202,10 @@ IF(CONNECT_WITH_ODBC)
DOC
"Specify the ODBC driver manager library here."
DOC
"Specify the ODBC driver manager library here."
)
)
mark_as_advanced
(
ODBC_LIBRARY ODBC_INCLUDE
_DIR
)
mark_as_advanced
(
ODBC_LIBRARY ODBC_INCLUDE
S
)
IF
(
ODBC_INCLUDE_DIR AND ODBC_LIBRARY
)
IF
(
ODBC_INCLUDES AND ODBC_LIBRARY
)
get_filename_component
(
ODBC_INCLUDE_DIR
"
${
ODBC_INCLUDES
}
"
PATH
)
set
(
CMAKE_REQUIRED_LIBRARIES
${
ODBC_LIBRARY
}
)
set
(
CMAKE_REQUIRED_LIBRARIES
${
ODBC_LIBRARY
}
)
set
(
CMAKE_REQUIRED_INCLUDES
${
ODBC_INCLUDE_DIR
}
)
set
(
CMAKE_REQUIRED_INCLUDES
${
ODBC_INCLUDE_DIR
}
)
CHECK_CXX_SOURCE_COMPILES
(
CHECK_CXX_SOURCE_COMPILES
(
...
@@ -316,19 +319,27 @@ OPTION(CONNECT_WITH_REST "Compile CONNECT storage engine with REST support" ON)
...
@@ -316,19 +319,27 @@ OPTION(CONNECT_WITH_REST "Compile CONNECT storage engine with REST support" ON)
IF
(
CONNECT_WITH_REST
)
IF
(
CONNECT_WITH_REST
)
MESSAGE
(
STATUS
"=====> REST support is ON"
)
MESSAGE
(
STATUS
"=====> REST support is ON"
)
FIND_PACKAGE
(
cpprestsdk
)
SET
(
CONNECT_SOURCES
${
CONNECT_SOURCES
}
tabrest.cpp tabrest.h
)
add_definitions
(
-DREST_SUPPORT
)
FIND_PACKAGE
(
cpprestsdk QUIET
)
IF
(
cpprestsdk_FOUND
)
IF
(
cpprestsdk_FOUND
)
MESSAGE
(
STATUS
"=====> cpprestsdk found"
)
IF
(
UNIX
)
IF
(
UNIX
)
# INCLUDE_DIRECTORIES(${CPPRESTSDK_INCLUDE_DIR})
# INCLUDE_DIRECTORIES(${CPPRESTSDK_INCLUDE_DIR})
# If needed edit next line to set the path to libcpprest.so
# If needed edit next line to set the path to libcpprest.so
SET
(
REST_LIBRARY -lcpprest
)
SET
(
REST_LIBRARY -lcpprest
)
MESSAGE
(
STATUS
${
REST_LIBRARY
}
)
MESSAGE
(
STATUS
${
REST_LIBRARY
}
)
ELSE
(
NOT UNIX
)
# Next line sets debug compile mode matching cpprest_2_10d.dll
# when it was binary installed (can be change later in Visual Studio)
# Comment it out if not needed depending on your cpprestsdk installation.
SET
(
CMAKE_CXX_FLAGS_DEBUG
"
${
CMAKE_CXX_FLAGS_DEBUG
}
/MDd"
)
ENDIF
(
UNIX
)
ENDIF
(
UNIX
)
SET
(
CONNECT_SOURCES
${
CONNECT_SOURCES
}
tabrest.cpp restget.cpp tabrest.h
)
# IF(REST_LIBRARY) why this? how about Windows
add_definitions
(
-DREST_SUPPORT
)
SET
(
CONNECT_SOURCES
${
CONNECT_SOURCES
}
restget.cpp
)
add_definitions
(
-DREST_SOURCE
)
# ENDIF()
ELSE
(
NOT cpprestsdk_FOUND
)
ELSE
(
NOT cpprestsdk_FOUND
)
MESSAGE
(
STATUS
"=====> cpprestsdk package not found"
)
#
MESSAGE(STATUS "=====> cpprestsdk package not found")
ENDIF
(
cpprestsdk_FOUND
)
ENDIF
(
cpprestsdk_FOUND
)
ENDIF
(
CONNECT_WITH_REST
)
ENDIF
(
CONNECT_WITH_REST
)
...
...
storage/connect/array.cpp
View file @
0b624deb
...
@@ -438,7 +438,7 @@ char *ARRAY::GetStringValue(int n)
...
@@ -438,7 +438,7 @@ char *ARRAY::GetStringValue(int n)
/***********************************************************************/
/***********************************************************************/
bool
ARRAY
::
Find
(
PVAL
valp
)
bool
ARRAY
::
Find
(
PVAL
valp
)
{
{
register
int
n
;
int
n
;
PVAL
vp
;
PVAL
vp
;
if
(
Type
!=
valp
->
GetType
())
{
if
(
Type
!=
valp
->
GetType
())
{
...
@@ -1042,7 +1042,7 @@ MULAR::MULAR(PGLOBAL g, int n) : CSORT(false)
...
@@ -1042,7 +1042,7 @@ MULAR::MULAR(PGLOBAL g, int n) : CSORT(false)
/***********************************************************************/
/***********************************************************************/
int
MULAR
::
Qcompare
(
int
*
i1
,
int
*
i2
)
int
MULAR
::
Qcompare
(
int
*
i1
,
int
*
i2
)
{
{
register
int
i
,
n
=
0
;
int
i
,
n
=
0
;
for
(
i
=
0
;
i
<
Narray
;
i
++
)
for
(
i
=
0
;
i
<
Narray
;
i
++
)
if
((
n
=
Pars
[
i
]
->
Qcompare
(
i1
,
i2
)))
if
((
n
=
Pars
[
i
]
->
Qcompare
(
i1
,
i2
)))
...
...
storage/connect/connect.cc
View file @
0b624deb
...
@@ -16,7 +16,7 @@
...
@@ -16,7 +16,7 @@
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA */
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA */
/***********************************************************************/
/***********************************************************************/
/* Author Olivier BERTRAND bertrandop@gmail.com 2004-201
7
*/
/* Author Olivier BERTRAND bertrandop@gmail.com 2004-201
9
*/
/* */
/* */
/* WHAT THIS PROGRAM DOES: */
/* WHAT THIS PROGRAM DOES: */
/* ----------------------- */
/* ----------------------- */
...
@@ -389,6 +389,9 @@ RCODE EvalColumns(PGLOBAL g, PTDB tdbp, bool reset, bool mrr)
...
@@ -389,6 +389,9 @@ RCODE EvalColumns(PGLOBAL g, PTDB tdbp, bool reset, bool mrr)
try
{
try
{
for
(
colp
=
tdbp
->
GetColumns
();
rc
==
RC_OK
&&
colp
;
for
(
colp
=
tdbp
->
GetColumns
();
rc
==
RC_OK
&&
colp
;
colp
=
colp
->
GetNext
())
{
colp
=
colp
->
GetNext
())
{
xtrc
(
2
,
"Going to read column %s of table %s
\n
"
,
colp
->
GetName
(),
tdbp
->
GetName
());
if
(
reset
)
if
(
reset
)
colp
->
Reset
();
colp
->
Reset
();
...
@@ -563,7 +566,7 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
...
@@ -563,7 +566,7 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
rc
=
tdbp
->
DeleteDB
(
g
,
RC_EF
);
// Specific A.M. delete routine
rc
=
tdbp
->
DeleteDB
(
g
,
RC_EF
);
// Specific A.M. delete routine
}
else
if
(
tdbp
->
GetMode
()
==
MODE_UPDATE
&&
tdbp
->
IsIndexed
())
}
else
if
(
tdbp
->
GetMode
()
==
MODE_UPDATE
&&
tdbp
->
IsIndexed
())
rc
=
((
PTDBDO
X
)
tdbp
)
->
Txfp
->
UpdateSortedRows
(
g
);
rc
=
((
PTDBDO
S
)
tdbp
)
->
GetTxfp
()
->
UpdateSortedRows
(
g
);
switch
(
rc
)
{
switch
(
rc
)
{
case
RC_FX
:
case
RC_FX
:
...
@@ -590,7 +593,7 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
...
@@ -590,7 +593,7 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
if
(
!
tdbp
->
IsRemote
())
{
if
(
!
tdbp
->
IsRemote
())
{
// Make all the eventual indexes
// Make all the eventual indexes
PTDBDO
X
tbxp
=
(
PTDBDOX
)
tdbp
;
PTDBDO
S
tbxp
=
(
PTDBDOS
)
tdbp
;
tbxp
->
ResetKindex
(
g
,
NULL
);
tbxp
->
ResetKindex
(
g
,
NULL
);
tbxp
->
SetKey_Col
(
NULL
);
tbxp
->
SetKey_Col
(
NULL
);
rc
=
tbxp
->
ResetTableOpt
(
g
,
true
,
tbxp
->
GetDef
()
->
Indexable
()
==
1
);
rc
=
tbxp
->
ResetTableOpt
(
g
,
true
,
tbxp
->
GetDef
()
->
Indexable
()
==
1
);
...
@@ -619,8 +622,8 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
...
@@ -619,8 +622,8 @@ int CntCloseTable(PGLOBAL g, PTDB tdbp, bool nox, bool abort)
int
CntIndexInit
(
PGLOBAL
g
,
PTDB
ptdb
,
int
id
,
bool
sorted
)
int
CntIndexInit
(
PGLOBAL
g
,
PTDB
ptdb
,
int
id
,
bool
sorted
)
{
{
PIXDEF
xdp
;
PIXDEF
xdp
;
PTDBDO
X
tdbp
;
PTDBDO
S
tdbp
;
DO
X
DEF
*
dfp
;
DO
S
DEF
*
dfp
;
if
(
!
ptdb
)
if
(
!
ptdb
)
return
-
1
;
return
-
1
;
...
@@ -630,9 +633,9 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
...
@@ -630,9 +633,9 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
}
else
if
(
ptdb
->
GetDef
()
->
Indexable
()
==
3
)
{
}
else
if
(
ptdb
->
GetDef
()
->
Indexable
()
==
3
)
{
return
1
;
return
1
;
}
else
}
else
tdbp
=
(
PTDBDO
X
)
ptdb
;
tdbp
=
(
PTDBDO
S
)
ptdb
;
dfp
=
(
DO
XDEF
*
)
tdbp
->
To_Def
;
dfp
=
(
DO
SDEF
*
)
tdbp
->
GetDef
()
;
//if (!(k= colp->GetKey()))
//if (!(k= colp->GetKey()))
// if (colp->GetOpt() >= 2) {
// if (colp->GetOpt() >= 2) {
...
@@ -642,16 +645,16 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
...
@@ -642,16 +645,16 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
// This is a pseudo indexed sorted block optimized column
// This is a pseudo indexed sorted block optimized column
// return 0;
// return 0;
if
(
tdbp
->
To_Kindex
)
if
(
tdbp
->
GetKindex
()
)
if
(((
XXBASE
*
)
tdbp
->
To_Kindex
)
->
GetID
()
==
id
)
{
if
(((
XXBASE
*
)
tdbp
->
GetKindex
()
)
->
GetID
()
==
id
)
{
tdbp
->
To_Kindex
->
Reset
();
// Same index
tdbp
->
GetKindex
()
->
Reset
();
// Same index
return
(
tdbp
->
To_Kindex
->
IsMul
())
?
2
:
1
;
return
(
tdbp
->
GetKindex
()
->
IsMul
())
?
2
:
1
;
}
else
{
}
else
{
tdbp
->
To_Kindex
->
Close
();
tdbp
->
GetKindex
()
->
Close
();
tdbp
->
To_Kindex
=
NULL
;
tdbp
->
SetKindex
(
NULL
)
;
}
// endif colp
}
// endif colp
for
(
xdp
=
dfp
->
To_Indx
;
xdp
;
xdp
=
xdp
->
GetNext
())
for
(
xdp
=
dfp
->
GetIndx
()
;
xdp
;
xdp
=
xdp
->
GetNext
())
if
(
xdp
->
GetID
()
==
id
)
if
(
xdp
->
GetID
()
==
id
)
break
;
break
;
...
@@ -673,7 +676,7 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
...
@@ -673,7 +676,7 @@ int CntIndexInit(PGLOBAL g, PTDB ptdb, int id, bool sorted)
if
(
tdbp
->
InitialyzeIndex
(
g
,
xdp
,
sorted
))
if
(
tdbp
->
InitialyzeIndex
(
g
,
xdp
,
sorted
))
return
0
;
return
0
;
return
(
tdbp
->
To_Kindex
->
IsMul
())
?
2
:
1
;
return
(
tdbp
->
GetKindex
()
->
IsMul
())
?
2
:
1
;
}
// end of CntIndexInit
}
// end of CntIndexInit
#if defined(WORDS_BIGENDIAN)
#if defined(WORDS_BIGENDIAN)
...
@@ -707,7 +710,7 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
...
@@ -707,7 +710,7 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
int
n
,
x
;
int
n
,
x
;
RCODE
rc
;
RCODE
rc
;
XXBASE
*
xbp
;
XXBASE
*
xbp
;
PTDBDO
X
tdbp
;
PTDBDO
S
tdbp
;
if
(
!
ptdb
)
if
(
!
ptdb
)
return
RC_FX
;
return
RC_FX
;
...
@@ -733,12 +736,12 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
...
@@ -733,12 +736,12 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
goto
rnd
;
goto
rnd
;
}
else
}
else
tdbp
=
(
PTDBDO
X
)
ptdb
;
tdbp
=
(
PTDBDO
S
)
ptdb
;
// Set reference values and index operator
// Set reference values and index operator
if
(
!
tdbp
->
To_Link
||
!
tdbp
->
To_Kindex
)
{
if
(
!
tdbp
->
GetLink
()
||
!
tdbp
->
GetKindex
()
)
{
// if (!tdbp->To_Xdp) {
// if (!tdbp->To_Xdp) {
sprintf
(
g
->
Message
,
"Index not initialized for table %s"
,
tdbp
->
Name
);
sprintf
(
g
->
Message
,
"Index not initialized for table %s"
,
tdbp
->
GetName
()
);
return
RC_FX
;
return
RC_FX
;
#if 0
#if 0
} // endif !To_Xdp
} // endif !To_Xdp
...
@@ -751,7 +754,7 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
...
@@ -751,7 +754,7 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
#endif // 0
#endif // 0
}
// endif !To_Kindex
}
// endif !To_Kindex
xbp
=
(
XXBASE
*
)
tdbp
->
To_Kindex
;
xbp
=
(
XXBASE
*
)
tdbp
->
GetKindex
()
;
if
(
kr
)
{
if
(
kr
)
{
char
*
kp
=
(
char
*
)
kr
->
key
;
char
*
kp
=
(
char
*
)
kr
->
key
;
...
@@ -761,13 +764,13 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
...
@@ -761,13 +764,13 @@ RCODE CntIndexRead(PGLOBAL g, PTDB ptdb, OPVAL op,
PVAL
valp
;
PVAL
valp
;
PCOL
colp
;
PCOL
colp
;
for
(
n
=
0
;
n
<
tdbp
->
Knum
;
n
++
)
{
for
(
n
=
0
;
n
<
tdbp
->
GetKnum
()
;
n
++
)
{
colp
=
(
PCOL
)
tdbp
->
To_Key_Col
[
n
]
;
colp
=
(
PCOL
)
tdbp
->
Key
(
n
)
;
if
(
colp
->
GetColUse
(
U_NULLS
))
if
(
colp
->
GetColUse
(
U_NULLS
))
kp
++
;
// Skip null byte
kp
++
;
// Skip null byte
valp
=
tdbp
->
To_Link
[
n
]
->
GetValue
();
valp
=
tdbp
->
Link
(
n
)
->
GetValue
();
if
(
!
valp
->
IsTypeNum
())
{
if
(
!
valp
->
IsTypeNum
())
{
if
(
colp
->
GetColUse
(
U_VAR
))
{
if
(
colp
->
GetColUse
(
U_VAR
))
{
...
@@ -837,7 +840,7 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
...
@@ -837,7 +840,7 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
bool
b
,
rcb
;
bool
b
,
rcb
;
PVAL
valp
;
PVAL
valp
;
PCOL
colp
;
PCOL
colp
;
PTDBDO
X
tdbp
;
PTDBDO
S
tdbp
;
XXBASE
*
xbp
;
XXBASE
*
xbp
;
if
(
!
ptdb
)
if
(
!
ptdb
)
...
@@ -862,35 +865,35 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
...
@@ -862,35 +865,35 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
return
k
[
1
]
-
k
[
0
]
+
1
;
return
k
[
1
]
-
k
[
0
]
+
1
;
}
else
}
else
tdbp
=
(
PTDBDO
X
)
ptdb
;
tdbp
=
(
PTDBDO
S
)
ptdb
;
if
(
!
tdbp
->
To_Kindex
||
!
tdbp
->
To_Link
)
{
if
(
!
tdbp
->
GetKindex
()
||
!
tdbp
->
GetLink
()
)
{
if
(
!
tdbp
->
To_Xdp
)
{
if
(
!
tdbp
->
GetXdp
()
)
{
sprintf
(
g
->
Message
,
"Index not initialized for table %s"
,
tdbp
->
Name
);
sprintf
(
g
->
Message
,
"Index not initialized for table %s"
,
tdbp
->
GetName
()
);
DBUG_PRINT
(
"Range"
,
(
"%s"
,
g
->
Message
));
DBUG_PRINT
(
"Range"
,
(
"%s"
,
g
->
Message
));
return
-
1
;
return
-
1
;
}
else
// Dynamic index
}
else
// Dynamic index
return
tdbp
->
To_Xdp
->
GetMaxSame
();
// TODO a better estimate
return
tdbp
->
GetXdp
()
->
GetMaxSame
();
// TODO a better estimate
}
else
}
else
xbp
=
(
XXBASE
*
)
tdbp
->
To_Kindex
;
xbp
=
(
XXBASE
*
)
tdbp
->
GetKindex
()
;
for
(
b
=
false
,
i
=
0
;
i
<
2
;
i
++
)
{
for
(
b
=
false
,
i
=
0
;
i
<
2
;
i
++
)
{
p
=
kp
=
key
[
i
];
p
=
kp
=
key
[
i
];
if
(
kp
)
{
if
(
kp
)
{
for
(
n
=
0
;
n
<
tdbp
->
Knum
;
n
++
)
{
for
(
n
=
0
;
n
<
tdbp
->
GetKnum
()
;
n
++
)
{
if
(
kmap
[
i
]
&
(
key_part_map
)(
1
<<
n
))
{
if
(
kmap
[
i
]
&
(
key_part_map
)(
1
<<
n
))
{
if
(
b
==
true
)
if
(
b
==
true
)
// Cannot do indexing with missing intermediate key
// Cannot do indexing with missing intermediate key
return
-
1
;
return
-
1
;
colp
=
(
PCOL
)
tdbp
->
To_Key_Col
[
n
]
;
colp
=
(
PCOL
)
tdbp
->
Key
(
n
)
;
if
(
colp
->
GetColUse
(
U_NULLS
))
if
(
colp
->
GetColUse
(
U_NULLS
))
p
++
;
// Skip null byte ???
p
++
;
// Skip null byte ???
valp
=
tdbp
->
To_Link
[
n
]
->
GetValue
();
valp
=
tdbp
->
Link
(
n
)
->
GetValue
();
if
(
!
valp
->
IsTypeNum
())
{
if
(
!
valp
->
IsTypeNum
())
{
if
(
colp
->
GetColUse
(
U_VAR
))
{
if
(
colp
->
GetColUse
(
U_VAR
))
{
...
...
storage/connect/connect.h
View file @
0b624deb
...
@@ -46,6 +46,7 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
...
@@ -46,6 +46,7 @@ int CntIndexRange(PGLOBAL g, PTDB ptdb, const uchar* *key, uint *len,
bool
*
incl
,
key_part_map
*
kmap
);
bool
*
incl
,
key_part_map
*
kmap
);
PGLOBAL
CntExit
(
PGLOBAL
g
);
PGLOBAL
CntExit
(
PGLOBAL
g
);
#if 0
/***********************************************************************/
/***********************************************************************/
/* Definition of classes XKPDEF, DOXDEF, TDBDOX */
/* Definition of classes XKPDEF, DOXDEF, TDBDOX */
/* These classes purpose is chiefly to access protected items! */
/* These classes purpose is chiefly to access protected items! */
...
@@ -76,3 +77,4 @@ class XKPDEF: public KPARTDEF {
...
@@ -76,3 +77,4 @@ class XKPDEF: public KPARTDEF {
public:
public:
XKPDEF(const char *name, int n) : KPARTDEF((PSZ)name, n) {}
XKPDEF(const char *name, int n) : KPARTDEF((PSZ)name, n) {}
}; // end of class XKPDEF
}; // end of class XKPDEF
#endif // 0
storage/connect/csort.cpp
View file @
0b624deb
...
@@ -178,9 +178,9 @@ void CSORT::DebugSort(int ph, int n, int *base, int *mid, int *tmp)
...
@@ -178,9 +178,9 @@ void CSORT::DebugSort(int ph, int n, int *base, int *mid, int *tmp)
/***********************************************************************/
/***********************************************************************/
int
CSORT
::
Qsortx
(
void
)
int
CSORT
::
Qsortx
(
void
)
{
{
register
int
c
;
int
c
;
register
int
lo
,
hi
,
min
;
int
lo
,
hi
,
min
;
register
int
i
,
j
,
rc
=
0
;
int
i
,
j
,
rc
=
0
;
// To do: rc should be checked for being used uninitialized
// To do: rc should be checked for being used uninitialized
int
*
top
;
int
*
top
;
#ifdef DEBTRACE
#ifdef DEBTRACE
...
@@ -344,7 +344,7 @@ int CSORT::Qsortx(void)
...
@@ -344,7 +344,7 @@ int CSORT::Qsortx(void)
/***********************************************************************/
/***********************************************************************/
void
CSORT
::
Qstx
(
int
*
base
,
int
*
max
)
void
CSORT
::
Qstx
(
int
*
base
,
int
*
max
)
{
{
register
int
*
i
,
*
j
,
*
jj
,
*
mid
,
*
him
,
c
;
int
*
i
,
*
j
,
*
jj
,
*
mid
,
*
him
,
c
;
int
*
tmp
;
int
*
tmp
;
int
lo
,
hi
,
rc
;
int
lo
,
hi
,
rc
;
size_t
zlo
,
zhi
,
cnm
;
size_t
zlo
,
zhi
,
cnm
;
...
@@ -543,9 +543,9 @@ void CSORT::Qstx(int *base, int *max)
...
@@ -543,9 +543,9 @@ void CSORT::Qstx(int *base, int *max)
/***********************************************************************/
/***********************************************************************/
int
CSORT
::
Qsortc
(
void
)
int
CSORT
::
Qsortc
(
void
)
{
{
register
int
c
;
int
c
;
register
int
lo
,
hi
,
min
;
int
lo
,
hi
,
min
;
register
int
i
,
j
,
k
,
m
,
rc
=
0
;
int
i
,
j
,
k
,
m
,
rc
=
0
;
// To do: rc should be checked for being used uninitialized
// To do: rc should be checked for being used uninitialized
int
*
max
;
int
*
max
;
#ifdef DEBTRACE
#ifdef DEBTRACE
...
@@ -720,7 +720,7 @@ int CSORT::Qsortc(void)
...
@@ -720,7 +720,7 @@ int CSORT::Qsortc(void)
/***********************************************************************/
/***********************************************************************/
void
CSORT
::
Qstc
(
int
*
base
,
int
*
max
)
void
CSORT
::
Qstc
(
int
*
base
,
int
*
max
)
{
{
register
int
*
i
,
*
j
,
*
jj
,
*
lt
,
*
eq
,
*
gt
,
*
mid
;
int
*
i
,
*
j
,
*
jj
,
*
lt
,
*
eq
,
*
gt
,
*
mid
;
int
c
=
0
,
lo
,
hi
,
rc
;
int
c
=
0
,
lo
,
hi
,
rc
;
size_t
zlo
,
zhi
,
cnm
;
size_t
zlo
,
zhi
,
cnm
;
...
@@ -907,9 +907,9 @@ void CSORT::Qstc(int *base, int *max)
...
@@ -907,9 +907,9 @@ void CSORT::Qstc(int *base, int *max)
/***********************************************************************/
/***********************************************************************/
void
CSORT
::
Istc
(
int
*
base
,
int
*
hi
,
int
*
max
)
void
CSORT
::
Istc
(
int
*
base
,
int
*
hi
,
int
*
max
)
{
{
register
int
c
=
0
;
int
c
=
0
;
register
int
*
lo
;
int
*
lo
;
register
int
*
i
,
*
j
;
int
*
i
,
*
j
;
/*********************************************************************/
/*********************************************************************/
/* First put smallest element, which must be in the first THRESH, */
/* First put smallest element, which must be in the first THRESH, */
...
...
storage/connect/ha_connect.cc
View file @
0b624deb
...
@@ -170,9 +170,9 @@
...
@@ -170,9 +170,9 @@
#define JSONMAX 10 // JSON Default max grp size
#define JSONMAX 10 // JSON Default max grp size
extern
"C"
{
extern
"C"
{
char
version
[]
=
"Version 1.0
6.0010 June 01
, 2019"
;
char
version
[]
=
"Version 1.0
7.0001 November 12
, 2019"
;
#if defined(__WIN__)
#if defined(__WIN__)
char
compver
[]
=
"Version 1.0
6.0010
"
__DATE__
" "
__TIME__
;
char
compver
[]
=
"Version 1.0
7.0001
"
__DATE__
" "
__TIME__
;
char
slash
=
'\\'
;
char
slash
=
'\\'
;
#else // !__WIN__
#else // !__WIN__
char
slash
=
'/'
;
char
slash
=
'/'
;
...
@@ -1045,6 +1045,8 @@ TABTYPE ha_connect::GetRealType(PTOS pos)
...
@@ -1045,6 +1045,8 @@ TABTYPE ha_connect::GetRealType(PTOS pos)
case
TAB_REST
:
case
TAB_REST
:
type
=
TAB_NIY
;
type
=
TAB_NIY
;
break
;
break
;
default:
break
;
}
// endswitch type
}
// endswitch type
#endif // REST_SUPPORT
#endif // REST_SUPPORT
...
@@ -1341,7 +1343,7 @@ char *ha_connect::GetRealString(PCSZ s)
...
@@ -1341,7 +1343,7 @@ char *ha_connect::GetRealString(PCSZ s)
{
{
char
*
sv
;
char
*
sv
;
if
(
IsPartitioned
()
&&
s
&&
partname
&&
*
partname
)
{
if
(
IsPartitioned
()
&&
s
&&
*
partname
)
{
sv
=
(
char
*
)
PlugSubAlloc
(
xp
->
g
,
NULL
,
0
);
sv
=
(
char
*
)
PlugSubAlloc
(
xp
->
g
,
NULL
,
0
);
sprintf
(
sv
,
s
,
partname
);
sprintf
(
sv
,
s
,
partname
);
PlugSubAlloc
(
xp
->
g
,
NULL
,
strlen
(
sv
)
+
1
);
PlugSubAlloc
(
xp
->
g
,
NULL
,
strlen
(
sv
)
+
1
);
...
@@ -2964,10 +2966,12 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
...
@@ -2964,10 +2966,12 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
case
Item_func
:
:
LE_FUNC
:
vop
=
OP_LE
;
break
;
case
Item_func
:
:
LE_FUNC
:
vop
=
OP_LE
;
break
;
case
Item_func
:
:
GE_FUNC
:
vop
=
OP_GE
;
break
;
case
Item_func
:
:
GE_FUNC
:
vop
=
OP_GE
;
break
;
case
Item_func
:
:
GT_FUNC
:
vop
=
OP_GT
;
break
;
case
Item_func
:
:
GT_FUNC
:
vop
=
OP_GT
;
break
;
#if MYSQL_VERSION_ID > 100200
case
Item_func
:
:
LIKE_FUNC
:
case
Item_func
:
:
LIKE_FUNC
:
vop
=
OP_LIKE
;
vop
=
OP_LIKE
;
neg
=
((
Item_func_opt_neg
*
)
condf
)
->
negated
;
neg
=
((
Item_func_like
*
)
condf
)
->
negated
;
break
;
break
;
#endif // VERSION_ID > 100200
case
Item_func
:
:
ISNOTNULL_FUNC
:
case
Item_func
:
:
ISNOTNULL_FUNC
:
neg
=
true
;
neg
=
true
;
// fall through
// fall through
...
@@ -3095,7 +3099,7 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
...
@@ -3095,7 +3099,7 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
strncat
(
s
,
res
->
ptr
(),
res
->
length
());
strncat
(
s
,
res
->
ptr
(),
res
->
length
());
if
(
res
->
length
()
<
19
)
if
(
res
->
length
()
<
19
)
strcat
(
s
,
"1970-01-01 00:00:00"
+
res
->
length
()
);
strcat
(
s
,
&
"1970-01-01 00:00:00"
[
res
->
length
()]
);
strcat
(
s
,
"'}"
);
strcat
(
s
,
"'}"
);
break
;
break
;
...
@@ -3125,7 +3129,7 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
...
@@ -3125,7 +3129,7 @@ PCFIL ha_connect::CheckCond(PGLOBAL g, PCFIL filp, const Item *cond)
strncat
(
s
,
res
->
ptr
(),
res
->
length
());
strncat
(
s
,
res
->
ptr
(),
res
->
length
());
if
(
res
->
length
()
<
19
)
if
(
res
->
length
()
<
19
)
strcat
(
s
,
"1970-01-01 00:00:00"
+
res
->
length
()
);
strcat
(
s
,
&
"1970-01-01 00:00:00"
[
res
->
length
()]
);
strcat
(
s
,
"'}"
);
strcat
(
s
,
"'}"
);
break
;
break
;
...
@@ -3785,9 +3789,9 @@ int ha_connect::index_init(uint idx, bool sorted)
...
@@ -3785,9 +3789,9 @@ int ha_connect::index_init(uint idx, bool sorted)
active_index
=
MAX_KEY
;
active_index
=
MAX_KEY
;
rc
=
HA_ERR_INTERNAL_ERROR
;
rc
=
HA_ERR_INTERNAL_ERROR
;
}
else
if
(
tdbp
->
GetKindex
())
{
}
else
if
(
tdbp
->
GetKindex
())
{
if
(((
PTDBDO
X
)
tdbp
)
->
To_Kindex
->
GetNum_K
())
{
if
(((
PTDBDO
S
)
tdbp
)
->
GetKindex
()
->
GetNum_K
())
{
if
(
tdbp
->
GetFtype
()
!=
RECFM_NAF
)
if
(
tdbp
->
GetFtype
()
!=
RECFM_NAF
)
((
PTDBDO
X
)
tdbp
)
->
GetTxfp
()
->
ResetBuffer
(
g
);
((
PTDBDO
S
)
tdbp
)
->
GetTxfp
()
->
ResetBuffer
(
g
);
active_index
=
idx
;
active_index
=
idx
;
// } else { // Void table
// } else { // Void table
...
@@ -4503,34 +4507,13 @@ bool ha_connect::check_privileges(THD *thd, PTOS options, char *dbn, bool quick)
...
@@ -4503,34 +4507,13 @@ bool ha_connect::check_privileges(THD *thd, PTOS options, char *dbn, bool quick)
case
TAB_DIR
:
case
TAB_DIR
:
case
TAB_ZIP
:
case
TAB_ZIP
:
case
TAB_OEM
:
case
TAB_OEM
:
#ifdef NO_EMBEDDED_ACCESS_CHECKS
if
(
table
&&
table
->
pos_in_table_list
)
// if SELECT
return
false
;
{
#endif
Switch_to_definer_security_ctx
backup_ctx
(
thd
,
table
->
pos_in_table_list
);
return
check_global_access
(
thd
,
FILE_ACL
);
/*
}
Check FILE_ACL
else
If table or table->mdl_ticket is NULL - it's a DLL, e.g. CREATE TABLE.
return
check_global_access
(
thd
,
FILE_ACL
);
if the table has an MDL_EXCLUSIVE lock - it's a DDL too, e.g. the
insert step of CREATE ... SELECT.
Otherwise it's a DML, the table was normally opened, locked,
privilege were already checked, and table->grant.privilege is set.
With SQL SECURITY DEFINER, table->grant.privilege has definer's privileges.
Unless we're in prelocking mode, in this case table->grant.privilege
is only checked in start_stmt(), not in external_lock().
*/
if
(
!
table
||
!
table
->
mdl_ticket
||
table
->
mdl_ticket
->
get_type
()
==
MDL_EXCLUSIVE
)
return
check_access
(
thd
,
FILE_ACL
,
db
,
NULL
,
NULL
,
0
,
0
);
if
((
!
quick
&&
thd
->
lex
->
requires_prelocking
())
||
table
->
grant
.
privilege
&
FILE_ACL
)
return
false
;
status_var_increment
(
thd
->
status_var
.
access_denied_errors
);
my_error
(
access_denied_error_code
(
thd
->
password
),
MYF
(
0
),
thd
->
security_ctx
->
priv_user
,
thd
->
security_ctx
->
priv_host
,
(
thd
->
password
?
ER
(
ER_YES
)
:
ER
(
ER_NO
)));
return
true
;
case
TAB_ODBC
:
case
TAB_ODBC
:
case
TAB_JDBC
:
case
TAB_JDBC
:
case
TAB_MONGO
:
case
TAB_MONGO
:
...
@@ -5653,6 +5636,8 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
...
@@ -5653,6 +5636,8 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
case
TAB_CSV
:
case
TAB_CSV
:
ttp
=
TAB_REST
;
ttp
=
TAB_REST
;
break
;
break
;
default:
break
;
}
// endswitch type
}
// endswitch type
#endif // REST_SUPPORT
#endif // REST_SUPPORT
}
// endif ttp
}
// endif ttp
...
@@ -6062,7 +6047,7 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
...
@@ -6062,7 +6047,7 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
}
// endif !nblin
}
// endif !nblin
for
(
i
=
0
;
!
rc
&&
i
<
qrp
->
Nblin
;
i
++
)
{
for
(
i
=
0
;
!
rc
&&
i
<
qrp
->
Nblin
;
i
++
)
{
typ
=
len
=
prec
=
dec
=
0
;
typ
=
len
=
prec
=
dec
=
flg
=
0
;
tm
=
NOT_NULL_FLAG
;
tm
=
NOT_NULL_FLAG
;
cnm
=
(
char
*
)
"noname"
;
cnm
=
(
char
*
)
"noname"
;
dft
=
xtra
=
key
=
fmt
=
tn
=
NULL
;
dft
=
xtra
=
key
=
fmt
=
tn
=
NULL
;
...
@@ -6102,6 +6087,9 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
...
@@ -6102,6 +6087,9 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
if
(
crp
->
Kdata
->
GetIntValue
(
i
))
if
(
crp
->
Kdata
->
GetIntValue
(
i
))
tm
=
0
;
// Nullable
tm
=
0
;
// Nullable
break
;
case
FLD_FLAG
:
flg
=
crp
->
Kdata
->
GetIntValue
(
i
);
break
;
break
;
case
FLD_FORMAT
:
case
FLD_FORMAT
:
fmt
=
(
crp
->
Kdata
)
?
crp
->
Kdata
->
GetCharValue
(
i
)
:
NULL
;
fmt
=
(
crp
->
Kdata
)
?
crp
->
Kdata
->
GetCharValue
(
i
)
:
NULL
;
...
@@ -6233,7 +6221,7 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
...
@@ -6233,7 +6221,7 @@ static int connect_assisted_discovery(handlerton *, THD* thd,
// Now add the field
// Now add the field
if
(
add_field
(
&
sql
,
cnm
,
typ
,
prec
,
dec
,
key
,
tm
,
rem
,
dft
,
xtra
,
if
(
add_field
(
&
sql
,
cnm
,
typ
,
prec
,
dec
,
key
,
tm
,
rem
,
dft
,
xtra
,
fmt
,
0
,
dbf
,
v
))
fmt
,
flg
,
dbf
,
v
))
rc
=
HA_ERR_OUT_OF_MEM
;
rc
=
HA_ERR_OUT_OF_MEM
;
}
// endfor i
}
// endfor i
...
@@ -7379,14 +7367,14 @@ maria_declare_plugin(connect)
...
@@ -7379,14 +7367,14 @@ maria_declare_plugin(connect)
&
connect_storage_engine
,
&
connect_storage_engine
,
"CONNECT"
,
"CONNECT"
,
"Olivier Bertrand"
,
"Olivier Bertrand"
,
"Management of External Data (SQL/NOSQL/MED), including
many file forma
ts"
,
"Management of External Data (SQL/NOSQL/MED), including
Rest query resul
ts"
,
PLUGIN_LICENSE_GPL
,
PLUGIN_LICENSE_GPL
,
connect_init_func
,
/* Plugin Init */
connect_init_func
,
/* Plugin Init */
connect_done_func
,
/* Plugin Deinit */
connect_done_func
,
/* Plugin Deinit */
0x010
6
,
/* version number (1.06
) */
0x010
7
,
/* version number (1.07
) */
NULL
,
/* status variables */
NULL
,
/* status variables */
connect_system_variables
,
/* system variables */
connect_system_variables
,
/* system variables */
"1.0
6.0010
"
,
/* string version */
"1.0
7.0001
"
,
/* string version */
MariaDB_PLUGIN_MATURITY_STABLE
/* maturity */
MariaDB_PLUGIN_MATURITY_STABLE
/* maturity */
}
}
maria_declare_plugin_end
;
maria_declare_plugin_end
;
storage/connect/jdbconn.cpp
View file @
0b624deb
...
@@ -1196,9 +1196,14 @@ int JDBConn::GetResultSize(PCSZ sql, PCOL colp)
...
@@ -1196,9 +1196,14 @@ int JDBConn::GetResultSize(PCSZ sql, PCOL colp)
if
((
rc
=
ExecuteQuery
(
sql
))
!=
RC_OK
)
if
((
rc
=
ExecuteQuery
(
sql
))
!=
RC_OK
)
return
-
1
;
return
-
1
;
if
((
rc
=
Fetch
())
>
0
)
if
((
rc
=
Fetch
())
>
0
)
{
SetColumnValue
(
1
,
NULL
,
colp
->
GetValue
());
try
{
else
SetColumnValue
(
1
,
NULL
,
colp
->
GetValue
());
}
catch
(...)
{
return
-
4
;
}
// end catch
}
else
return
-
2
;
return
-
2
;
if
((
rc
=
Fetch
())
!=
0
)
if
((
rc
=
Fetch
())
!=
0
)
...
...
storage/connect/mycat.cc
View file @
0b624deb
...
@@ -95,7 +95,7 @@
...
@@ -95,7 +95,7 @@
#endif // ZIP_SUPPORT
#endif // ZIP_SUPPORT
#if defined(REST_SUPPORT)
#if defined(REST_SUPPORT)
#include "tabrest.h"
#include "tabrest.h"
#endif // R
est
_SUPPORT
#endif // R
EST
_SUPPORT
#include "mycat.h"
#include "mycat.h"
/***********************************************************************/
/***********************************************************************/
...
@@ -107,7 +107,6 @@ extern "C" HINSTANCE s_hModule; // Saved module handle
...
@@ -107,7 +107,6 @@ extern "C" HINSTANCE s_hModule; // Saved module handle
#if defined(JAVA_SUPPORT) || defined(CMGO_SUPPORT)
#if defined(JAVA_SUPPORT) || defined(CMGO_SUPPORT)
bool
MongoEnabled
(
void
);
bool
MongoEnabled
(
void
);
#endif // JAVA_SUPPORT || CMGO_SUPPORT
#endif // JAVA_SUPPORT || CMGO_SUPPORT
PQRYRES
OEMColumns
(
PGLOBAL
g
,
PTOS
topt
,
char
*
tab
,
char
*
db
,
bool
info
);
/***********************************************************************/
/***********************************************************************/
/* Get the plugin directory. */
/* Get the plugin directory. */
...
@@ -349,100 +348,6 @@ uint GetFuncID(const char *func)
...
@@ -349,100 +348,6 @@ uint GetFuncID(const char *func)
return
fnc
;
return
fnc
;
}
// end of GetFuncID
}
// end of GetFuncID
/***********************************************************************/
/* OEMColumn: Get table column info for an OEM table. */
/***********************************************************************/
PQRYRES
OEMColumns
(
PGLOBAL
g
,
PTOS
topt
,
char
*
tab
,
char
*
db
,
bool
info
)
{
typedef
PQRYRES
(
__stdcall
*
XCOLDEF
)
(
PGLOBAL
,
void
*
,
char
*
,
char
*
,
bool
);
const
char
*
module
,
*
subtype
;
char
c
,
soname
[
_MAX_PATH
],
getname
[
40
]
=
"Col"
;
#if defined(__WIN__)
HANDLE
hdll
;
/* Handle to the external DLL */
#else // !__WIN__
void
*
hdll
;
/* Handle for the loaded shared library */
#endif // !__WIN__
XCOLDEF
coldef
=
NULL
;
PQRYRES
qrp
=
NULL
;
module
=
topt
->
module
;
subtype
=
topt
->
subtype
;
if
(
!
module
||
!
subtype
)
return
NULL
;
/*********************************************************************/
/* Ensure that the .dll doesn't have a path. */
/* This is done to ensure that only approved dll from the system */
/* directories are used (to make this even remotely secure). */
/*********************************************************************/
if
(
check_valid_path
(
module
,
strlen
(
module
)))
{
strcpy
(
g
->
Message
,
"Module cannot contain a path"
);
return
NULL
;
}
else
PlugSetPath
(
soname
,
module
,
GetPluginDir
());
// The exported name is always in uppercase
for
(
int
i
=
0
;
;
i
++
)
{
c
=
subtype
[
i
];
getname
[
i
+
3
]
=
toupper
(
c
);
if
(
!
c
)
break
;
}
// endfor i
#if defined(__WIN__)
// Load the Dll implementing the table
if
(
!
(
hdll
=
LoadLibrary
(
soname
)))
{
char
buf
[
256
];
DWORD
rc
=
GetLastError
();
sprintf
(
g
->
Message
,
MSG
(
DLL_LOAD_ERROR
),
rc
,
soname
);
FormatMessage
(
FORMAT_MESSAGE_FROM_SYSTEM
|
FORMAT_MESSAGE_IGNORE_INSERTS
,
NULL
,
rc
,
0
,
(
LPTSTR
)
buf
,
sizeof
(
buf
),
NULL
);
strcat
(
strcat
(
g
->
Message
,
": "
),
buf
);
return
NULL
;
}
// endif hDll
// Get the function returning an instance of the external DEF class
if
(
!
(
coldef
=
(
XCOLDEF
)
GetProcAddress
((
HINSTANCE
)
hdll
,
getname
)))
{
sprintf
(
g
->
Message
,
MSG
(
PROCADD_ERROR
),
GetLastError
(),
getname
);
FreeLibrary
((
HMODULE
)
hdll
);
return
NULL
;
}
// endif coldef
#else // !__WIN__
const
char
*
error
=
NULL
;
// Load the desired shared library
if
(
!
(
hdll
=
dlopen
(
soname
,
RTLD_LAZY
)))
{
error
=
dlerror
();
sprintf
(
g
->
Message
,
MSG
(
SHARED_LIB_ERR
),
soname
,
SVP
(
error
));
return
NULL
;
}
// endif Hdll
// Get the function returning an instance of the external DEF class
if
(
!
(
coldef
=
(
XCOLDEF
)
dlsym
(
hdll
,
getname
)))
{
error
=
dlerror
();
sprintf
(
g
->
Message
,
MSG
(
GET_FUNC_ERR
),
getname
,
SVP
(
error
));
dlclose
(
hdll
);
return
NULL
;
}
// endif coldef
#endif // !__WIN__
// Just in case the external Get function does not set error messages
sprintf
(
g
->
Message
,
"Error getting column info from %s"
,
subtype
);
// Get the table column definition
qrp
=
coldef
(
g
,
topt
,
tab
,
db
,
info
);
#if defined(__WIN__)
FreeLibrary
((
HMODULE
)
hdll
);
#else // !__WIN__
dlclose
(
hdll
);
#endif // !__WIN__
return
qrp
;
}
// end of OEMColumns
/* ------------------------- Class CATALOG --------------------------- */
/* ------------------------- Class CATALOG --------------------------- */
/***********************************************************************/
/***********************************************************************/
...
@@ -483,10 +388,10 @@ void MYCAT::Reset(void)
...
@@ -483,10 +388,10 @@ void MYCAT::Reset(void)
/* GetTableDesc: retrieve a table descriptor. */
/* GetTableDesc: retrieve a table descriptor. */
/* Look for a table descriptor matching the name and type. */
/* Look for a table descriptor matching the name and type. */
/***********************************************************************/
/***********************************************************************/
P
REL
DEF
MYCAT
::
GetTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
P
TAB
DEF
MYCAT
::
GetTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
type
,
PRELDEF
*
)
LPCSTR
type
,
PRELDEF
*
)
{
{
P
REL
DEF
tdp
=
NULL
;
P
TAB
DEF
tdp
=
NULL
;
if
(
trace
(
1
))
if
(
trace
(
1
))
htrc
(
"GetTableDesc: name=%s am=%s
\n
"
,
tablep
->
GetName
(),
SVP
(
type
));
htrc
(
"GetTableDesc: name=%s am=%s
\n
"
,
tablep
->
GetName
(),
SVP
(
type
));
...
@@ -507,12 +412,12 @@ PRELDEF MYCAT::GetTableDesc(PGLOBAL g, PTABLE tablep,
...
@@ -507,12 +412,12 @@ PRELDEF MYCAT::GetTableDesc(PGLOBAL g, PTABLE tablep,
/* MakeTableDesc: make a table/view description. */
/* MakeTableDesc: make a table/view description. */
/* Note: caller must check if name already exists before calling it. */
/* Note: caller must check if name already exists before calling it. */
/***********************************************************************/
/***********************************************************************/
P
REL
DEF
MYCAT
::
MakeTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
am
)
P
TAB
DEF
MYCAT
::
MakeTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
am
)
{
{
TABTYPE
tc
;
TABTYPE
tc
;
LPCSTR
name
=
(
PSZ
)
PlugDup
(
g
,
tablep
->
GetName
());
LPCSTR
name
=
(
PSZ
)
PlugDup
(
g
,
tablep
->
GetName
());
LPCSTR
schema
=
(
PSZ
)
PlugDup
(
g
,
tablep
->
GetSchema
());
LPCSTR
schema
=
(
PSZ
)
PlugDup
(
g
,
tablep
->
GetSchema
());
P
REL
DEF
tdp
=
NULL
;
P
TAB
DEF
tdp
=
NULL
;
if
(
trace
(
1
))
if
(
trace
(
1
))
htrc
(
"MakeTableDesc: name=%s schema=%s am=%s
\n
"
,
htrc
(
"MakeTableDesc: name=%s schema=%s am=%s
\n
"
,
...
@@ -580,8 +485,8 @@ PRELDEF MYCAT::MakeTableDesc(PGLOBAL g, PTABLE tablep, LPCSTR am)
...
@@ -580,8 +485,8 @@ PRELDEF MYCAT::MakeTableDesc(PGLOBAL g, PTABLE tablep, LPCSTR am)
}
// endswitch
}
// endswitch
// Do make the table/view definition
// Do make the table/view definition
if
(
tdp
&&
tdp
->
Define
(
g
,
this
,
name
,
schema
,
am
))
if
(
tdp
&&
tdp
->
Define
(
g
,
this
,
name
,
schema
,
am
))
tdp
=
NULL
;
tdp
=
NULL
;
if
(
trace
(
1
))
if
(
trace
(
1
))
htrc
(
"Table %s made
\n
"
,
am
);
htrc
(
"Table %s made
\n
"
,
am
);
...
@@ -594,7 +499,7 @@ PRELDEF MYCAT::MakeTableDesc(PGLOBAL g, PTABLE tablep, LPCSTR am)
...
@@ -594,7 +499,7 @@ PRELDEF MYCAT::MakeTableDesc(PGLOBAL g, PTABLE tablep, LPCSTR am)
/***********************************************************************/
/***********************************************************************/
PTDB
MYCAT
::
GetTable
(
PGLOBAL
g
,
PTABLE
tablep
,
MODE
mode
,
LPCSTR
type
)
PTDB
MYCAT
::
GetTable
(
PGLOBAL
g
,
PTABLE
tablep
,
MODE
mode
,
LPCSTR
type
)
{
{
P
REL
DEF
tdp
;
P
TAB
DEF
tdp
;
PTDB
tdbp
=
NULL
;
PTDB
tdbp
=
NULL
;
// LPCSTR name= tablep->GetName();
// LPCSTR name= tablep->GetName();
...
...
storage/connect/mycat.h
View file @
0b624deb
...
@@ -102,14 +102,14 @@ class MYCAT : public CATALOG {
...
@@ -102,14 +102,14 @@ class MYCAT : public CATALOG {
// Methods
// Methods
void
Reset
(
void
);
void
Reset
(
void
);
bool
StoreIndex
(
PGLOBAL
,
PTABDEF
)
{
return
false
;}
// Temporary
bool
StoreIndex
(
PGLOBAL
,
PTABDEF
)
{
return
false
;}
// Temporary
P
REL
DEF
GetTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
P
TAB
DEF
GetTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
type
,
PRELDEF
*
prp
=
NULL
);
LPCSTR
type
,
PRELDEF
*
prp
=
NULL
);
PTDB
GetTable
(
PGLOBAL
g
,
PTABLE
tablep
,
PTDB
GetTable
(
PGLOBAL
g
,
PTABLE
tablep
,
MODE
mode
=
MODE_READ
,
LPCSTR
type
=
NULL
);
MODE
mode
=
MODE_READ
,
LPCSTR
type
=
NULL
);
void
ClearDB
(
PGLOBAL
g
);
void
ClearDB
(
PGLOBAL
g
);
protected:
protected:
P
REL
DEF
MakeTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
am
);
P
TAB
DEF
MakeTableDesc
(
PGLOBAL
g
,
PTABLE
tablep
,
LPCSTR
am
);
// Members
// Members
ha_connect
*
Hc
;
// The Connect handler
ha_connect
*
Hc
;
// The Connect handler
...
...
storage/connect/myconn.cpp
View file @
0b624deb
...
@@ -472,7 +472,7 @@ int MYSQLC::Open(PGLOBAL g, const char *host, const char *db,
...
@@ -472,7 +472,7 @@ int MYSQLC::Open(PGLOBAL g, const char *host, const char *db,
int
pt
,
const
char
*
csname
)
int
pt
,
const
char
*
csname
)
{
{
const
char
*
pipe
=
NULL
;
const
char
*
pipe
=
NULL
;
uint
cto
=
10
,
nrt
=
20
;
//uint
cto = 10, nrt = 20;
my_bool
my_true
=
1
;
my_bool
my_true
=
1
;
m_DB
=
mysql_init
(
NULL
);
m_DB
=
mysql_init
(
NULL
);
...
@@ -485,11 +485,11 @@ int MYSQLC::Open(PGLOBAL g, const char *host, const char *db,
...
@@ -485,11 +485,11 @@ int MYSQLC::Open(PGLOBAL g, const char *host, const char *db,
if
(
trace
(
1
))
if
(
trace
(
1
))
htrc
(
"MYSQLC Open: m_DB=%.4X size=%d
\n
"
,
m_DB
,
(
int
)
sizeof
(
*
m_DB
));
htrc
(
"MYSQLC Open: m_DB=%.4X size=%d
\n
"
,
m_DB
,
(
int
)
sizeof
(
*
m_DB
));
// Removed to do like FEDERATED do
// Removed to do like FEDERATED do
es
//mysql_options(m_DB, MYSQL_READ_DEFAULT_GROUP, "client-mariadb");
//mysql_options(m_DB, MYSQL_READ_DEFAULT_GROUP, "client-mariadb");
mysql_options
(
m_DB
,
MYSQL_OPT_USE_REMOTE_CONNECTION
,
NULL
);
//
mysql_options(m_DB, MYSQL_OPT_USE_REMOTE_CONNECTION, NULL);
mysql_options
(
m_DB
,
MYSQL_OPT_CONNECT_TIMEOUT
,
&
cto
);
//
mysql_options(m_DB, MYSQL_OPT_CONNECT_TIMEOUT, &cto);
mysql_options
(
m_DB
,
MYSQL_OPT_READ_TIMEOUT
,
&
nrt
);
//
mysql_options(m_DB, MYSQL_OPT_READ_TIMEOUT, &nrt);
//mysql_options(m_DB, MYSQL_OPT_WRITE_TIMEOUT, ...);
//mysql_options(m_DB, MYSQL_OPT_WRITE_TIMEOUT, ...);
#if defined(__WIN__)
#if defined(__WIN__)
...
@@ -879,7 +879,7 @@ MYSQL_FIELD *MYSQLC::GetNextField(void)
...
@@ -879,7 +879,7 @@ MYSQL_FIELD *MYSQLC::GetNextField(void)
PQRYRES
MYSQLC
::
GetResult
(
PGLOBAL
g
,
bool
pdb
)
PQRYRES
MYSQLC
::
GetResult
(
PGLOBAL
g
,
bool
pdb
)
{
{
PCSZ
fmt
;
PCSZ
fmt
;
char
*
name
,
v
;
char
*
name
,
v
=
0
;
int
n
;
int
n
;
bool
uns
;
bool
uns
;
PCOLRES
*
pcrp
,
crp
;
PCOLRES
*
pcrp
,
crp
;
...
...
storage/connect/odbconn.cpp
View file @
0b624deb
...
@@ -2279,7 +2279,7 @@ int ODBConn::GetCatInfo(CATPARM *cap)
...
@@ -2279,7 +2279,7 @@ int ODBConn::GetCatInfo(CATPARM *cap)
int
i
,
irc
;
int
i
,
irc
;
bool
b
;
bool
b
;
PCSZ
fnc
=
"Unknown"
;
PCSZ
fnc
=
"Unknown"
;
UWORD
n
;
UWORD
n
=
0
;
SWORD
ncol
,
len
,
tp
;
SWORD
ncol
,
len
,
tp
;
SQLULEN
crow
=
0
;
SQLULEN
crow
=
0
;
PQRYRES
qrp
=
cap
->
Qrp
;
PQRYRES
qrp
=
cap
->
Qrp
;
...
...
storage/connect/plgdbsem.h
View file @
0b624deb
...
@@ -149,16 +149,22 @@ enum AMT {TYPE_AM_ERROR = 0, /* Type not defined */
...
@@ -149,16 +149,22 @@ enum AMT {TYPE_AM_ERROR = 0, /* Type not defined */
TYPE_AM_MGO
=
194
,
/* MGO access method type no */
TYPE_AM_MGO
=
194
,
/* MGO access method type no */
TYPE_AM_OUT
=
200
};
/* Output relations (storage) */
TYPE_AM_OUT
=
200
};
/* Output relations (storage) */
enum
RECFM
{
RECFM_NAF
=
-
2
,
/* Not a file */
enum
RECFM
{
RECFM_DFLT
=
0
,
/* Default table type */
RECFM_OEM
=
-
1
,
/* OEM file access method */
RECFM_NAF
=
1
,
/* Not a file table */
RECFM_VAR
=
0
,
/* Varying length DOS files */
RECFM_OEM
=
2
,
/* OEM table */
RECFM_FIX
=
1
,
/* Fixed length DOS files */
RECFM_VAR
=
3
,
/* Varying length DOS files */
RECFM_BIN
=
2
,
/* Binary DOS files (also fixed) */
RECFM_FIX
=
4
,
/* Fixed length DOS files */
RECFM_VCT
=
3
,
/* VCT formatted files */
RECFM_BIN
=
5
,
/* Binary DOS files (also fixed) */
RECFM_ODBC
=
4
,
/* Table accessed via ODBC */
RECFM_DBF
=
6
,
/* DBase formatted file */
RECFM_JDBC
=
5
,
/* Table accessed via JDBC */
RECFM_CSV
=
7
,
/* CSV file */
RECFM_PLG
=
6
,
/* Table accessed via PLGconn */
RECFM_FMT
=
8
,
/* FMT formatted file */
RECFM_DBF
=
7
};
/* DBase formatted file */
RECFM_VCT
=
9
,
/* VCT formatted files */
RECFM_XML
=
10
,
/* XML formatted files */
RECFM_JASON
=
11
,
/* JASON formatted files */
RECFM_DIR
=
12
,
/* DIR table */
RECFM_ODBC
=
13
,
/* Table accessed via ODBC */
RECFM_JDBC
=
14
,
/* Table accessed via JDBC */
RECFM_PLG
=
15
};
/* Table accessed via PLGconn */
enum
MISC
{
DB_TABNO
=
1
,
/* DB routines in Utility Table */
enum
MISC
{
DB_TABNO
=
1
,
/* DB routines in Utility Table */
MAX_MULT_KEY
=
10
,
/* Max multiple key number */
MAX_MULT_KEY
=
10
,
/* Max multiple key number */
...
@@ -537,7 +543,8 @@ enum XFLD {FLD_NO = 0, /* Not a field definition item */
...
@@ -537,7 +543,8 @@ enum XFLD {FLD_NO = 0, /* Not a field definition item */
FLD_FORMAT
=
16
,
/* Field format */
FLD_FORMAT
=
16
,
/* Field format */
FLD_CAT
=
17
,
/* Table catalog */
FLD_CAT
=
17
,
/* Table catalog */
FLD_SCHEM
=
18
,
/* Table schema */
FLD_SCHEM
=
18
,
/* Table schema */
FLD_TABNAME
=
19
};
/* Column Table name */
FLD_TABNAME
=
19
,
/* Column Table name */
FLD_FLAG
=
20
};
/* Field flag (CONNECT specific) */
/***********************************************************************/
/***********************************************************************/
/* Result of last SQL noconv query. */
/* Result of last SQL noconv query. */
...
...
storage/connect/reldef.cpp
View file @
0b624deb
This diff is collapsed.
Click to expand it.
storage/connect/reldef.h
View file @
0b624deb
...
@@ -84,10 +84,12 @@ class DllExport TABDEF : public RELDEF { /* Logical table descriptor */
...
@@ -84,10 +84,12 @@ class DllExport TABDEF : public RELDEF { /* Logical table descriptor */
void
SetNext
(
PTABDEF
tdfp
)
{
Next
=
tdfp
;}
void
SetNext
(
PTABDEF
tdfp
)
{
Next
=
tdfp
;}
int
GetMultiple
(
void
)
{
return
Multiple
;}
int
GetMultiple
(
void
)
{
return
Multiple
;}
int
GetPseudo
(
void
)
{
return
Pseudo
;}
int
GetPseudo
(
void
)
{
return
Pseudo
;}
PCSZ
GetPath
(
void
);
RECFM
GetRecfm
(
void
)
{
return
Recfm
;}
PCSZ
GetPath
(
void
);
//PSZ GetPath(void)
//PSZ GetPath(void)
// {return (Database) ? (PSZ)Database : Cat->GetDataPath();}
// {return (Database) ? (PSZ)Database : Cat->GetDataPath();}
bool
SepIndex
(
void
)
{
return
GetBoolCatInfo
(
"SepIndex"
,
false
);}
RECFM
GetTableFormat
(
const
char
*
type
);
bool
SepIndex
(
void
)
{
return
GetBoolCatInfo
(
"SepIndex"
,
false
);}
bool
IsReadOnly
(
void
)
{
return
Read_Only
;}
bool
IsReadOnly
(
void
)
{
return
Read_Only
;}
virtual
AMT
GetDefType
(
void
)
{
return
TYPE_AM_TAB
;}
virtual
AMT
GetDefType
(
void
)
{
return
TYPE_AM_TAB
;}
virtual
PIXDEF
GetIndx
(
void
)
{
return
NULL
;}
virtual
PIXDEF
GetIndx
(
void
)
{
return
NULL
;}
...
@@ -108,7 +110,8 @@ class DllExport TABDEF : public RELDEF { /* Logical table descriptor */
...
@@ -108,7 +110,8 @@ class DllExport TABDEF : public RELDEF { /* Logical table descriptor */
// Members
// Members
PCSZ
Schema
;
/* Table schema (for ODBC) */
PCSZ
Schema
;
/* Table schema (for ODBC) */
PCSZ
Desc
;
/* Table description */
PCSZ
Desc
;
/* Table description */
uint
Catfunc
;
/* Catalog function ID */
RECFM
Recfm
;
/* File or table format */
uint
Catfunc
;
/* Catalog function ID */
int
Card
;
/* (max) number of rows in table */
int
Card
;
/* (max) number of rows in table */
int
Elemt
;
/* Number of rows in blocks or rowset */
int
Elemt
;
/* Number of rows in blocks or rowset */
int
Sort
;
/* Table already sorted ??? */
int
Sort
;
/* Table already sorted ??? */
...
...
storage/connect/restget.cpp
View file @
0b624deb
...
@@ -4,12 +4,6 @@
...
@@ -4,12 +4,6 @@
/***********************************************************************/
/***********************************************************************/
#include <cpprest/filestream.h>
#include <cpprest/filestream.h>
#include <cpprest/http_client.h>
#include <cpprest/http_client.h>
#if defined(MARIADB)
#include <my_global.h>
#else
#include "mini-global.h"
#define _OS_H_INCLUDED // Prevent os.h to be called
#endif
using
namespace
utility
::
conversions
;
// String conversions utilities
using
namespace
utility
::
conversions
;
// String conversions utilities
using
namespace
web
;
// Common features like URIs.
using
namespace
web
;
// Common features like URIs.
...
@@ -17,24 +11,26 @@ using namespace web::http; // Common HTTP functionality
...
@@ -17,24 +11,26 @@ using namespace web::http; // Common HTTP functionality
using
namespace
web
::
http
::
client
;
// HTTP client features
using
namespace
web
::
http
::
client
;
// HTTP client features
using
namespace
concurrency
::
streams
;
// Asynchronous streams
using
namespace
concurrency
::
streams
;
// Asynchronous streams
#include "global.h"
typedef
const
char
*
PCSZ
;
extern
"C"
int
restGetFile
(
char
*
m
,
bool
xt
,
PCSZ
http
,
PCSZ
uri
,
PCSZ
fn
);
/***********************************************************************/
/***********************************************************************/
/* Make a local copy of the requested file. */
/* Make a local copy of the requested file. */
/***********************************************************************/
/***********************************************************************/
int
restGetFile
(
PGLOBAL
g
,
PCSZ
http
,
PCSZ
uri
,
PCSZ
fn
)
int
restGetFile
(
char
*
m
,
bool
xt
,
PCSZ
http
,
PCSZ
uri
,
PCSZ
fn
)
{
{
int
rc
=
0
;
int
rc
=
0
;
bool
xt
=
trace
(
515
);
auto
fileStream
=
std
::
make_shared
<
ostream
>
();
auto
fileStream
=
std
::
make_shared
<
ostream
>
();
if
(
!
http
||
!
fn
)
{
if
(
!
http
||
!
fn
)
{
strcpy
(
g
->
Message
,
"Missing http or filename"
);
//strcpy(g->Message, "Missing http or filename");
return
2
;
strcpy
(
m
,
"Missing http or filename"
);
return
2
;
}
// endif
}
// endif
if
(
xt
)
if
(
xt
)
htrc
(
"restGetFile: fn=%s
\n
"
,
fn
);
fprintf
(
stderr
,
"restGetFile: fn=%s
\n
"
,
fn
);
// Open stream to output file.
// Open stream to output file.
pplx
::
task
<
void
>
requestTask
=
fstream
::
open_ostream
(
to_string_t
(
fn
))
pplx
::
task
<
void
>
requestTask
=
fstream
::
open_ostream
(
to_string_t
(
fn
))
...
@@ -42,7 +38,7 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
...
@@ -42,7 +38,7 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
*
fileStream
=
outFile
;
*
fileStream
=
outFile
;
if
(
xt
)
if
(
xt
)
htrc
(
"Outfile isopen=%d
\n
"
,
outFile
.
is_open
());
fprintf
(
stderr
,
"Outfile isopen=%d
\n
"
,
outFile
.
is_open
());
// Create http_client to send the request.
// Create http_client to send the request.
http_client
client
(
to_string_t
(
http
));
http_client
client
(
to_string_t
(
http
));
...
@@ -58,8 +54,8 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
...
@@ -58,8 +54,8 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
// Handle response headers arriving.
// Handle response headers arriving.
.
then
([
=
](
http_response
response
)
{
.
then
([
=
](
http_response
response
)
{
if
(
xt
)
if
(
xt
)
htrc
(
"Received response status code:%u
\n
"
,
fprintf
(
stderr
,
"Received response status code:%u
\n
"
,
response
.
status_code
());
response
.
status_code
());
// Write response body into the file.
// Write response body into the file.
return
response
.
body
().
read_to_end
(
fileStream
->
streambuf
());
return
response
.
body
().
read_to_end
(
fileStream
->
streambuf
());
...
@@ -68,27 +64,27 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
...
@@ -68,27 +64,27 @@ int restGetFile(PGLOBAL g, PCSZ http, PCSZ uri, PCSZ fn)
// Close the file stream.
// Close the file stream.
.
then
([
=
](
size_t
n
)
{
.
then
([
=
](
size_t
n
)
{
if
(
xt
)
if
(
xt
)
htrc
(
"Return size=%
u
\n
"
,
n
);
fprintf
(
stderr
,
"Return size=%z
u
\n
"
,
n
);
return
fileStream
->
close
();
return
fileStream
->
close
();
});
});
// Wait for all the outstanding I/O to complete and handle any exceptions
// Wait for all the outstanding I/O to complete and handle any exceptions
try
{
try
{
requestTask
.
wait
();
if
(
xt
)
if
(
xt
)
htrc
(
"In Wait
\n
"
);
fprintf
(
stderr
,
"Waiting
\n
"
);
requestTask
.
wait
();
}
catch
(
const
std
::
exception
&
e
)
{
}
catch
(
const
std
::
exception
&
e
)
{
if
(
xt
)
if
(
xt
)
htrc
(
"Error exception: %s
\n
"
,
e
.
what
());
fprintf
(
stderr
,
"Error exception: %s
\n
"
,
e
.
what
());
sprintf
(
g
->
Message
,
"Error exception: %s"
,
e
.
what
());
rc
=
1
;
sprintf
(
m
,
"Error exception: %s"
,
e
.
what
());
rc
=
1
;
}
// end try/catch
}
// end try/catch
if
(
xt
)
if
(
xt
)
htrc
(
"restget done: rc=%d
\n
"
,
rc
);
fprintf
(
stderr
,
"restget done: rc=%d
\n
"
,
rc
);
return
rc
;
return
rc
;
}
// end of restGetFile
}
// end of restGetFile
storage/connect/tabcmg.cpp
View file @
0b624deb
...
@@ -53,25 +53,30 @@ bool CMGDISC::FindInDoc(PGLOBAL g, bson_iter_t *iter, const bson_t *doc,
...
@@ -53,25 +53,30 @@ bool CMGDISC::FindInDoc(PGLOBAL g, bson_iter_t *iter, const bson_t *doc,
{
{
if
(
!
doc
||
bson_iter_init
(
iter
,
doc
))
{
if
(
!
doc
||
bson_iter_init
(
iter
,
doc
))
{
const
char
*
key
;
const
char
*
key
;
char
colname
[
65
];
char
colname
[
65
];
char
fmt
[
129
];
char
fmt
[
129
];
bool
newcol
;
bool
newcol
;
size_t
n
;
while
(
bson_iter_next
(
iter
))
{
while
(
bson_iter_next
(
iter
))
{
key
=
bson_iter_key
(
iter
);
key
=
bson_iter_key
(
iter
);
newcol
=
true
;
newcol
=
true
;
if
(
pcn
)
{
if
(
pcn
)
{
strncpy
(
colname
,
pcn
,
64
);
n
=
sizeof
(
colname
)
-
1
;
colname
[
64
]
=
0
;
strncpy
(
colname
,
pcn
,
n
);
strncat
(
strncat
(
colname
,
"_"
,
65
),
key
,
65
);
colname
[
n
]
=
0
;
n
-=
strlen
(
colname
);
strncat
(
strncat
(
colname
,
"_"
,
n
),
key
,
n
-
1
);
}
else
}
else
strcpy
(
colname
,
key
);
strcpy
(
colname
,
key
);
if
(
pfmt
)
{
if
(
pfmt
)
{
strncpy
(
fmt
,
pfmt
,
128
);
n
=
sizeof
(
fmt
)
-
1
;
fmt
[
128
]
=
0
;
strncpy
(
fmt
,
pfmt
,
n
);
strncat
(
strncat
(
fmt
,
"."
,
129
),
key
,
129
);
fmt
[
n
]
=
0
;
n
-=
strlen
(
fmt
);
strncat
(
strncat
(
fmt
,
"."
,
n
),
key
,
n
-
1
);
}
else
}
else
strcpy
(
fmt
,
key
);
strcpy
(
fmt
,
key
);
...
...
storage/connect/tabdos.cpp
View file @
0b624deb
...
@@ -45,7 +45,7 @@
...
@@ -45,7 +45,7 @@
#include "global.h"
#include "global.h"
#include "osutil.h"
#include "osutil.h"
#include "plgdbsem.h"
#include "plgdbsem.h"
#include "catalog.h"
//
#include "catalog.h"
#include "mycat.h"
#include "mycat.h"
#include "xindex.h"
#include "xindex.h"
#include "filamap.h"
#include "filamap.h"
...
@@ -161,7 +161,12 @@ bool DOSDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
...
@@ -161,7 +161,12 @@ bool DOSDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
//Last = GetIntCatInfo("Last", 0);
//Last = GetIntCatInfo("Last", 0);
Ending
=
GetIntCatInfo
(
"Ending"
,
CRLF
);
Ending
=
GetIntCatInfo
(
"Ending"
,
CRLF
);
if
(
Recfm
==
RECFM_FIX
||
Recfm
==
RECFM_BIN
)
{
if
(
Ending
<=
0
)
{
Ending
=
(
Recfm
==
RECFM_BIN
||
Recfm
==
RECFM_VCT
)
?
0
:
CRLF
;
SetIntCatInfo
(
"Ending"
,
Ending
);
}
// endif ending
if
(
Recfm
==
RECFM_FIX
||
Recfm
==
RECFM_BIN
)
{
Huge
=
GetBoolCatInfo
(
"Huge"
,
Cat
->
GetDefHuge
());
Huge
=
GetBoolCatInfo
(
"Huge"
,
Cat
->
GetDefHuge
());
Padded
=
GetBoolCatInfo
(
"Padded"
,
false
);
Padded
=
GetBoolCatInfo
(
"Padded"
,
false
);
Blksize
=
GetIntCatInfo
(
"Blksize"
,
0
);
Blksize
=
GetIntCatInfo
(
"Blksize"
,
0
);
...
@@ -191,7 +196,8 @@ bool DOSDEF::GetOptFileName(PGLOBAL g, char *filename)
...
@@ -191,7 +196,8 @@ bool DOSDEF::GetOptFileName(PGLOBAL g, char *filename)
case
RECFM_FIX
:
ftype
=
".fop"
;
break
;
case
RECFM_FIX
:
ftype
=
".fop"
;
break
;
case
RECFM_BIN
:
ftype
=
".bop"
;
break
;
case
RECFM_BIN
:
ftype
=
".bop"
;
break
;
case
RECFM_VCT
:
ftype
=
".vop"
;
break
;
case
RECFM_VCT
:
ftype
=
".vop"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbp"
;
break
;
case
RECFM_CSV
:
ftype
=
".cop"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbp"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Recfm
);
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Recfm
);
return
true
;
return
true
;
...
@@ -261,7 +267,8 @@ bool DOSDEF::DeleteIndexFile(PGLOBAL g, PIXDEF pxdf)
...
@@ -261,7 +267,8 @@ bool DOSDEF::DeleteIndexFile(PGLOBAL g, PIXDEF pxdf)
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
case
RECFM_CSV
:
ftype
=
".cnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
BAD_RECFM_VAL
),
Recfm
);
sprintf
(
g
->
Message
,
MSG
(
BAD_RECFM_VAL
),
Recfm
);
return
true
;
return
true
;
...
@@ -2257,7 +2264,7 @@ int TDBDOS::ReadDB(PGLOBAL g)
...
@@ -2257,7 +2264,7 @@ int TDBDOS::ReadDB(PGLOBAL g)
/***********************************************************************/
/***********************************************************************/
bool
TDBDOS
::
PrepareWriting
(
PGLOBAL
)
bool
TDBDOS
::
PrepareWriting
(
PGLOBAL
)
{
{
if
(
!
Ftype
&&
(
Mode
==
MODE_INSERT
||
Txfp
->
GetUseTemp
()))
{
if
(
Ftype
==
RECFM_VAR
&&
(
Mode
==
MODE_INSERT
||
Txfp
->
GetUseTemp
()))
{
char
*
p
;
char
*
p
;
/*******************************************************************/
/*******************************************************************/
...
@@ -2542,7 +2549,8 @@ void DOSCOL::ReadColumn(PGLOBAL g)
...
@@ -2542,7 +2549,8 @@ void DOSCOL::ReadColumn(PGLOBAL g)
/*********************************************************************/
/*********************************************************************/
/* For a variable length file, check if the field exists. */
/* For a variable length file, check if the field exists. */
/*********************************************************************/
/*********************************************************************/
if
(
tdbp
->
Ftype
==
RECFM_VAR
&&
strlen
(
tdbp
->
To_Line
)
<
(
unsigned
)
Deplac
)
if
((
tdbp
->
Ftype
==
RECFM_VAR
||
tdbp
->
Ftype
==
RECFM_CSV
)
&&
strlen
(
tdbp
->
To_Line
)
<
(
unsigned
)
Deplac
)
field
=
0
;
field
=
0
;
else
if
(
Dsp
)
else
if
(
Dsp
)
for
(
i
=
0
;
i
<
field
;
i
++
)
for
(
i
=
0
;
i
<
field
;
i
++
)
...
@@ -2552,7 +2560,8 @@ void DOSCOL::ReadColumn(PGLOBAL g)
...
@@ -2552,7 +2560,8 @@ void DOSCOL::ReadColumn(PGLOBAL g)
switch
(
tdbp
->
Ftype
)
{
switch
(
tdbp
->
Ftype
)
{
case
RECFM_VAR
:
case
RECFM_VAR
:
case
RECFM_FIX
:
// Fixed length text file
case
RECFM_FIX
:
// Fixed length text file
case
RECFM_DBF
:
// Fixed length DBase file
case
RECFM_CSV
:
// Variable length CSV or FMT file
case
RECFM_DBF
:
// Fixed length DBase file
if
(
Nod
)
switch
(
Buf_Type
)
{
if
(
Nod
)
switch
(
Buf_Type
)
{
case
TYPE_INT
:
case
TYPE_INT
:
case
TYPE_SHORT
:
case
TYPE_SHORT
:
...
...
storage/connect/tabdos.h
View file @
0b624deb
...
@@ -80,7 +80,6 @@ class DllExport DOSDEF : public TABDEF { /* Logical table description */
...
@@ -80,7 +80,6 @@ class DllExport DOSDEF : public TABDEF { /* Logical table description */
PCSZ
Entry
;
/* Zip entry name or pattern */
PCSZ
Entry
;
/* Zip entry name or pattern */
PCSZ
Pwd
;
/* Zip password */
PCSZ
Pwd
;
/* Zip password */
PIXDEF
To_Indx
;
/* To index definitions blocks */
PIXDEF
To_Indx
;
/* To index definitions blocks */
RECFM
Recfm
;
/* 0:VAR, 1:FIX, 2:BIN, 3:VCT, 6:DBF */
bool
Mapped
;
/* 0: disk file, 1: memory mapped file */
bool
Mapped
;
/* 0: disk file, 1: memory mapped file */
bool
Zipped
;
/* true for zipped table file */
bool
Zipped
;
/* true for zipped table file */
bool
Mulentries
;
/* true for multiple entries */
bool
Mulentries
;
/* true for multiple entries */
...
...
storage/connect/tabfix.cpp
View file @
0b624deb
...
@@ -84,7 +84,7 @@ PTDB TDBFIX::Clone(PTABS t)
...
@@ -84,7 +84,7 @@ PTDB TDBFIX::Clone(PTABS t)
tp
=
new
(
g
)
TDBFIX
(
g
,
this
);
tp
=
new
(
g
)
TDBFIX
(
g
,
this
);
if
(
Ftype
<
2
)
{
if
(
Ftype
==
RECFM_VAR
||
Ftype
==
RECFM_FIX
)
{
// File is text
// File is text
PDOSCOL
cp1
,
cp2
;
PDOSCOL
cp1
,
cp2
;
...
...
storage/connect/tabfmt.cpp
View file @
0b624deb
/************* TabFmt C++ Program Source Code File (.CPP) **************/
/************* TabFmt C++ Program Source Code File (.CPP) **************/
/* PROGRAM NAME: TABFMT */
/* PROGRAM NAME: TABFMT */
/* ------------- */
/* ------------- */
/* Version 3.9.
2
*/
/* Version 3.9.
3
*/
/* */
/* */
/* COPYRIGHT: */
/* COPYRIGHT: */
/* ---------- */
/* ---------- */
/* (C) Copyright to the author Olivier BERTRAND 2001 - 201
7
*/
/* (C) Copyright to the author Olivier BERTRAND 2001 - 201
9
*/
/* */
/* */
/* WHAT THIS PROGRAM DOES: */
/* WHAT THIS PROGRAM DOES: */
/* ----------------------- */
/* ----------------------- */
...
@@ -477,6 +477,7 @@ bool CSVDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -477,6 +477,7 @@ bool CSVDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
if
(
DOSDEF
::
DefineAM
(
g
,
"CSV"
,
poff
))
if
(
DOSDEF
::
DefineAM
(
g
,
"CSV"
,
poff
))
return
true
;
return
true
;
Recfm
=
RECFM_CSV
;
GetCharCatInfo
(
"Separator"
,
","
,
buf
,
sizeof
(
buf
));
GetCharCatInfo
(
"Separator"
,
","
,
buf
,
sizeof
(
buf
));
Sep
=
(
strlen
(
buf
)
==
2
&&
buf
[
0
]
==
'\\'
&&
buf
[
1
]
==
't'
)
?
'\t'
:
*
buf
;
Sep
=
(
strlen
(
buf
)
==
2
&&
buf
[
0
]
==
'\\'
&&
buf
[
1
]
==
't'
)
?
'\t'
:
*
buf
;
Quoted
=
GetIntCatInfo
(
"Quoted"
,
-
1
);
Quoted
=
GetIntCatInfo
(
"Quoted"
,
-
1
);
...
...
storage/connect/tabjson.cpp
View file @
0b624deb
...
@@ -394,10 +394,11 @@ int JSONDISC::GetColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt)
...
@@ -394,10 +394,11 @@ int JSONDISC::GetColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt)
bool
JSONDISC
::
Find
(
PGLOBAL
g
,
PJVAL
jvp
,
PCSZ
key
,
int
j
)
bool
JSONDISC
::
Find
(
PGLOBAL
g
,
PJVAL
jvp
,
PCSZ
key
,
int
j
)
{
{
char
*
p
,
*
pc
=
colname
+
strlen
(
colname
);
char
*
p
,
*
pc
=
colname
+
strlen
(
colname
);
int
ars
;
int
ars
;
PJOB
job
;
size_t
n
;
PJAR
jar
;
PJOB
job
;
PJAR
jar
;
if
((
valp
=
jvp
?
jvp
->
GetValue
()
:
NULL
))
{
if
((
valp
=
jvp
?
jvp
->
GetValue
()
:
NULL
))
{
jcol
.
Type
=
valp
->
GetType
();
jcol
.
Type
=
valp
->
GetType
();
...
@@ -423,8 +424,10 @@ bool JSONDISC::Find(PGLOBAL g, PJVAL jvp, PCSZ key, int j)
...
@@ -423,8 +424,10 @@ bool JSONDISC::Find(PGLOBAL g, PJVAL jvp, PCSZ key, int j)
PCSZ
k
=
jrp
->
GetKey
();
PCSZ
k
=
jrp
->
GetKey
();
if
(
*
k
!=
'$'
)
{
if
(
*
k
!=
'$'
)
{
strncat
(
strncat
(
fmt
,
sep
,
128
),
k
,
128
);
n
=
sizeof
(
fmt
)
-
strlen
(
fmt
)
-
1
;
strncat
(
strncat
(
colname
,
"_"
,
64
),
k
,
64
);
strncat
(
strncat
(
fmt
,
sep
,
n
),
k
,
n
-
strlen
(
sep
));
n
=
sizeof
(
colname
)
-
strlen
(
colname
)
-
1
;
strncat
(
strncat
(
colname
,
"_"
,
n
),
k
,
n
-
1
);
}
// endif Key
}
// endif Key
if
(
Find
(
g
,
jrp
->
GetVal
(),
k
,
j
+
1
))
if
(
Find
(
g
,
jrp
->
GetVal
(),
k
,
j
+
1
))
...
@@ -443,19 +446,26 @@ bool JSONDISC::Find(PGLOBAL g, PJVAL jvp, PCSZ key, int j)
...
@@ -443,19 +446,26 @@ bool JSONDISC::Find(PGLOBAL g, PJVAL jvp, PCSZ key, int j)
ars
=
MY_MIN
(
jar
->
GetSize
(
false
),
1
);
ars
=
MY_MIN
(
jar
->
GetSize
(
false
),
1
);
for
(
int
k
=
0
;
k
<
ars
;
k
++
)
{
for
(
int
k
=
0
;
k
<
ars
;
k
++
)
{
if
(
!
tdp
->
Xcol
||
stricmp
(
tdp
->
Xcol
,
key
))
{
n
=
sizeof
(
fmt
)
-
(
strlen
(
fmt
)
+
1
);
sprintf
(
buf
,
"%d"
,
k
);
if
(
tdp
->
Uri
)
strncat
(
strncat
(
fmt
,
sep
,
128
),
buf
,
128
);
else
strncat
(
strncat
(
strncat
(
fmt
,
"["
,
128
),
buf
,
128
),
"]"
,
128
);
if
(
all
)
if
(
!
tdp
->
Xcol
||
stricmp
(
tdp
->
Xcol
,
key
))
{
strncat
(
strncat
(
colname
,
"_"
,
64
),
buf
,
64
);
sprintf
(
buf
,
"%d"
,
k
);
}
else
if
(
tdp
->
Uri
)
{
strncat
(
fmt
,
(
tdp
->
Uri
?
sep
:
"[*]"
),
128
);
strncat
(
strncat
(
fmt
,
sep
,
n
),
buf
,
n
-
strlen
(
sep
));
}
else
{
strncat
(
strncat
(
fmt
,
"["
,
n
),
buf
,
n
-
1
);
strncat
(
fmt
,
"]"
,
n
-
(
strlen
(
buf
)
+
1
));
}
// endif uri
if
(
all
)
{
n
=
sizeof
(
colname
)
-
(
strlen
(
colname
)
+
1
);
strncat
(
strncat
(
colname
,
"_"
,
n
),
buf
,
n
-
1
);
}
// endif all
}
else
{
strncat
(
fmt
,
(
tdp
->
Uri
?
sep
:
"[*]"
),
n
);
}
if
(
Find
(
g
,
jar
->
GetValue
(
k
),
""
,
j
))
if
(
Find
(
g
,
jar
->
GetValue
(
k
),
""
,
j
))
return
true
;
return
true
;
...
...
storage/connect/tabmysql.cpp
View file @
0b624deb
...
@@ -342,11 +342,13 @@ bool MYSQLDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
...
@@ -342,11 +342,13 @@ bool MYSQLDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
Delayed
=
!!
GetIntCatInfo
(
"Delayed"
,
0
);
Delayed
=
!!
GetIntCatInfo
(
"Delayed"
,
0
);
}
else
{
}
else
{
// MYSQL access from a PROXY table
// MYSQL access from a PROXY table
Tabschema
=
GetStringCatInfo
(
g
,
"Database"
,
Tabschema
?
Tabschema
:
PlugDup
(
g
,
"*"
));
TABLE_SHARE
*
s
;
Tabschema
=
GetStringCatInfo
(
g
,
"Database"
,
Tabschema
?
Tabschema
:
PlugDup
(
g
,
"*"
));
Isview
=
GetBoolCatInfo
(
"View"
,
false
);
Isview
=
GetBoolCatInfo
(
"View"
,
false
);
// We must get other connection parms from the calling table
// We must get other connection parms from the calling table
Remove_tshp
(
Cat
);
s
=
Remove_tshp
(
Cat
);
url
=
GetStringCatInfo
(
g
,
"Connect"
,
NULL
);
url
=
GetStringCatInfo
(
g
,
"Connect"
,
NULL
);
if
(
!
url
||
!*
url
)
{
if
(
!
url
||
!*
url
)
{
...
@@ -365,6 +367,9 @@ bool MYSQLDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
...
@@ -365,6 +367,9 @@ bool MYSQLDEF::DefineAM(PGLOBAL g, LPCSTR am, int)
}
// endif url
}
// endif url
Tabname
=
Name
;
Tabname
=
Name
;
// Needed for column description
Restore_tshp
(
Cat
,
s
);
}
// endif am
}
// endif am
if
((
Srcdef
=
GetStringCatInfo
(
g
,
"Srcdef"
,
NULL
)))
{
if
((
Srcdef
=
GetStringCatInfo
(
g
,
"Srcdef"
,
NULL
)))
{
...
...
storage/connect/tabodbc.cpp
View file @
0b624deb
...
@@ -605,8 +605,10 @@ bool TDBODBC::OpenDB(PGLOBAL g)
...
@@ -605,8 +605,10 @@ bool TDBODBC::OpenDB(PGLOBAL g)
Cnp
->
InitValue
(
g
);
Cnp
->
InitValue
(
g
);
if
((
n
=
Ocp
->
GetResultSize
(
Query
->
GetStr
(),
Cnp
))
<
0
)
{
if
((
n
=
Ocp
->
GetResultSize
(
Query
->
GetStr
(),
Cnp
))
<
0
)
{
strcpy
(
g
->
Message
,
"Cannot get result size"
);
char
*
msg
=
PlugDup
(
g
,
g
->
Message
);
return
true
;
sprintf
(
g
->
Message
,
"Get result size: %s (rc=%d)"
,
msg
,
n
);
return
true
;
}
else
if
(
n
)
{
}
else
if
(
n
)
{
Ocp
->
m_Rows
=
n
;
Ocp
->
m_Rows
=
n
;
...
...
storage/connect/tabrest.cpp
View file @
0b624deb
/**************
* Rest C++ Program Source Code File (.CPP) **
************/
/**************
tabrest C++ Program Source Code File (.CPP)
************/
/* PROGRAM NAME:
Rest Version 1.5
*/
/* PROGRAM NAME:
tabrest Version 1.7
*/
/* (C) Copyright to the author Olivier BERTRAND 2018 - 2019 */
/* (C) Copyright to the author Olivier BERTRAND 2018 - 2019 */
/* This program is the REST Web API support for MariaDB. */
/* This program is the REST Web API support for MariaDB. */
/* When compiled without MARIADB defined, it is the EOM module code. */
/* When compiled without MARIADB defined, it is the EOM module code. */
...
@@ -9,13 +9,18 @@
...
@@ -9,13 +9,18 @@
/* Definitions needed by the included files. */
/* Definitions needed by the included files. */
/***********************************************************************/
/***********************************************************************/
#if defined(MARIADB)
#if defined(MARIADB)
#include <my_global.h> // All MariaDB stuff
#include <my_global.h>
// All MariaDB stuff
#else // !MARIADB OEM module
#else // !MARIADB OEM module
#include "mini-global.h"
#include "mini-global.h"
#define _MAX_PATH 260
#define _MAX_PATH 260
#if !defined(__WIN__)
#if !defined(REST_SOURCE)
#if defined(__WIN__) || defined(_WINDOWS)
#include <windows.h>
#else // !__WIN__
#define __stdcall
#define __stdcall
#include <dlfcn.h> // dlopen(), dlclose(), dlsym() ...
#endif // !__WIN__
#endif // !__WIN__
#endif // !REST_SOURCE
#define _OS_H_INCLUDED // Prevent os.h to be called
#define _OS_H_INCLUDED // Prevent os.h to be called
#endif // !MARIADB
#endif // !MARIADB
...
@@ -23,7 +28,6 @@
...
@@ -23,7 +28,6 @@
/* Include application header files: */
/* Include application header files: */
/* global.h is header containing all global declarations. */
/* global.h is header containing all global declarations. */
/* plgdbsem.h is header containing the DB application declarations. */
/* plgdbsem.h is header containing the DB application declarations. */
/* (x)table.h is header containing the TDBASE declarations. */
/***********************************************************************/
/***********************************************************************/
#include "global.h"
#include "global.h"
#include "plgdbsem.h"
#include "plgdbsem.h"
...
@@ -36,17 +40,7 @@
...
@@ -36,17 +40,7 @@
#include "tabfmt.h"
#include "tabfmt.h"
#include "tabrest.h"
#include "tabrest.h"
/***********************************************************************/
static
XGETREST
getRestFnc
=
NULL
;
/* Get the file from the Web. */
/***********************************************************************/
int
restGetFile
(
PGLOBAL
g
,
PCSZ
http
,
PCSZ
uri
,
PCSZ
fn
);
#if defined(__WIN__)
static
PCSZ
slash
=
"
\\
"
;
#else // !__WIN__
static
PCSZ
slash
=
"/"
;
#define stricmp strcasecmp
#endif // !__WIN__
#if !defined(MARIADB)
#if !defined(MARIADB)
/***********************************************************************/
/***********************************************************************/
...
@@ -75,6 +69,74 @@ PTABDEF __stdcall GetREST(PGLOBAL g, void *memp)
...
@@ -75,6 +69,74 @@ PTABDEF __stdcall GetREST(PGLOBAL g, void *memp)
}
// end of GetREST
}
// end of GetREST
#endif // !MARIADB
#endif // !MARIADB
/***********************************************************************/
/* GetREST: get the external TABDEF from OEM module. */
/***********************************************************************/
XGETREST
GetRestFunction
(
PGLOBAL
g
)
{
if
(
getRestFnc
)
return
getRestFnc
;
#if !defined(MARIADB) || !defined(REST_SOURCE)
if
(
trace
(
515
))
htrc
(
"Looking for GetRest library
\n
"
);
#if defined(__WIN__) || defined(_WINDOWS)
HANDLE
Hdll
;
const
char
*
soname
=
"GetRest.dll"
;
// Module name
if
(
!
(
Hdll
=
LoadLibrary
(
soname
)))
{
char
buf
[
256
];
DWORD
rc
=
GetLastError
();
sprintf
(
g
->
Message
,
MSG
(
DLL_LOAD_ERROR
),
rc
,
soname
);
FormatMessage
(
FORMAT_MESSAGE_FROM_SYSTEM
|
FORMAT_MESSAGE_IGNORE_INSERTS
,
NULL
,
rc
,
0
,
(
LPTSTR
)
buf
,
sizeof
(
buf
),
NULL
);
strcat
(
strcat
(
g
->
Message
,
": "
),
buf
);
return
NULL
;
}
// endif Hdll
// Get the function returning an instance of the external DEF class
if
(
!
(
getRestFnc
=
(
XGETREST
)
GetProcAddress
((
HINSTANCE
)
Hdll
,
"restGetFile"
)))
{
char
buf
[
256
];
DWORD
rc
=
GetLastError
();
sprintf
(
g
->
Message
,
MSG
(
PROCADD_ERROR
),
rc
,
"restGetFile"
);
FormatMessage
(
FORMAT_MESSAGE_FROM_SYSTEM
|
FORMAT_MESSAGE_IGNORE_INSERTS
,
NULL
,
rc
,
0
,
(
LPTSTR
)
buf
,
sizeof
(
buf
),
NULL
);
strcat
(
strcat
(
g
->
Message
,
": "
),
buf
);
FreeLibrary
((
HMODULE
)
Hdll
);
return
NULL
;
}
// endif getRestFnc
#else // !__WIN__
void
*
Hso
;
const
char
*
error
=
NULL
;
const
char
*
soname
=
"GetRest.so"
;
// Module name
// Load the desired shared library
if
(
!
(
Hso
=
dlopen
(
soname
,
RTLD_LAZY
)))
{
error
=
dlerror
();
sprintf
(
g
->
Message
,
MSG
(
SHARED_LIB_ERR
),
soname
,
SVP
(
error
));
return
NULL
;
}
// endif Hdll
// Get the function returning an instance of the external DEF class
if
(
!
(
getRestFnc
=
(
XGETREST
)
dlsym
(
Hso
,
"restGetFile"
)))
{
error
=
dlerror
();
sprintf
(
g
->
Message
,
MSG
(
GET_FUNC_ERR
),
"restGetFile"
,
SVP
(
error
));
dlclose
(
Hso
);
return
NULL
;
}
// endif getdef
#endif // !__WIN__
#else
getRestFnc
=
restGetFile
;
#endif
return
getRestFnc
;
}
// end of GetRestFunction
/***********************************************************************/
/***********************************************************************/
/* Return the columns definition to MariaDB. */
/* Return the columns definition to MariaDB. */
/***********************************************************************/
/***********************************************************************/
...
@@ -87,6 +149,10 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
...
@@ -87,6 +149,10 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
PQRYRES
qrp
=
NULL
;
PQRYRES
qrp
=
NULL
;
char
filename
[
_MAX_PATH
+
1
];
// MAX PATH ???
char
filename
[
_MAX_PATH
+
1
];
// MAX PATH ???
PCSZ
http
,
uri
,
fn
,
ftype
;
PCSZ
http
,
uri
,
fn
,
ftype
;
XGETREST
grf
=
GetRestFunction
(
g
);
if
(
!
grf
)
return
NULL
;
http
=
GetStringTableOption
(
g
,
tp
,
"Http"
,
NULL
);
http
=
GetStringTableOption
(
g
,
tp
,
"Http"
,
NULL
);
uri
=
GetStringTableOption
(
g
,
tp
,
"Uri"
,
NULL
);
uri
=
GetStringTableOption
(
g
,
tp
,
"Uri"
,
NULL
);
...
@@ -100,11 +166,11 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
...
@@ -100,11 +166,11 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
// We used the file name relative to recorded datapath
// We used the file name relative to recorded datapath
strcat
(
strcat
(
strcat
(
strcpy
(
filename
,
"."
),
slash
),
db
),
slash
);
strcat
(
strcat
(
strcat
(
strcpy
(
filename
,
"."
),
slash
),
db
),
slash
);
strncat
(
filename
,
fn
,
_MAX_PATH
);
strncat
(
filename
,
fn
,
_MAX_PATH
-
strlen
(
filename
)
);
// Retrieve the file from the web and copy it locally
// Retrieve the file from the web and copy it locally
if
(
http
&&
restGetFile
(
g
,
http
,
uri
,
filename
))
{
if
(
http
&&
grf
(
g
->
Message
,
trace
(
515
)
,
http
,
uri
,
filename
))
{
// sprintf(g->Message, "Failed to get file at %s", http);
// sprintf(g->Message, "Failed to get file at %s", http);
}
else
if
(
!
stricmp
(
ftype
,
"XML"
))
}
else
if
(
!
stricmp
(
ftype
,
"XML"
))
qrp
=
XMLColumns
(
g
,
db
,
tab
,
tp
,
info
);
qrp
=
XMLColumns
(
g
,
db
,
tab
,
tp
,
info
);
else
if
(
!
stricmp
(
ftype
,
"JSON"
))
else
if
(
!
stricmp
(
ftype
,
"JSON"
))
...
@@ -124,9 +190,14 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
...
@@ -124,9 +190,14 @@ PQRYRES __stdcall ColREST(PGLOBAL g, PTOS tp, char *tab, char *db, bool info)
/***********************************************************************/
/***********************************************************************/
bool
RESTDEF
::
DefineAM
(
PGLOBAL
g
,
LPCSTR
am
,
int
poff
)
bool
RESTDEF
::
DefineAM
(
PGLOBAL
g
,
LPCSTR
am
,
int
poff
)
{
{
char
filename
[
_MAX_PATH
+
1
];
char
filename
[
_MAX_PATH
+
1
];
int
rc
=
0
,
n
;
int
rc
=
0
,
n
;
LPCSTR
ftype
;
bool
xt
=
trace
(
515
);
LPCSTR
ftype
;
XGETREST
grf
=
GetRestFunction
(
g
);
if
(
!
grf
)
return
true
;
#if defined(MARIADB)
#if defined(MARIADB)
ftype
=
GetStringCatInfo
(
g
,
"Type"
,
"JSON"
);
ftype
=
GetStringCatInfo
(
g
,
"Type"
,
"JSON"
);
...
@@ -135,7 +206,7 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -135,7 +206,7 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
ftype
=
GetStringCatInfo
(
g
,
"Ftype"
,
"JSON"
);
ftype
=
GetStringCatInfo
(
g
,
"Ftype"
,
"JSON"
);
#endif // !MARIADB
#endif // !MARIADB
if
(
trace
(
515
)
)
if
(
xt
)
htrc
(
"ftype = %s am = %s
\n
"
,
ftype
,
SVP
(
am
));
htrc
(
"ftype = %s am = %s
\n
"
,
ftype
,
SVP
(
am
));
n
=
(
!
stricmp
(
ftype
,
"JSON"
))
?
1
n
=
(
!
stricmp
(
ftype
,
"JSON"
))
?
1
...
@@ -154,12 +225,13 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -154,12 +225,13 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
// We used the file name relative to recorded datapath
// We used the file name relative to recorded datapath
//PlugSetPath(filename, Fn, GetPath());
//PlugSetPath(filename, Fn, GetPath());
strncat
(
strcpy
(
filename
,
GetPath
()),
Fn
,
_MAX_PATH
);
strcpy
(
filename
,
GetPath
());
strncat
(
filename
,
Fn
,
_MAX_PATH
-
strlen
(
filename
));
// Retrieve the file from the web and copy it locally
// Retrieve the file from the web and copy it locally
rc
=
restGetFile
(
g
,
Http
,
Uri
,
filename
);
rc
=
grf
(
g
->
Message
,
xt
,
Http
,
Uri
,
filename
);
if
(
trace
(
515
)
)
if
(
xt
)
htrc
(
"Return from restGetFile: rc=%d
\n
"
,
rc
);
htrc
(
"Return from restGetFile: rc=%d
\n
"
,
rc
);
if
(
rc
)
if
(
rc
)
...
@@ -175,7 +247,7 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -175,7 +247,7 @@ bool RESTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
if
(
Tdp
&&
Tdp
->
Define
(
g
,
Cat
,
Name
,
Schema
,
"REST"
))
if
(
Tdp
&&
Tdp
->
Define
(
g
,
Cat
,
Name
,
Schema
,
"REST"
))
Tdp
=
NULL
;
// Error occured
Tdp
=
NULL
;
// Error occured
if
(
trace
(
515
)
)
if
(
xt
)
htrc
(
"Tdp defined
\n
"
,
rc
);
htrc
(
"Tdp defined
\n
"
,
rc
);
// Return true in case of error
// Return true in case of error
...
...
storage/connect/tabrest.h
View file @
0b624deb
...
@@ -5,6 +5,27 @@
...
@@ -5,6 +5,27 @@
/***********************************************************************/
/***********************************************************************/
#pragma once
#pragma once
#if defined(__WIN__)
static
PCSZ
slash
=
"
\\
"
;
#else // !__WIN__
static
PCSZ
slash
=
"/"
;
#define stricmp strcasecmp
#endif // !__WIN__
typedef
int
(
__stdcall
*
XGETREST
)
(
char
*
,
bool
,
PCSZ
,
PCSZ
,
PCSZ
);
/***********************************************************************/
/* Functions used by REST. */
/***********************************************************************/
XGETREST
GetRestFunction
(
PGLOBAL
g
);
#if defined(REST_SOURCE)
extern
"C"
int
restGetFile
(
char
*
m
,
bool
xt
,
PCSZ
http
,
PCSZ
uri
,
PCSZ
fn
);
#endif // REST_SOURCE
#if defined(MARIADB)
PQRYRES
RESTColumns
(
PGLOBAL
g
,
PTOS
tp
,
char
*
tab
,
char
*
db
,
bool
info
);
#endif // !MARIADB
/***********************************************************************/
/***********************************************************************/
/* Restest table. */
/* Restest table. */
/***********************************************************************/
/***********************************************************************/
...
...
storage/connect/tabutil.cpp
View file @
0b624deb
...
@@ -59,11 +59,23 @@ int GetConvSize(void);
...
@@ -59,11 +59,23 @@ int GetConvSize(void);
/* Used by MYSQL tables to get MySQL parameters from the calling proxy */
/* Used by MYSQL tables to get MySQL parameters from the calling proxy */
/* table (PROXY, TBL, XCL, or OCCUR) when used by one of these. */
/* table (PROXY, TBL, XCL, or OCCUR) when used by one of these. */
/************************************************************************/
/************************************************************************/
void
Remove_tshp
(
PCATLG
cat
)
TABLE_SHARE
*
Remove_tshp
(
PCATLG
cat
)
{
{
((
MYCAT
*
)
cat
)
->
GetHandler
()
->
tshp
=
NULL
;
TABLE_SHARE
*
s
=
((
MYCAT
*
)
cat
)
->
GetHandler
()
->
tshp
;
((
MYCAT
*
)
cat
)
->
GetHandler
()
->
tshp
=
NULL
;
return
s
;
}
// end of Remove_thsp
}
// end of Remove_thsp
/************************************************************************/
/* Used by MYSQL tables to get MySQL parameters from the calling proxy */
/* table (PROXY, TBL, XCL, or OCCUR) when used by one of these. */
/************************************************************************/
void
Restore_tshp
(
PCATLG
cat
,
TABLE_SHARE
*
s
)
{
((
MYCAT
*
)
cat
)
->
GetHandler
()
->
tshp
=
s
;
}
// end of Restore_thsp
/************************************************************************/
/************************************************************************/
/* GetTableShare: allocates and open a table share. */
/* GetTableShare: allocates and open a table share. */
/************************************************************************/
/************************************************************************/
...
...
storage/connect/tabutil.h
View file @
0b624deb
...
@@ -18,7 +18,8 @@ TABLE_SHARE *GetTableShare(PGLOBAL g, THD *thd, const char *db,
...
@@ -18,7 +18,8 @@ TABLE_SHARE *GetTableShare(PGLOBAL g, THD *thd, const char *db,
PQRYRES
TabColumns
(
PGLOBAL
g
,
THD
*
thd
,
const
char
*
db
,
PQRYRES
TabColumns
(
PGLOBAL
g
,
THD
*
thd
,
const
char
*
db
,
const
char
*
name
,
bool
&
info
);
const
char
*
name
,
bool
&
info
);
void
Remove_tshp
(
PCATLG
cat
);
TABLE_SHARE
*
Remove_tshp
(
PCATLG
cat
);
void
Restore_tshp
(
PCATLG
cat
,
TABLE_SHARE
*
s
);
/* -------------------------- PROXY classes -------------------------- */
/* -------------------------- PROXY classes -------------------------- */
...
...
storage/connect/tabvct.cpp
View file @
0b624deb
...
@@ -115,11 +115,14 @@ bool VCTDEF::DefineAM(PGLOBAL g, LPCSTR, int poff)
...
@@ -115,11 +115,14 @@ bool VCTDEF::DefineAM(PGLOBAL g, LPCSTR, int poff)
Recfm
=
RECFM_VCT
;
Recfm
=
RECFM_VCT
;
// poff is no more in use; This will have to be revisited
#if 0
// For packed files the logical record length is calculated in poff
// For packed files the logical record length is calculated in poff
if (poff != Lrecl) {
if (poff != Lrecl) {
Lrecl = poff;
Lrecl = poff;
SetIntCatInfo("Lrecl", poff);
SetIntCatInfo("Lrecl", poff);
} // endif poff
} // endif poff
#endif // 0
Padded
=
false
;
Padded
=
false
;
Blksize
=
0
;
Blksize
=
0
;
...
...
storage/connect/tabxml.cpp
View file @
0b624deb
...
@@ -240,7 +240,9 @@ PQRYRES XMLColumns(PGLOBAL g, char *db, char *tab, PTOS topt, bool info)
...
@@ -240,7 +240,9 @@ PQRYRES XMLColumns(PGLOBAL g, char *db, char *tab, PTOS topt, bool info)
more:
more:
if
(
vp
->
atp
)
{
if
(
vp
->
atp
)
{
strncpy
(
colname
,
vp
->
atp
->
GetName
(
g
),
sizeof
(
colname
));
size_t
z
=
sizeof
(
colname
)
-
1
;
strncpy
(
colname
,
vp
->
atp
->
GetName
(
g
),
z
);
colname
[
z
]
=
0
;
strncat
(
xcol
->
Name
,
colname
,
XLEN
(
xcol
->
Name
));
strncat
(
xcol
->
Name
,
colname
,
XLEN
(
xcol
->
Name
));
switch
(
vp
->
atp
->
GetText
(
g
,
buf
,
sizeof
(
buf
)))
{
switch
(
vp
->
atp
->
GetText
(
g
,
buf
,
sizeof
(
buf
)))
{
...
...
storage/connect/valblk.cpp
View file @
0b624deb
...
@@ -206,6 +206,7 @@ void VALBLK::ChkIndx(int n)
...
@@ -206,6 +206,7 @@ void VALBLK::ChkIndx(int n)
{
{
if
(
n
<
0
||
n
>=
Nval
)
{
if
(
n
<
0
||
n
>=
Nval
)
{
PGLOBAL
&
g
=
Global
;
PGLOBAL
&
g
=
Global
;
xtrc
(
1
,
"ChkIndx: n=%d Nval=%d
\n
"
,
n
,
Nval
);
strcpy
(
g
->
Message
,
MSG
(
BAD_VALBLK_INDX
));
strcpy
(
g
->
Message
,
MSG
(
BAD_VALBLK_INDX
));
throw
Type
;
throw
Type
;
}
// endif n
}
// endif n
...
@@ -216,7 +217,8 @@ void VALBLK::ChkTyp(PVAL v)
...
@@ -216,7 +217,8 @@ void VALBLK::ChkTyp(PVAL v)
{
{
if
(
Check
&&
(
Type
!=
v
->
GetType
()
||
Unsigned
!=
v
->
IsUnsigned
()))
{
if
(
Check
&&
(
Type
!=
v
->
GetType
()
||
Unsigned
!=
v
->
IsUnsigned
()))
{
PGLOBAL
&
g
=
Global
;
PGLOBAL
&
g
=
Global
;
strcpy
(
g
->
Message
,
MSG
(
VALTYPE_NOMATCH
));
xtrc
(
1
,
"ChkTyp: Type=%d valType=%d
\n
"
,
Type
,
v
->
GetType
());
strcpy
(
g
->
Message
,
MSG
(
VALTYPE_NOMATCH
));
throw
Type
;
throw
Type
;
}
// endif Type
}
// endif Type
...
@@ -511,7 +513,7 @@ void TYPBLK<TYPE>::SetValues(PVBLK pv, int k, int n)
...
@@ -511,7 +513,7 @@ void TYPBLK<TYPE>::SetValues(PVBLK pv, int k, int n)
CheckType(pv)
CheckType(pv)
TYPE *lp = ((TYPBLK*)pv)->Typp;
TYPE *lp = ((TYPBLK*)pv)->Typp;
for (
register
int i = k; i < n; i++) // TODO
for (int i = k; i < n; i++) // TODO
Typp[i] = lp[i];
Typp[i] = lp[i];
} // end of SetValues
} // end of SetValues
...
@@ -805,7 +807,7 @@ void CHRBLK::SetValue(const char *sp, uint len, int n)
...
@@ -805,7 +807,7 @@ void CHRBLK::SetValue(const char *sp, uint len, int n)
if
(
Blanks
)
{
if
(
Blanks
)
{
// Suppress eventual ending zero and right fill with blanks
// Suppress eventual ending zero and right fill with blanks
for
(
register
int
i
=
len
;
i
<
Long
;
i
++
)
for
(
int
i
=
len
;
i
<
Long
;
i
++
)
p
[
i
]
=
' '
;
p
[
i
]
=
' '
;
}
else
if
((
signed
)
len
<
Long
)
}
else
if
((
signed
)
len
<
Long
)
...
...
storage/connect/value.cpp
View file @
0b624deb
This diff is collapsed.
Click to expand it.
storage/connect/xindex.cpp
View file @
0b624deb
...
@@ -272,8 +272,8 @@ void XINDEX::Close(void)
...
@@ -272,8 +272,8 @@ void XINDEX::Close(void)
/***********************************************************************/
/***********************************************************************/
int
XINDEX
::
Qcompare
(
int
*
i1
,
int
*
i2
)
int
XINDEX
::
Qcompare
(
int
*
i1
,
int
*
i2
)
{
{
register
int
k
;
int
k
;
register
PXCOL
kcp
;
PXCOL
kcp
;
for
(
kcp
=
To_KeyCol
,
k
=
0
;
kcp
;
kcp
=
kcp
->
Next
)
for
(
kcp
=
To_KeyCol
,
k
=
0
;
kcp
;
kcp
=
kcp
->
Next
)
if
((
k
=
kcp
->
Compare
(
*
i1
,
*
i2
)))
if
((
k
=
kcp
->
Compare
(
*
i1
,
*
i2
)))
...
@@ -659,7 +659,7 @@ bool XINDEX::Make(PGLOBAL g, PIXDEF sxp)
...
@@ -659,7 +659,7 @@ bool XINDEX::Make(PGLOBAL g, PIXDEF sxp)
/* Not true for DBF tables because of eventual soft deleted lines. */
/* Not true for DBF tables because of eventual soft deleted lines. */
/* Note: for Num_K = 1 any non null value is Ok. */
/* Note: for Num_K = 1 any non null value is Ok. */
/*********************************************************************/
/*********************************************************************/
if
(
Srtd
&&
!
filp
&&
Tdbp
->
Ftype
!=
RECFM_VAR
if
(
Srtd
&&
!
filp
&&
Tdbp
->
Ftype
!=
RECFM_VAR
&&
Tdbp
->
Ftype
!=
RECFM_CSV
&&
Tdbp
->
Txfp
->
GetAmType
()
!=
TYPE_AM_DBF
)
{
&&
Tdbp
->
Txfp
->
GetAmType
()
!=
TYPE_AM_DBF
)
{
Incr
=
(
Num_K
>
1
)
?
To_Rec
[
1
]
:
Num_K
;
Incr
=
(
Num_K
>
1
)
?
To_Rec
[
1
]
:
Num_K
;
PlgDBfree
(
Record
);
PlgDBfree
(
Record
);
...
@@ -745,7 +745,7 @@ int XINDEX::ColMaxSame(PXCOL kp)
...
@@ -745,7 +745,7 @@ int XINDEX::ColMaxSame(PXCOL kp)
/***********************************************************************/
/***********************************************************************/
bool
XINDEX
::
Reorder
(
PGLOBAL
g
__attribute__
((
unused
)))
bool
XINDEX
::
Reorder
(
PGLOBAL
g
__attribute__
((
unused
)))
{
{
register
int
i
,
j
,
k
,
n
;
int
i
,
j
,
k
,
n
;
bool
sorted
=
true
;
bool
sorted
=
true
;
PXCOL
kcp
;
PXCOL
kcp
;
#if 0
#if 0
...
@@ -837,7 +837,8 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
...
@@ -837,7 +837,8 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
case
RECFM_CSV
:
ftype
=
".cnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
return
true
;
return
true
;
...
@@ -990,7 +991,8 @@ bool XINDEX::Init(PGLOBAL g)
...
@@ -990,7 +991,8 @@ bool XINDEX::Init(PGLOBAL g)
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
case
RECFM_CSV
:
ftype
=
".cnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
return
true
;
return
true
;
...
@@ -1243,7 +1245,8 @@ bool XINDEX::MapInit(PGLOBAL g)
...
@@ -1243,7 +1245,8 @@ bool XINDEX::MapInit(PGLOBAL g)
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
case
RECFM_CSV
:
ftype
=
".cnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
return
true
;
return
true
;
...
@@ -1457,7 +1460,8 @@ bool XINDEX::GetAllSizes(PGLOBAL g,/* int &ndif,*/ int &numk)
...
@@ -1457,7 +1460,8 @@ bool XINDEX::GetAllSizes(PGLOBAL g,/* int &ndif,*/ int &numk)
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_FIX
:
ftype
=
".fnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_BIN
:
ftype
=
".bnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_VCT
:
ftype
=
".vnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
case
RECFM_CSV
:
ftype
=
".cnx"
;
break
;
case
RECFM_DBF
:
ftype
=
".dbx"
;
break
;
default:
default:
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
sprintf
(
g
->
Message
,
MSG
(
INVALID_FTYPE
),
Tdbp
->
Ftype
);
return
true
;
return
true
;
...
@@ -1870,8 +1874,8 @@ int XINDEX::Fetch(PGLOBAL g)
...
@@ -1870,8 +1874,8 @@ int XINDEX::Fetch(PGLOBAL g)
/***********************************************************************/
/***********************************************************************/
int
XINDEX
::
FastFind
(
void
)
int
XINDEX
::
FastFind
(
void
)
{
{
register
int
curk
,
sup
,
inf
,
i
=
0
,
k
,
n
=
2
;
int
curk
,
sup
,
inf
,
i
=
0
,
k
,
n
=
2
;
register
PXCOL
kp
,
kcp
;
PXCOL
kp
,
kcp
;
//assert((int)nv == Nval);
//assert((int)nv == Nval);
...
@@ -2209,8 +2213,8 @@ int XINDXS::Fetch(PGLOBAL g)
...
@@ -2209,8 +2213,8 @@ int XINDXS::Fetch(PGLOBAL g)
/***********************************************************************/
/***********************************************************************/
int
XINDXS
::
FastFind
(
void
)
int
XINDXS
::
FastFind
(
void
)
{
{
register
int
sup
,
inf
,
i
=
0
,
n
=
2
;
int
sup
,
inf
,
i
=
0
,
n
=
2
;
register
PXCOL
kcp
=
To_KeyCol
;
PXCOL
kcp
=
To_KeyCol
;
if
(
Nblk
&&
Op
==
OP_EQ
)
{
if
(
Nblk
&&
Op
==
OP_EQ
)
{
// Look in block values to find in which block to search
// Look in block values to find in which block to search
...
@@ -3235,7 +3239,7 @@ void KXYCOL::FillValue(PVAL valp)
...
@@ -3235,7 +3239,7 @@ void KXYCOL::FillValue(PVAL valp)
int
KXYCOL
::
Compare
(
int
i1
,
int
i2
)
int
KXYCOL
::
Compare
(
int
i1
,
int
i2
)
{
{
// Do the actual comparison between values.
// Do the actual comparison between values.
register
int
k
=
Kblp
->
CompVal
(
i1
,
i2
);
int
k
=
Kblp
->
CompVal
(
i1
,
i2
);
if
(
trace
(
4
))
if
(
trace
(
4
))
htrc
(
"Compare done result=%d
\n
"
,
k
);
htrc
(
"Compare done result=%d
\n
"
,
k
);
...
@@ -3250,7 +3254,7 @@ int KXYCOL::CompVal(int i)
...
@@ -3250,7 +3254,7 @@ int KXYCOL::CompVal(int i)
{
{
// Do the actual comparison between numerical values.
// Do the actual comparison between numerical values.
if
(
trace
(
4
))
{
if
(
trace
(
4
))
{
register
int
k
=
(
int
)
Kblp
->
CompVal
(
Valp
,
(
int
)
i
);
int
k
=
(
int
)
Kblp
->
CompVal
(
Valp
,
(
int
)
i
);
htrc
(
"Compare done result=%d
\n
"
,
k
);
htrc
(
"Compare done result=%d
\n
"
,
k
);
return
k
;
return
k
;
...
...
storage/connect/xtable.h
View file @
0b624deb
...
@@ -173,9 +173,12 @@ class DllExport TDBASE : public TDB {
...
@@ -173,9 +173,12 @@ class DllExport TDBASE : public TDB {
inline
void
SetKindex
(
PKXBASE
kxp
)
{
To_Kindex
=
kxp
;}
inline
void
SetKindex
(
PKXBASE
kxp
)
{
To_Kindex
=
kxp
;}
// Properties
// Properties
virtual
PKXBASE
GetKindex
(
void
)
{
return
To_Kindex
;}
PKXBASE
GetKindex
(
void
)
{
return
To_Kindex
;}
PXOB
*
GetLink
(
void
)
{
return
To_Link
;}
PIXDEF
GetXdp
(
void
)
{
return
To_Xdp
;}
void
ResetKindex
(
PGLOBAL
g
,
PKXBASE
kxp
);
void
ResetKindex
(
PGLOBAL
g
,
PKXBASE
kxp
);
PCOL
Key
(
int
i
)
{
return
(
To_Key_Col
)
?
To_Key_Col
[
i
]
:
NULL
;}
PCOL
Key
(
int
i
)
{
return
(
To_Key_Col
)
?
To_Key_Col
[
i
]
:
NULL
;}
PXOB
Link
(
int
i
)
{
return
(
To_Link
)
?
To_Link
[
i
]
:
NULL
;
}
// Methods
// Methods
virtual
bool
IsUsingTemp
(
PGLOBAL
)
{
return
false
;}
virtual
bool
IsUsingTemp
(
PGLOBAL
)
{
return
false
;}
...
...
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