LAPTOP-SNT8I5JK\Boounion
2024-11-15 a2a0aed00c2ee1ac1cf1187be8f2cbdc6c89310d
1.PLC的连接;
已添加5个文件
已修改6个文件
270446 ■■■■■ 文件已修改
SourceCode/Bond/BondEq/BondEq.vcxproj 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/CBonder.cpp 13 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/CBonder.h 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/Common.h 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/GB2860SQLite.cpp 320 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/GB2860SQLite.h 26 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/Model.cpp 184 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/Model.h 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/sqlite3.c 255811 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/sqlite3.h 13357 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/sqlite3ext.h 719 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/BondEq.vcxproj
@@ -219,6 +219,7 @@
    <ClInclude Include="DBManager\UserManager.h" />
    <ClInclude Include="EQState.h" />
    <ClInclude Include="EQStateMonitor.h" />
    <ClInclude Include="GB2860SQLite.h" />
    <ClInclude Include="HmTab.h" />
    <ClInclude Include="HmVerticalTab.h" />
    <ClInclude Include="HorizontalLine.h" />
@@ -237,6 +238,8 @@
    <ClInclude Include="SetPage1.h" />
    <ClInclude Include="SetPage2.h" />
    <ClInclude Include="SettingsDlg.h" />
    <ClInclude Include="sqlite3.h" />
    <ClInclude Include="sqlite3ext.h" />
    <ClInclude Include="stdafx.h" />
    <ClInclude Include="targetver.h" />
    <ClInclude Include="ToolUnits.h" />
@@ -274,6 +277,7 @@
    <ClCompile Include="DBManager\UserManager.cpp" />
    <ClCompile Include="EQState.cpp" />
    <ClCompile Include="EQStateMonitor.cpp" />
    <ClCompile Include="GB2860SQLite.cpp" />
    <ClCompile Include="HmTab.cpp" />
    <ClCompile Include="HmVerticalTab.cpp" />
    <ClCompile Include="HorizontalLine.cpp" />
@@ -291,6 +295,9 @@
    <ClCompile Include="SetPage1.cpp" />
    <ClCompile Include="SetPage2.cpp" />
    <ClCompile Include="SettingsDlg.cpp" />
    <ClCompile Include="sqlite3.c">
      <PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">NotUsing</PrecompiledHeader>
    </ClCompile>
    <ClCompile Include="stdafx.cpp">
      <PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Create</PrecompiledHeader>
      <PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">Create</PrecompiledHeader>
SourceCode/Bond/BondEq/CBonder.cpp
@@ -60,7 +60,6 @@
{
    m_listener.onStateChanged = listener.onStateChanged;
    m_listener.onPlcStateChanged = listener.onPlcStateChanged;
    m_listener.onCimStateChanged = listener.onCimStateChanged;
    m_listener.onEfemStateChanged = listener.onEfemStateChanged;
    m_listener.onRecvBroadcast = listener.onRecvBroadcast;
}
@@ -187,7 +186,6 @@
    pPlc->setName("PLC(1)");
    pPlc->setDescription("PLC");
    pPlc->setIndex(0);
    pPlc->init();
    AddComponent(pPlc);
@@ -449,6 +447,17 @@
        item->OnTimer(nTimerid);
    }
    // PLC延时连接
    static int nPlc = 0;
    nPlc++;
    if (nPlc == 3) {
        CPLC* pPLC = (CPLC*)GetComponent("PLC(1)");
        pPLC->init();
    }
    // è‡ªåŠ¨ä¿å­˜
    static int iii = 0;
    iii++;
    if (iii % 5 == 0) {
SourceCode/Bond/BondEq/CBonder.h
@@ -20,7 +20,6 @@
typedef std::function<void(void* pFrom, int)> ONBONDSTATECHANGED;
typedef std::function<void(void* pFrom, int)> ONPLCSTATECHANGED;
typedef std::function<void(void* pFrom, int)> ONCIMSTATECHANGED;
typedef std::function<void(void* pFrom, const char* pszAddr, int port, int)> ONEFEMSTATECHANGED;
typedef std::function<void(void* pFrom, void*)> ONRECVBROADCAST;
@@ -28,7 +27,6 @@
{
    ONBONDSTATECHANGED        onStateChanged;
    ONPLCSTATECHANGED        onPlcStateChanged;
    ONCIMSTATECHANGED        onCimStateChanged;
    ONEFEMSTATECHANGED        onEfemStateChanged;
    ONRECVBROADCAST            onRecvBroadcast;
} BondListener;
SourceCode/Bond/BondEq/Common.h
@@ -20,7 +20,6 @@
#define RX_CODE_TEST                    0
#define RX_CODE_LOG                        1000
#define RX_CODE_BONDER_STATE_CHANGED    1001
#define RX_CODE_PASSIVE_STATUS_CHANGED    1002
#define RX_CODE_PLC1_CONNECTTD            1003
#define RX_CODE_PLC1_DISCONNECTTD        1004
#define RX_CODE_SELECT_EQ                1005
SourceCode/Bond/BondEq/GB2860SQLite.cpp
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,320 @@
#include "stdafx.h"
#include "GB2860SQLite.h"
#include "ToolUnits.h"
CGB2860SQLite::CGB2860SQLite()
{
    m_db = nullptr;
}
CGB2860SQLite::~CGB2860SQLite()
{
}
void CGB2860SQLite::setDbFilepath(const char* pszFilepath)
{
    m_strDbFilepath = pszFilepath;
}
int CGB2860SQLite::init(std::string& strError)
{
    char* pszError = nullptr;
    int nRet;
    // æ‰“开指定的数据库文件, å¦‚果不存在将创建一个同名的数据库文件
    nRet = sqlite3_open(m_strDbFilepath.c_str(), &m_db);
    if (nRet != 0) {
        sqlite3_close(m_db);
        m_db = nullptr;
        return -1;
    }
    // åˆ›å»ºPanel表, å¦‚果该表存在,则不创建,
    // å¹¶ç»™å‡ºæç¤ºä¿¡æ¯ï¼Œå­˜å‚¨åœ¨zErrMsg ä¸­
    char* sql = "CREATE TABLE Panels (ID INTEGER PRIMARY KEY,"        \
        "PanelID VARCHAR(64),"                                        \
        "UnitId INTEGER,"                                            \
        "RecipeName VARCHAR(64),"                                    \
        "ReceivedTime TIME,"                                        \
        "BeginSamplingTime TIME,"                                    \
        "EndSamplingTime TIME,"                                        \
        "RemovedTime TIME,"                                            \
        "Ari1 REAL,"                                                \
        "Ari2 REAL,"                                                \
        "Ari3 REAL,"                                                \
        "Pre1 INTEGER,"                                                \
        "Tmp1 REAL,"                                                \
        "Tmp2 REAL,"                                                \
        "Temp0Max REAL,"                                            \
        "Temp0Min REAL,"                                            \
        "Temp0Ave REAL,"                                            \
        "Temp1Max REAL,"                                            \
        "Temp1Min REAL,"                                            \
        "Temp1Ave REAL,"                                            \
        "Temp2Max REAL,"                                            \
        "Temp2Min REAL,"                                            \
        "Temp2Ave REAL,"                                            \
        "Temp3Max REAL,"                                            \
        "Temp3Min REAL,"                                            \
        "Temp3Ave REAL,"                                            \
        "Temp4Max REAL,"                                            \
        "Temp4Min REAL,"                                            \
        "Temp4Ave REAL,"                                            \
        "Temp5Max REAL,"                                            \
        "Temp5Min REAL,"                                            \
        "Temp5Ave REAL,"                                            \
        "Temp6Max REAL,"                                            \
        "Temp6Min REAL,"                                            \
        "Temp6Ave REAL,"                                            \
        "Temp7Max REAL,"                                            \
        "Temp7Min REAL,"                                            \
        "Temp7Ave REAL,"                                            \
        "Temp8Max REAL,"                                            \
        "Temp8Min REAL,"                                            \
        "Temp8Ave REAL,"                                            \
        "Temp9Max REAL,"                                            \
        "Temp9Min REAL,"                                            \
        "Temp9Ave REAL,"                                            \
        "VacuumMax REAL,"                                        \
        "VacuumMin REAL,"                                        \
        "VacuumAve REAL,"                                        \
        "Pressure0Max REAL,"                                        \
        "Pressure0Min REAL,"                                        \
        "Pressure0Ave REAL,"                                        \
        "Pressure1Max REAL,"                                        \
        "Pressure1Min REAL,"                                        \
        "Pressure1Ave REAL,"                                        \
        "Pressure2Max REAL,"                                        \
        "Pressure2Min REAL,"                                        \
        "Pressure2Ave REAL,"                                        \
        "Pressure3Max REAL,"                                        \
        "Pressure3Min REAL,"                                        \
        "Pressure3Ave REAL,"                                        \
        "Pressure4Max REAL,"                                        \
        "Pressure4Min REAL,"                                        \
        "Pressure4Ave REAL,"                                        \
        "Datas BLOB);";
    nRet = sqlite3_exec(m_db, sql, 0, 0, &pszError);
    if (pszError != nullptr) {
        strError = pszError;
        sqlite3_free(pszError);
    }
    return nRet;
}
int CGB2860SQLite::term()
{
    if (m_db != nullptr) {
        sqlite3_close(m_db);
        m_db = nullptr;
    }
    return 0;
}
int CGB2860SQLite::insertPanel(CPanel* pPanel, std::string& strError)
{
    if (m_db == nullptr) return -1;
    //插入数据
    char* pszError = nullptr;
    char szSQL[1024];
    UNITDATA1& dataMax = pPanel->getMathData(IMAX);
    UNITDATA1& dataMin = pPanel->getMathData(IMIN);
    UNITDATA1& dataAve = pPanel->getMathData(IAVE);
    sprintf_s(szSQL, 1024, "INSERT INTO Panels VALUES(NULL, '%s', %d, '%s', "        \
        "'%s', '%s', '%s', '%s',"        \
        "%f, %f, %f, %d, %f, %f, "        \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f,"            \
        "%f, %f, %f, ?);",
        pPanel->getQRCode().c_str(),
        pPanel->getUnitId(),
        pPanel->getRecipeName().c_str(),
        CToolUnits::timeToString2(pPanel->getReceivedTime()).c_str(),
        CToolUnits::timeToString2(pPanel->getBeginSamplingTime()).c_str(),
        CToolUnits::timeToString2(pPanel->getEndSamplingTime()).c_str(),
        CToolUnits::timeToString2(pPanel->getRemovedTime()).c_str(),
        pPanel->getAir1(),
        pPanel->getAir2(),
        pPanel->getAir3(),
        pPanel->getPre1(),
        pPanel->getTmp1(),
        pPanel->getTmp2(),
        dataMax.temp[0], dataMin.temp[0], dataAve.temp[0],
        dataMax.temp[1], dataMin.temp[1], dataAve.temp[1],
        dataMax.temp[2], dataMin.temp[2], dataAve.temp[2],
        dataMax.temp[3], dataMin.temp[3], dataAve.temp[3],
        dataMax.temp[4], dataMin.temp[4], dataAve.temp[4],
        dataMax.temp[5], dataMin.temp[5], dataAve.temp[5],
        dataMax.temp[6], dataMin.temp[6], dataAve.temp[6],
        dataMax.temp[7], dataMin.temp[7], dataAve.temp[7],
        dataMax.temp[8], dataMin.temp[8], dataAve.temp[8],
        dataMax.temp[9], dataMin.temp[9], dataAve.temp[9],
        dataMax.vacuum, dataMin.vacuum, dataAve.vacuum,
        dataMax.pressure[0], dataMin.pressure[0], dataAve.pressure[0],
        dataMax.pressure[1], dataMin.pressure[1], dataAve.pressure[1],
        dataMax.pressure[2], dataMin.pressure[2], dataAve.pressure[2],
        dataMax.pressure[3], dataMin.pressure[3], dataAve.pressure[3],
        dataMax.pressure[4], dataMin.pressure[4], dataAve.pressure[4]);
    char* pBlod = nullptr;
    int nSize = pPanel->getBlodLen();
    pBlod = new char[nSize];
    pPanel->getBlod(pBlod, nSize);
    sqlite3_stmt *stmt;
    sqlite3_prepare(m_db, szSQL, (int)strlen(szSQL), &stmt, 0);
    sqlite3_bind_blob(stmt, 1, pBlod, nSize, NULL);
    int nRet = sqlite3_step(stmt);
    sqlite3_finalize(stmt);
    return 0;
}
int CGB2860SQLite::getPanelList(const char* pszKeyword, int nSearchFlag,
    int dtFlag, const char* pszStartTime, const char* pszEndTime,
    std::list<CPanel*>& list, std::string& strError)
{
    if (m_db == nullptr) return -1;
    int nRet;
    CString strSQL = _T("SELECT * FROM Panels Where (1=2");
    if ((nSearchFlag & 0x01) == 0x01) {
        strSQL.AppendFormat(" OR PanelID like '%s%s%s'", "%", pszKeyword, "%");
    }
    strSQL.Append(")");
    if (dtFlag != 0) {
        strSQL.AppendFormat(" AND (ReceivedTime BETWEEN '%s' AND '%s')",
            pszStartTime, pszEndTime);
    }
    strSQL.Append(" ORDER BY ID DESC LIMIT 3000");    // ASC
    sqlite3_stmt *stmt;
    sqlite3_prepare(m_db, (LPTSTR)(LPCTSTR)strSQL, strSQL.GetLength(), &stmt, 0);
    nRet = sqlite3_step(stmt);
    while (nRet == SQLITE_ROW) {
        int id, unitId;
        double air1, air2, air3, tmp1, tmp2;
        int pre1;
        const unsigned char* pszQRCode, *pszRecipeName;
        const unsigned char* pszReceivedTime, *pszBeginTime, *pszEndTime, *pszRemovedTime;
        const void * pBolbData;
        int nBlodDataLen;
        id = sqlite3_column_int(stmt, 0);
        pszQRCode = sqlite3_column_text(stmt, 1);
        unitId = sqlite3_column_int(stmt, 2);
        pszRecipeName = sqlite3_column_text(stmt, 3);
        pszReceivedTime = sqlite3_column_text(stmt, 4);
        pszBeginTime = sqlite3_column_text(stmt, 5);
        pszEndTime = sqlite3_column_text(stmt, 6);
        pszRemovedTime = sqlite3_column_text(stmt, 7);
        air1 = sqlite3_column_double(stmt, 8);
        air2 = sqlite3_column_double(stmt, 9);
        air3 = sqlite3_column_double(stmt, 10);
        pre1 = sqlite3_column_int(stmt, 11);
        tmp1 = sqlite3_column_double(stmt, 12);
        tmp2 = sqlite3_column_double(stmt, 13);
        pBolbData = sqlite3_column_blob(stmt, 62);
        nBlodDataLen = sqlite3_column_bytes(stmt, 62);
        CPanel* pPanel = new CPanel();
        pPanel->setQRCode((const char*)pszQRCode);
        pPanel->setUnitId(unitId);
        pPanel->setRecipeName((const char*)pszRecipeName);
        pPanel->setReceivedTime(CToolUnits::stringToTime((const char*)pszReceivedTime));
        pPanel->setBeginSamplingTime(CToolUnits::stringToTime((const char*)pszBeginTime));
        pPanel->setEndSamplingTime(CToolUnits::stringToTime((const char*)pszEndTime));
        pPanel->setRemovedTime(CToolUnits::stringToTime((const char*)pszRemovedTime));
        pPanel->setAir1(air1);
        pPanel->setAir2(air2);
        pPanel->setAir3(air3);
        pPanel->setPre1(pre1);
        pPanel->setTmp1(tmp1);
        pPanel->setTmp2(tmp2);
        pPanel->setBlod((char*)pBolbData, nBlodDataLen);
        list.push_back(pPanel);
        nRet = sqlite3_step(stmt);
    }
    sqlite3_finalize(stmt);
    return (int)list.size();
}
int CGB2860SQLite::getPanelWithPanelId(const char* pszBoxId, CPanel*& pPanel, std::string& strError)
{
    if (m_db == nullptr) return -1;
    int nRet;
    CString strSQL;
    strSQL.Format(_T("SELECT * FROM Panels Where PanelID = '%s' ORDER BY ID ASC"), pszBoxId);
    sqlite3_stmt *stmt;
    sqlite3_prepare(m_db, (LPTSTR)(LPCTSTR)strSQL, strSQL.GetLength(), &stmt, 0);
    nRet = sqlite3_step(stmt);
    if (nRet == SQLITE_ROW) {
        int id, unitId;
        double air1, air2, air3, tmp1, tmp2;
        int pre1;
        const unsigned char* pszQRCode, *pszRecipeName;
        const unsigned char* pszReceivedTime, *pszBeginTime, *pszEndTime, *pszRemovedTime;
        const void * pBolbData;
        int nBlodDataLen;
        id = sqlite3_column_int(stmt, 0);
        pszQRCode = sqlite3_column_text(stmt, 1);
        unitId = sqlite3_column_int(stmt, 2);
        pszRecipeName = sqlite3_column_text(stmt, 3);
        pszReceivedTime = sqlite3_column_text(stmt, 4);
        pszBeginTime = sqlite3_column_text(stmt, 5);
        pszEndTime = sqlite3_column_text(stmt, 6);
        pszRemovedTime = sqlite3_column_text(stmt, 7);
        air1 = sqlite3_column_double(stmt, 8);
        air2 = sqlite3_column_double(stmt, 9);
        air3 = sqlite3_column_double(stmt, 10);
        pre1 = sqlite3_column_int(stmt, 11);
        tmp1 = sqlite3_column_double(stmt, 12);
        tmp2 = sqlite3_column_double(stmt, 13);
        pBolbData = sqlite3_column_blob(stmt, 62);
        nBlodDataLen = sqlite3_column_bytes(stmt, 62);
        CPanel* pPanel = new CPanel();
        pPanel->setQRCode((const char*)pszQRCode);
        pPanel->setUnitId(unitId);
        pPanel->setRecipeName((const char*)pszRecipeName);
        pPanel->setReceivedTime(CToolUnits::stringToTime((const char*)pszReceivedTime));
        pPanel->setBeginSamplingTime(CToolUnits::stringToTime((const char*)pszBeginTime));
        pPanel->setEndSamplingTime(CToolUnits::stringToTime((const char*)pszEndTime));
        pPanel->setRemovedTime(CToolUnits::stringToTime((const char*)pszRemovedTime));
        pPanel->setAir1(air1);
        pPanel->setAir2(air2);
        pPanel->setAir3(air3);
        pPanel->setPre1(pre1);
        pPanel->setTmp1(tmp1);
        pPanel->setTmp2(tmp2);
        pPanel->setBlod((char*)pBolbData, nBlodDataLen);
    }
    sqlite3_finalize(stmt);
    return 0;
}
SourceCode/Bond/BondEq/GB2860SQLite.h
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,26 @@
#pragma once
#include "sqlite3.h"
#include "CPanel.h"
#include <list>
class CGB2860SQLite
{
public:
    CGB2860SQLite();
    ~CGB2860SQLite();
public:
    void setDbFilepath(const char* pszFilepath);
    int init(std::string& strError);
    int term();
    int insertPanel(CPanel* pPanel, std::string& strError);
    int getPanelList(const char* pszKeyword, int nSearchFlag,
        int dtFlag, const char* pszStartTime, const char* pszEndTime,
        std::list<CPanel*>& list, std::string& strError);
    int getPanelWithPanelId(const char* pszPanelId, CPanel*& pPanel, std::string& strError);
private:
    std::string m_strDbFilepath;
    sqlite3* m_db;
};
SourceCode/Bond/BondEq/Model.cpp
@@ -4,6 +4,8 @@
#include "Model.h"
#include "Log.h"
#include "ToolUnits.h"
#include "Alarm.h"
#include "EQState.h"
CModel* g_pModel = NULL;
@@ -36,6 +38,7 @@
void CModel::setWorkDir(const char* pszWorkDir)
{
    m_strWorkDir = pszWorkDir;
    m_bonder.setWorkDir(pszWorkDir);
}
int CModel::init()
@@ -97,6 +100,76 @@
    m_nTimerID = (int)SetTimer(NULL, 1, 1000, (TIMERPROC)ModerTimerProc);
    g_pModel = this;
    BondListener bonderListener;
    bonderListener.onStateChanged = [&](void* pFrom, int state) -> void {
        notifyInt(RX_CODE_BONDER_STATE_CHANGED, state);
    };
    bonderListener.onPlcStateChanged = [&](void* pFrom, int state) -> void {
        PLCSTATE ps = (PLCSTATE)state;
        if (ps == PLCSTATE::CONNECTED) {
            notifyPtrAndInt(RX_CODE_PLC1_CONNECTTD, pFrom, 0, state);
        }
        else if (ps == PLCSTATE::DISCONNECTED) {
            notifyPtrAndInt(RX_CODE_PLC1_DISCONNECTTD, pFrom, 0, state);
        }
    };
    bonderListener.onEfemStateChanged = [&](void* pFrom, const char* pszAddr, int port, int state) -> void {
        if (m_pObservableEmitter != NULL) {
            IAny* pAny = RX_AllocaAny();
            if (pAny != NULL) {
                pAny->addRef();
                pAny->setCode(RX_CODE_EFEM_STATUS_CHANGED);
                pAny->setStringValue("addr", pszAddr);
                pAny->setIntValue("port", port);
                pAny->setIntValue("state", state);
                m_pObservableEmitter->onNext(pAny);
                pAny->release();
            }
        }
    };
    bonderListener.onRecvBroadcast = [&](void* pFrom, void* p) -> void {
        CComponent* pSender = (CComponent*)pFrom;
        CIntent* pIntent = (CIntent*)p;
        int code = pIntent->getCode();
        if (code == BC_CODE_DATA1_MATERIAL_RECEIVED) {
            notifyPtr(RX_CODE_DATA1_MATERIAL_RECEIVED, pSender);
        }
        else if (code == BC_CODE_DATA1_BEGIN_SAMPLING) {
            notifyPtr(RX_CODE_DATA1_BEGIN_SAMPLING, pSender);
        }
        else if (code == BC_CODE_DATA1_UPDATE) {
            notifyPtr(RX_CODE_DATA1_UPDATE, pSender);
        }
        else if (code == BC_CODE_DATA1_END_SAMPLING) {
            notifyPtr(RX_CODE_DATA1_END_SAMPLING, pSender);
        }
        else if (code == BC_CODE_DATA1_MATERIAL_REMOVED) {
            std::string strError;
            CPanel* pPanel = (CPanel*)pIntent->getContext();
            pPanel->addRef();
            savePanel(pPanel, pSender);
            m_sqlite.insertPanel(pPanel, strError);
            notifyPtr(RX_CODE_DATA1_MATERIAL_REMOVEED, pSender);
            notifyObj(RX_CODE_PANEL_COMPLATE, pPanel);
            pPanel->release();
        }
        else if (code == BC_CODE_ALARM_EVENT) {
            CAlarm* pAlarm = (CAlarm*)pIntent->getContext();
            pAlarm->addRef();
            notifyObjAndPtr(RX_CODE_ALARM_EVENT, pAlarm, pSender);
            pAlarm->release();
        }
        else if (code == BC_CODE_EQSTATE_EVENT) {
            CEQState* pState = (CEQState*)pIntent->getContext();
            pState->addRef();
            notifyObjAndPtr(RX_CODE_EQSTATE_EVENT, pState, pSender);
            pState->release();
        }
    };
    m_bonder.setListener(bonderListener);
    m_bonder.init();
    return 0;
@@ -293,4 +366,113 @@
void CModel::onTimer(UINT nTimerid)
{
}
}
int CModel::savePanel(CPanel* pPanel, CComponent* pComponent)
{
    int year, month, day;
    pPanel->getReceivedTime(year, month, day);
    CString strDir, strFilepath;
    strDir.Format("%s\\%d\\%d\\%d", (LPTSTR)(LPCTSTR)m_strDataDir, year, month, day);
    CToolUnits::createDir((LPTSTR)(LPCTSTR)strDir);
    strFilepath.Format("%s\\%s.csv", (LPTSTR)(LPCTSTR)strDir, pPanel->getQRCode().c_str());
    CStdioFile file;
    if (!file.Open(strFilepath, CFile::modeCreate | CFile::modeWrite)) {
        return -1;
    }
    // åŸºæœ¬ä¿¡æ¯
    // æ¥æºï¼Œ id,开始采样时间,结束采样时间
    CString strLine;
    file.WriteString("# ç»Ÿè®¡\n");
    strLine.Format(_T("来源,%s\n"), pComponent->getName().c_str());
    file.WriteString(strLine);
    strLine.Format(_T("id,%s\n"), pPanel->getQRCode().c_str());
    file.WriteString(strLine);
    strLine.Format(_T("来料时间,%s\n"),
        CToolUnits::timeToString3(pPanel->getReceivedTime()).c_str());
    file.WriteString(strLine);
    strLine.Format(_T("采样开始时间,%s\n"),
        CToolUnits::timeToString3(pPanel->getBeginSamplingTime()).c_str());
    file.WriteString(strLine);
    strLine.Format(_T("采样结束时间,%s\n"),
        CToolUnits::timeToString3(pPanel->getEndSamplingTime()).c_str());
    file.WriteString(strLine);
    strLine.Format(_T("出料时间,%s\n"),
        CToolUnits::timeToString3(pPanel->getRemovedTime()).c_str());
    file.WriteString(strLine);
    strLine.Format(_T("Recipe name,%s\n"), pPanel->getRecipeName().c_str());
    file.WriteString(strLine);
    strLine.Format(_T("干泵吸真空值,%f\n"), pPanel->getAir1());
    file.WriteString(strLine);
    strLine.Format(_T("分子泵吸真空值,%f\n"), pPanel->getAir2());
    file.WriteString(strLine);
    strLine.Format(_T("气囊压力值,%f\n"), pPanel->getAir3());
    file.WriteString(strLine);
    strLine.Format(_T("贴合总压力,%d\n"), pPanel->getPre1());
    file.WriteString(strLine);
    strLine.Format(_T("上腔体温度,%f\n"), pPanel->getTmp1());
    file.WriteString(strLine);
    strLine.Format(_T("下腔体温度,%f\n"), pPanel->getTmp2());
    file.WriteString(strLine);
    file.WriteString("\n");
    // ç»Ÿè®¡åŒº
    file.WriteString("# ç»Ÿè®¡\n");
    file.WriteString("项,上腔体温度(℃),下腔体温度(℃),上腔体温度1(℃),上腔体温度2(℃),上腔体温度3(℃),上腔体温度4(℃),上腔体温度5(℃),下腔体温度1(℃),下腔体温度2(℃),下腔体温度3(℃),下腔体温度4(℃),下腔体温度5(℃),腔体真空(Pa),腔体压力1(Kg),腔体压力2(Kg),腔体压力3(Kg),腔体压力4(Kg),腔体压力5(Kg)\n");
    UNITDATA1 dataMax = pPanel->getMathData(IMAX);
    strLine.Format(_T("最大值,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.03f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f\n"),
        dataMax.temp[0], dataMax.temp[1],
        dataMax.temp[2], dataMax.temp[3], dataMax.temp[4], dataMax.temp[5], dataMax.temp[6],
        dataMax.temp[7], dataMax.temp[8], dataMax.temp[9], dataMax.temp[10], dataMax.temp[11],
        dataMax.vacuum,
        dataMax.pressure[0], dataMax.pressure[1], dataMax.pressure[2],
        dataMax.pressure[3], dataMax.pressure[4]);
    file.WriteString(strLine);
    UNITDATA1 dataMin = pPanel->getMathData(IMIN);
    strLine.Format(_T("最小值,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.03f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f\n"),
        dataMin.temp[0], dataMin.temp[1],
        dataMin.temp[2], dataMin.temp[3], dataMin.temp[4], dataMin.temp[5], dataMin.temp[6],
        dataMin.temp[7], dataMin.temp[8], dataMin.temp[9], dataMin.temp[10], dataMin.temp[11],
        dataMin.vacuum,
        dataMin.pressure[0], dataMin.pressure[1], dataMin.pressure[2],
        dataMin.pressure[3], dataMin.pressure[4]);
    file.WriteString(strLine);
    UNITDATA1 dataAve = pPanel->getMathData(IAVE);
    strLine.Format(_T("平均值,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.03f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f\n"),
        dataAve.temp[0], dataAve.temp[1],
        dataAve.temp[2], dataAve.temp[3], dataAve.temp[4], dataAve.temp[5], dataAve.temp[6],
        dataAve.temp[7], dataAve.temp[8], dataAve.temp[9], dataAve.temp[10], dataAve.temp[11],
        dataAve.vacuum,
        dataAve.pressure[0], dataAve.pressure[1], dataAve.pressure[2],
        dataAve.pressure[3], dataAve.pressure[4]);
    file.WriteString(strLine);
    file.WriteString("\n");
    // æ•°æ®åŒº
    file.WriteString("# æ•°æ®åŒº\n");
    file.WriteString("时间,上腔体温度(℃),下腔体温度(℃),上腔体温度1(℃),上腔体温度2(℃),上腔体温度3(℃),上腔体温度4(℃),上腔体温度5(℃),下腔体温度1(℃),下腔体温度2(℃),下腔体温度3(℃),下腔体温度4(℃),下腔体温度5(℃),腔体真空(Pa),腔体压力1(Kg),腔体压力2(Kg),腔体压力3(Kg),腔体压力4(Kg),腔体压力5(Kg)\n");
    std::vector<UNITDATA1> datas;
    pPanel->getDatas(datas);
    for (auto item : datas) {
        strLine.Format(_T("%s,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.03f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f,%.01f\n"),
            CToolUnits::timeToString3(item.time).c_str(),
            item.temp[0], item.temp[1],
            item.temp[2], item.temp[3], item.temp[4], item.temp[5], item.temp[6],
            item.temp[7], item.temp[8], item.temp[9], item.temp[10], item.temp[11],
            item.vacuum,
            item.pressure[0], item.pressure[1], item.pressure[2],
            item.pressure[3], item.pressure[4]);
        file.WriteString(strLine);
    }
    file.Close();
    return 0;
}
SourceCode/Bond/BondEq/Model.h
@@ -1,6 +1,8 @@
#pragma once
#include "CBonder.h"
#include "Configuration.h"
#include "CPanel.h"
#include "GB2860SQLite.h"
class CModel
@@ -30,6 +32,9 @@
    int notifyTextAndInt(int code, const char* pszText, int exCode);
    int notifyMesMsg(int code, int stream, int function, const char* pszText);
private:
    int savePanel(CPanel* pPanel, CComponent* pComponent);
public:
    CConfiguration m_configuration;
@@ -44,5 +49,6 @@
    CBonder m_bonder;
    BEQ::IEquipment* m_pEquipment;
    int m_nTimerID;
    CGB2860SQLite m_sqlite;
};
SourceCode/Bond/BondEq/sqlite3.c
¶Ô±ÈÐÂÎļþ
ÎļþÌ«´ó
SourceCode/Bond/BondEq/sqlite3.h
¶Ô±ÈÐÂÎļþ
ÎļþÌ«´ó
SourceCode/Bond/BondEq/sqlite3ext.h
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,719 @@
/*
** 2006 June 7
**
** The author disclaims copyright to this source code.  In place of
** a legal notice, here is a blessing:
**
**    May you do good and not evil.
**    May you find forgiveness for yourself and forgive others.
**    May you share freely, never taking more than you give.
**
*************************************************************************
** This header file defines the SQLite interface for use by
** shared libraries that want to be imported as extensions into
** an SQLite instance.  Shared libraries that intend to be loaded
** as extensions by SQLite should #include this file instead of
** sqlite3.h.
*/
#ifndef SQLITE3EXT_H
#define SQLITE3EXT_H
#include "sqlite3.h"
/*
** The following structure holds pointers to all of the SQLite API
** routines.
**
** WARNING:  In order to maintain backwards compatibility, add new
** interfaces to the end of this structure only.  If you insert new
** interfaces in the middle of this structure, then older different
** versions of SQLite will not be able to load each other's shared
** libraries!
*/
struct sqlite3_api_routines {
  void * (*aggregate_context)(sqlite3_context*,int nBytes);
  int  (*aggregate_count)(sqlite3_context*);
  int  (*bind_blob)(sqlite3_stmt*,int,const void*,int n,void(*)(void*));
  int  (*bind_double)(sqlite3_stmt*,int,double);
  int  (*bind_int)(sqlite3_stmt*,int,int);
  int  (*bind_int64)(sqlite3_stmt*,int,sqlite_int64);
  int  (*bind_null)(sqlite3_stmt*,int);
  int  (*bind_parameter_count)(sqlite3_stmt*);
  int  (*bind_parameter_index)(sqlite3_stmt*,const char*zName);
  const char * (*bind_parameter_name)(sqlite3_stmt*,int);
  int  (*bind_text)(sqlite3_stmt*,int,const char*,int n,void(*)(void*));
  int  (*bind_text16)(sqlite3_stmt*,int,const void*,int,void(*)(void*));
  int  (*bind_value)(sqlite3_stmt*,int,const sqlite3_value*);
  int  (*busy_handler)(sqlite3*,int(*)(void*,int),void*);
  int  (*busy_timeout)(sqlite3*,int ms);
  int  (*changes)(sqlite3*);
  int  (*close)(sqlite3*);
  int  (*collation_needed)(sqlite3*,void*,void(*)(void*,sqlite3*,
                           int eTextRep,const char*));
  int  (*collation_needed16)(sqlite3*,void*,void(*)(void*,sqlite3*,
                             int eTextRep,const void*));
  const void * (*column_blob)(sqlite3_stmt*,int iCol);
  int  (*column_bytes)(sqlite3_stmt*,int iCol);
  int  (*column_bytes16)(sqlite3_stmt*,int iCol);
  int  (*column_count)(sqlite3_stmt*pStmt);
  const char * (*column_database_name)(sqlite3_stmt*,int);
  const void * (*column_database_name16)(sqlite3_stmt*,int);
  const char * (*column_decltype)(sqlite3_stmt*,int i);
  const void * (*column_decltype16)(sqlite3_stmt*,int);
  double  (*column_double)(sqlite3_stmt*,int iCol);
  int  (*column_int)(sqlite3_stmt*,int iCol);
  sqlite_int64  (*column_int64)(sqlite3_stmt*,int iCol);
  const char * (*column_name)(sqlite3_stmt*,int);
  const void * (*column_name16)(sqlite3_stmt*,int);
  const char * (*column_origin_name)(sqlite3_stmt*,int);
  const void * (*column_origin_name16)(sqlite3_stmt*,int);
  const char * (*column_table_name)(sqlite3_stmt*,int);
  const void * (*column_table_name16)(sqlite3_stmt*,int);
  const unsigned char * (*column_text)(sqlite3_stmt*,int iCol);
  const void * (*column_text16)(sqlite3_stmt*,int iCol);
  int  (*column_type)(sqlite3_stmt*,int iCol);
  sqlite3_value* (*column_value)(sqlite3_stmt*,int iCol);
  void * (*commit_hook)(sqlite3*,int(*)(void*),void*);
  int  (*complete)(const char*sql);
  int  (*complete16)(const void*sql);
  int  (*create_collation)(sqlite3*,const char*,int,void*,
                           int(*)(void*,int,const void*,int,const void*));
  int  (*create_collation16)(sqlite3*,const void*,int,void*,
                             int(*)(void*,int,const void*,int,const void*));
  int  (*create_function)(sqlite3*,const char*,int,int,void*,
                          void (*xFunc)(sqlite3_context*,int,sqlite3_value**),
                          void (*xStep)(sqlite3_context*,int,sqlite3_value**),
                          void (*xFinal)(sqlite3_context*));
  int  (*create_function16)(sqlite3*,const void*,int,int,void*,
                            void (*xFunc)(sqlite3_context*,int,sqlite3_value**),
                            void (*xStep)(sqlite3_context*,int,sqlite3_value**),
                            void (*xFinal)(sqlite3_context*));
  int (*create_module)(sqlite3*,const char*,const sqlite3_module*,void*);
  int  (*data_count)(sqlite3_stmt*pStmt);
  sqlite3 * (*db_handle)(sqlite3_stmt*);
  int (*declare_vtab)(sqlite3*,const char*);
  int  (*enable_shared_cache)(int);
  int  (*errcode)(sqlite3*db);
  const char * (*errmsg)(sqlite3*);
  const void * (*errmsg16)(sqlite3*);
  int  (*exec)(sqlite3*,const char*,sqlite3_callback,void*,char**);
  int  (*expired)(sqlite3_stmt*);
  int  (*finalize)(sqlite3_stmt*pStmt);
  void  (*free)(void*);
  void  (*free_table)(char**result);
  int  (*get_autocommit)(sqlite3*);
  void * (*get_auxdata)(sqlite3_context*,int);
  int  (*get_table)(sqlite3*,const char*,char***,int*,int*,char**);
  int  (*global_recover)(void);
  void  (*interruptx)(sqlite3*);
  sqlite_int64  (*last_insert_rowid)(sqlite3*);
  const char * (*libversion)(void);
  int  (*libversion_number)(void);
  void *(*malloc)(int);
  char * (*mprintf)(const char*,...);
  int  (*open)(const char*,sqlite3**);
  int  (*open16)(const void*,sqlite3**);
  int  (*prepare)(sqlite3*,const char*,int,sqlite3_stmt**,const char**);
  int  (*prepare16)(sqlite3*,const void*,int,sqlite3_stmt**,const void**);
  void * (*profile)(sqlite3*,void(*)(void*,const char*,sqlite_uint64),void*);
  void  (*progress_handler)(sqlite3*,int,int(*)(void*),void*);
  void *(*realloc)(void*,int);
  int  (*reset)(sqlite3_stmt*pStmt);
  void  (*result_blob)(sqlite3_context*,const void*,int,void(*)(void*));
  void  (*result_double)(sqlite3_context*,double);
  void  (*result_error)(sqlite3_context*,const char*,int);
  void  (*result_error16)(sqlite3_context*,const void*,int);
  void  (*result_int)(sqlite3_context*,int);
  void  (*result_int64)(sqlite3_context*,sqlite_int64);
  void  (*result_null)(sqlite3_context*);
  void  (*result_text)(sqlite3_context*,const char*,int,void(*)(void*));
  void  (*result_text16)(sqlite3_context*,const void*,int,void(*)(void*));
  void  (*result_text16be)(sqlite3_context*,const void*,int,void(*)(void*));
  void  (*result_text16le)(sqlite3_context*,const void*,int,void(*)(void*));
  void  (*result_value)(sqlite3_context*,sqlite3_value*);
  void * (*rollback_hook)(sqlite3*,void(*)(void*),void*);
  int  (*set_authorizer)(sqlite3*,int(*)(void*,int,const char*,const char*,
                         const char*,const char*),void*);
  void  (*set_auxdata)(sqlite3_context*,int,void*,void (*)(void*));
  char * (*xsnprintf)(int,char*,const char*,...);
  int  (*step)(sqlite3_stmt*);
  int  (*table_column_metadata)(sqlite3*,const char*,const char*,const char*,
                                char const**,char const**,int*,int*,int*);
  void  (*thread_cleanup)(void);
  int  (*total_changes)(sqlite3*);
  void * (*trace)(sqlite3*,void(*xTrace)(void*,const char*),void*);
  int  (*transfer_bindings)(sqlite3_stmt*,sqlite3_stmt*);
  void * (*update_hook)(sqlite3*,void(*)(void*,int ,char const*,char const*,
                                         sqlite_int64),void*);
  void * (*user_data)(sqlite3_context*);
  const void * (*value_blob)(sqlite3_value*);
  int  (*value_bytes)(sqlite3_value*);
  int  (*value_bytes16)(sqlite3_value*);
  double  (*value_double)(sqlite3_value*);
  int  (*value_int)(sqlite3_value*);
  sqlite_int64  (*value_int64)(sqlite3_value*);
  int  (*value_numeric_type)(sqlite3_value*);
  const unsigned char * (*value_text)(sqlite3_value*);
  const void * (*value_text16)(sqlite3_value*);
  const void * (*value_text16be)(sqlite3_value*);
  const void * (*value_text16le)(sqlite3_value*);
  int  (*value_type)(sqlite3_value*);
  char *(*vmprintf)(const char*,va_list);
  /* Added ??? */
  int (*overload_function)(sqlite3*, const char *zFuncName, int nArg);
  /* Added by 3.3.13 */
  int (*prepare_v2)(sqlite3*,const char*,int,sqlite3_stmt**,const char**);
  int (*prepare16_v2)(sqlite3*,const void*,int,sqlite3_stmt**,const void**);
  int (*clear_bindings)(sqlite3_stmt*);
  /* Added by 3.4.1 */
  int (*create_module_v2)(sqlite3*,const char*,const sqlite3_module*,void*,
                          void (*xDestroy)(void *));
  /* Added by 3.5.0 */
  int (*bind_zeroblob)(sqlite3_stmt*,int,int);
  int (*blob_bytes)(sqlite3_blob*);
  int (*blob_close)(sqlite3_blob*);
  int (*blob_open)(sqlite3*,const char*,const char*,const char*,sqlite3_int64,
                   int,sqlite3_blob**);
  int (*blob_read)(sqlite3_blob*,void*,int,int);
  int (*blob_write)(sqlite3_blob*,const void*,int,int);
  int (*create_collation_v2)(sqlite3*,const char*,int,void*,
                             int(*)(void*,int,const void*,int,const void*),
                             void(*)(void*));
  int (*file_control)(sqlite3*,const char*,int,void*);
  sqlite3_int64 (*memory_highwater)(int);
  sqlite3_int64 (*memory_used)(void);
  sqlite3_mutex *(*mutex_alloc)(int);
  void (*mutex_enter)(sqlite3_mutex*);
  void (*mutex_free)(sqlite3_mutex*);
  void (*mutex_leave)(sqlite3_mutex*);
  int (*mutex_try)(sqlite3_mutex*);
  int (*open_v2)(const char*,sqlite3**,int,const char*);
  int (*release_memory)(int);
  void (*result_error_nomem)(sqlite3_context*);
  void (*result_error_toobig)(sqlite3_context*);
  int (*sleep)(int);
  void (*soft_heap_limit)(int);
  sqlite3_vfs *(*vfs_find)(const char*);
  int (*vfs_register)(sqlite3_vfs*,int);
  int (*vfs_unregister)(sqlite3_vfs*);
  int (*xthreadsafe)(void);
  void (*result_zeroblob)(sqlite3_context*,int);
  void (*result_error_code)(sqlite3_context*,int);
  int (*test_control)(int, ...);
  void (*randomness)(int,void*);
  sqlite3 *(*context_db_handle)(sqlite3_context*);
  int (*extended_result_codes)(sqlite3*,int);
  int (*limit)(sqlite3*,int,int);
  sqlite3_stmt *(*next_stmt)(sqlite3*,sqlite3_stmt*);
  const char *(*sql)(sqlite3_stmt*);
  int (*status)(int,int*,int*,int);
  int (*backup_finish)(sqlite3_backup*);
  sqlite3_backup *(*backup_init)(sqlite3*,const char*,sqlite3*,const char*);
  int (*backup_pagecount)(sqlite3_backup*);
  int (*backup_remaining)(sqlite3_backup*);
  int (*backup_step)(sqlite3_backup*,int);
  const char *(*compileoption_get)(int);
  int (*compileoption_used)(const char*);
  int (*create_function_v2)(sqlite3*,const char*,int,int,void*,
                            void (*xFunc)(sqlite3_context*,int,sqlite3_value**),
                            void (*xStep)(sqlite3_context*,int,sqlite3_value**),
                            void (*xFinal)(sqlite3_context*),
                            void(*xDestroy)(void*));
  int (*db_config)(sqlite3*,int,...);
  sqlite3_mutex *(*db_mutex)(sqlite3*);
  int (*db_status)(sqlite3*,int,int*,int*,int);
  int (*extended_errcode)(sqlite3*);
  void (*log)(int,const char*,...);
  sqlite3_int64 (*soft_heap_limit64)(sqlite3_int64);
  const char *(*sourceid)(void);
  int (*stmt_status)(sqlite3_stmt*,int,int);
  int (*strnicmp)(const char*,const char*,int);
  int (*unlock_notify)(sqlite3*,void(*)(void**,int),void*);
  int (*wal_autocheckpoint)(sqlite3*,int);
  int (*wal_checkpoint)(sqlite3*,const char*);
  void *(*wal_hook)(sqlite3*,int(*)(void*,sqlite3*,const char*,int),void*);
  int (*blob_reopen)(sqlite3_blob*,sqlite3_int64);
  int (*vtab_config)(sqlite3*,int op,...);
  int (*vtab_on_conflict)(sqlite3*);
  /* Version 3.7.16 and later */
  int (*close_v2)(sqlite3*);
  const char *(*db_filename)(sqlite3*,const char*);
  int (*db_readonly)(sqlite3*,const char*);
  int (*db_release_memory)(sqlite3*);
  const char *(*errstr)(int);
  int (*stmt_busy)(sqlite3_stmt*);
  int (*stmt_readonly)(sqlite3_stmt*);
  int (*stricmp)(const char*,const char*);
  int (*uri_boolean)(const char*,const char*,int);
  sqlite3_int64 (*uri_int64)(const char*,const char*,sqlite3_int64);
  const char *(*uri_parameter)(const char*,const char*);
  char *(*xvsnprintf)(int,char*,const char*,va_list);
  int (*wal_checkpoint_v2)(sqlite3*,const char*,int,int*,int*);
  /* Version 3.8.7 and later */
  int (*auto_extension)(void(*)(void));
  int (*bind_blob64)(sqlite3_stmt*,int,const void*,sqlite3_uint64,
                     void(*)(void*));
  int (*bind_text64)(sqlite3_stmt*,int,const char*,sqlite3_uint64,
                      void(*)(void*),unsigned char);
  int (*cancel_auto_extension)(void(*)(void));
  int (*load_extension)(sqlite3*,const char*,const char*,char**);
  void *(*malloc64)(sqlite3_uint64);
  sqlite3_uint64 (*msize)(void*);
  void *(*realloc64)(void*,sqlite3_uint64);
  void (*reset_auto_extension)(void);
  void (*result_blob64)(sqlite3_context*,const void*,sqlite3_uint64,
                        void(*)(void*));
  void (*result_text64)(sqlite3_context*,const char*,sqlite3_uint64,
                         void(*)(void*), unsigned char);
  int (*strglob)(const char*,const char*);
  /* Version 3.8.11 and later */
  sqlite3_value *(*value_dup)(const sqlite3_value*);
  void (*value_free)(sqlite3_value*);
  int (*result_zeroblob64)(sqlite3_context*,sqlite3_uint64);
  int (*bind_zeroblob64)(sqlite3_stmt*, int, sqlite3_uint64);
  /* Version 3.9.0 and later */
  unsigned int (*value_subtype)(sqlite3_value*);
  void (*result_subtype)(sqlite3_context*,unsigned int);
  /* Version 3.10.0 and later */
  int (*status64)(int,sqlite3_int64*,sqlite3_int64*,int);
  int (*strlike)(const char*,const char*,unsigned int);
  int (*db_cacheflush)(sqlite3*);
  /* Version 3.12.0 and later */
  int (*system_errno)(sqlite3*);
  /* Version 3.14.0 and later */
  int (*trace_v2)(sqlite3*,unsigned,int(*)(unsigned,void*,void*,void*),void*);
  char *(*expanded_sql)(sqlite3_stmt*);
  /* Version 3.18.0 and later */
  void (*set_last_insert_rowid)(sqlite3*,sqlite3_int64);
  /* Version 3.20.0 and later */
  int (*prepare_v3)(sqlite3*,const char*,int,unsigned int,
                    sqlite3_stmt**,const char**);
  int (*prepare16_v3)(sqlite3*,const void*,int,unsigned int,
                      sqlite3_stmt**,const void**);
  int (*bind_pointer)(sqlite3_stmt*,int,void*,const char*,void(*)(void*));
  void (*result_pointer)(sqlite3_context*,void*,const char*,void(*)(void*));
  void *(*value_pointer)(sqlite3_value*,const char*);
  int (*vtab_nochange)(sqlite3_context*);
  int (*value_nochange)(sqlite3_value*);
  const char *(*vtab_collation)(sqlite3_index_info*,int);
  /* Version 3.24.0 and later */
  int (*keyword_count)(void);
  int (*keyword_name)(int,const char**,int*);
  int (*keyword_check)(const char*,int);
  sqlite3_str *(*str_new)(sqlite3*);
  char *(*str_finish)(sqlite3_str*);
  void (*str_appendf)(sqlite3_str*, const char *zFormat, ...);
  void (*str_vappendf)(sqlite3_str*, const char *zFormat, va_list);
  void (*str_append)(sqlite3_str*, const char *zIn, int N);
  void (*str_appendall)(sqlite3_str*, const char *zIn);
  void (*str_appendchar)(sqlite3_str*, int N, char C);
  void (*str_reset)(sqlite3_str*);
  int (*str_errcode)(sqlite3_str*);
  int (*str_length)(sqlite3_str*);
  char *(*str_value)(sqlite3_str*);
  /* Version 3.25.0 and later */
  int (*create_window_function)(sqlite3*,const char*,int,int,void*,
                            void (*xStep)(sqlite3_context*,int,sqlite3_value**),
                            void (*xFinal)(sqlite3_context*),
                            void (*xValue)(sqlite3_context*),
                            void (*xInv)(sqlite3_context*,int,sqlite3_value**),
                            void(*xDestroy)(void*));
  /* Version 3.26.0 and later */
  const char *(*normalized_sql)(sqlite3_stmt*);
  /* Version 3.28.0 and later */
  int (*stmt_isexplain)(sqlite3_stmt*);
  int (*value_frombind)(sqlite3_value*);
  /* Version 3.30.0 and later */
  int (*drop_modules)(sqlite3*,const char**);
  /* Version 3.31.0 and later */
  sqlite3_int64 (*hard_heap_limit64)(sqlite3_int64);
  const char *(*uri_key)(const char*,int);
  const char *(*filename_database)(const char*);
  const char *(*filename_journal)(const char*);
  const char *(*filename_wal)(const char*);
  /* Version 3.32.0 and later */
  const char *(*create_filename)(const char*,const char*,const char*,
                           int,const char**);
  void (*free_filename)(const char*);
  sqlite3_file *(*database_file_object)(const char*);
  /* Version 3.34.0 and later */
  int (*txn_state)(sqlite3*,const char*);
  /* Version 3.36.1 and later */
  sqlite3_int64 (*changes64)(sqlite3*);
  sqlite3_int64 (*total_changes64)(sqlite3*);
  /* Version 3.37.0 and later */
  int (*autovacuum_pages)(sqlite3*,
     unsigned int(*)(void*,const char*,unsigned int,unsigned int,unsigned int),
     void*, void(*)(void*));
  /* Version 3.38.0 and later */
  int (*error_offset)(sqlite3*);
  int (*vtab_rhs_value)(sqlite3_index_info*,int,sqlite3_value**);
  int (*vtab_distinct)(sqlite3_index_info*);
  int (*vtab_in)(sqlite3_index_info*,int,int);
  int (*vtab_in_first)(sqlite3_value*,sqlite3_value**);
  int (*vtab_in_next)(sqlite3_value*,sqlite3_value**);
  /* Version 3.39.0 and later */
  int (*deserialize)(sqlite3*,const char*,unsigned char*,
                     sqlite3_int64,sqlite3_int64,unsigned);
  unsigned char *(*serialize)(sqlite3*,const char *,sqlite3_int64*,
                              unsigned int);
  const char *(*db_name)(sqlite3*,int);
  /* Version 3.40.0 and later */
  int (*value_encoding)(sqlite3_value*);
  /* Version 3.41.0 and later */
  int (*is_interrupted)(sqlite3*);
  /* Version 3.43.0 and later */
  int (*stmt_explain)(sqlite3_stmt*,int);
  /* Version 3.44.0 and later */
  void *(*get_clientdata)(sqlite3*,const char*);
  int (*set_clientdata)(sqlite3*, const char*, void*, void(*)(void*));
};
/*
** This is the function signature used for all extension entry points.  It
** is also defined in the file "loadext.c".
*/
typedef int (*sqlite3_loadext_entry)(
  sqlite3 *db,                       /* Handle to the database. */
  char **pzErrMsg,                   /* Used to set error string on failure. */
  const sqlite3_api_routines *pThunk /* Extension API function pointers. */
);
/*
** The following macros redefine the API routines so that they are
** redirected through the global sqlite3_api structure.
**
** This header file is also used by the loadext.c source file
** (part of the main SQLite library - not an extension) so that
** it can get access to the sqlite3_api_routines structure
** definition.  But the main library does not want to redefine
** the API.  So the redefinition macros are only valid if the
** SQLITE_CORE macros is undefined.
*/
#if !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION)
#define sqlite3_aggregate_context      sqlite3_api->aggregate_context
#ifndef SQLITE_OMIT_DEPRECATED
#define sqlite3_aggregate_count        sqlite3_api->aggregate_count
#endif
#define sqlite3_bind_blob              sqlite3_api->bind_blob
#define sqlite3_bind_double            sqlite3_api->bind_double
#define sqlite3_bind_int               sqlite3_api->bind_int
#define sqlite3_bind_int64             sqlite3_api->bind_int64
#define sqlite3_bind_null              sqlite3_api->bind_null
#define sqlite3_bind_parameter_count   sqlite3_api->bind_parameter_count
#define sqlite3_bind_parameter_index   sqlite3_api->bind_parameter_index
#define sqlite3_bind_parameter_name    sqlite3_api->bind_parameter_name
#define sqlite3_bind_text              sqlite3_api->bind_text
#define sqlite3_bind_text16            sqlite3_api->bind_text16
#define sqlite3_bind_value             sqlite3_api->bind_value
#define sqlite3_busy_handler           sqlite3_api->busy_handler
#define sqlite3_busy_timeout           sqlite3_api->busy_timeout
#define sqlite3_changes                sqlite3_api->changes
#define sqlite3_close                  sqlite3_api->close
#define sqlite3_collation_needed       sqlite3_api->collation_needed
#define sqlite3_collation_needed16     sqlite3_api->collation_needed16
#define sqlite3_column_blob            sqlite3_api->column_blob
#define sqlite3_column_bytes           sqlite3_api->column_bytes
#define sqlite3_column_bytes16         sqlite3_api->column_bytes16
#define sqlite3_column_count           sqlite3_api->column_count
#define sqlite3_column_database_name   sqlite3_api->column_database_name
#define sqlite3_column_database_name16 sqlite3_api->column_database_name16
#define sqlite3_column_decltype        sqlite3_api->column_decltype
#define sqlite3_column_decltype16      sqlite3_api->column_decltype16
#define sqlite3_column_double          sqlite3_api->column_double
#define sqlite3_column_int             sqlite3_api->column_int
#define sqlite3_column_int64           sqlite3_api->column_int64
#define sqlite3_column_name            sqlite3_api->column_name
#define sqlite3_column_name16          sqlite3_api->column_name16
#define sqlite3_column_origin_name     sqlite3_api->column_origin_name
#define sqlite3_column_origin_name16   sqlite3_api->column_origin_name16
#define sqlite3_column_table_name      sqlite3_api->column_table_name
#define sqlite3_column_table_name16    sqlite3_api->column_table_name16
#define sqlite3_column_text            sqlite3_api->column_text
#define sqlite3_column_text16          sqlite3_api->column_text16
#define sqlite3_column_type            sqlite3_api->column_type
#define sqlite3_column_value           sqlite3_api->column_value
#define sqlite3_commit_hook            sqlite3_api->commit_hook
#define sqlite3_complete               sqlite3_api->complete
#define sqlite3_complete16             sqlite3_api->complete16
#define sqlite3_create_collation       sqlite3_api->create_collation
#define sqlite3_create_collation16     sqlite3_api->create_collation16
#define sqlite3_create_function        sqlite3_api->create_function
#define sqlite3_create_function16      sqlite3_api->create_function16
#define sqlite3_create_module          sqlite3_api->create_module
#define sqlite3_create_module_v2       sqlite3_api->create_module_v2
#define sqlite3_data_count             sqlite3_api->data_count
#define sqlite3_db_handle              sqlite3_api->db_handle
#define sqlite3_declare_vtab           sqlite3_api->declare_vtab
#define sqlite3_enable_shared_cache    sqlite3_api->enable_shared_cache
#define sqlite3_errcode                sqlite3_api->errcode
#define sqlite3_errmsg                 sqlite3_api->errmsg
#define sqlite3_errmsg16               sqlite3_api->errmsg16
#define sqlite3_exec                   sqlite3_api->exec
#ifndef SQLITE_OMIT_DEPRECATED
#define sqlite3_expired                sqlite3_api->expired
#endif
#define sqlite3_finalize               sqlite3_api->finalize
#define sqlite3_free                   sqlite3_api->free
#define sqlite3_free_table             sqlite3_api->free_table
#define sqlite3_get_autocommit         sqlite3_api->get_autocommit
#define sqlite3_get_auxdata            sqlite3_api->get_auxdata
#define sqlite3_get_table              sqlite3_api->get_table
#ifndef SQLITE_OMIT_DEPRECATED
#define sqlite3_global_recover         sqlite3_api->global_recover
#endif
#define sqlite3_interrupt              sqlite3_api->interruptx
#define sqlite3_last_insert_rowid      sqlite3_api->last_insert_rowid
#define sqlite3_libversion             sqlite3_api->libversion
#define sqlite3_libversion_number      sqlite3_api->libversion_number
#define sqlite3_malloc                 sqlite3_api->malloc
#define sqlite3_mprintf                sqlite3_api->mprintf
#define sqlite3_open                   sqlite3_api->open
#define sqlite3_open16                 sqlite3_api->open16
#define sqlite3_prepare                sqlite3_api->prepare
#define sqlite3_prepare16              sqlite3_api->prepare16
#define sqlite3_prepare_v2             sqlite3_api->prepare_v2
#define sqlite3_prepare16_v2           sqlite3_api->prepare16_v2
#define sqlite3_profile                sqlite3_api->profile
#define sqlite3_progress_handler       sqlite3_api->progress_handler
#define sqlite3_realloc                sqlite3_api->realloc
#define sqlite3_reset                  sqlite3_api->reset
#define sqlite3_result_blob            sqlite3_api->result_blob
#define sqlite3_result_double          sqlite3_api->result_double
#define sqlite3_result_error           sqlite3_api->result_error
#define sqlite3_result_error16         sqlite3_api->result_error16
#define sqlite3_result_int             sqlite3_api->result_int
#define sqlite3_result_int64           sqlite3_api->result_int64
#define sqlite3_result_null            sqlite3_api->result_null
#define sqlite3_result_text            sqlite3_api->result_text
#define sqlite3_result_text16          sqlite3_api->result_text16
#define sqlite3_result_text16be        sqlite3_api->result_text16be
#define sqlite3_result_text16le        sqlite3_api->result_text16le
#define sqlite3_result_value           sqlite3_api->result_value
#define sqlite3_rollback_hook          sqlite3_api->rollback_hook
#define sqlite3_set_authorizer         sqlite3_api->set_authorizer
#define sqlite3_set_auxdata            sqlite3_api->set_auxdata
#define sqlite3_snprintf               sqlite3_api->xsnprintf
#define sqlite3_step                   sqlite3_api->step
#define sqlite3_table_column_metadata  sqlite3_api->table_column_metadata
#define sqlite3_thread_cleanup         sqlite3_api->thread_cleanup
#define sqlite3_total_changes          sqlite3_api->total_changes
#define sqlite3_trace                  sqlite3_api->trace
#ifndef SQLITE_OMIT_DEPRECATED
#define sqlite3_transfer_bindings      sqlite3_api->transfer_bindings
#endif
#define sqlite3_update_hook            sqlite3_api->update_hook
#define sqlite3_user_data              sqlite3_api->user_data
#define sqlite3_value_blob             sqlite3_api->value_blob
#define sqlite3_value_bytes            sqlite3_api->value_bytes
#define sqlite3_value_bytes16          sqlite3_api->value_bytes16
#define sqlite3_value_double           sqlite3_api->value_double
#define sqlite3_value_int              sqlite3_api->value_int
#define sqlite3_value_int64            sqlite3_api->value_int64
#define sqlite3_value_numeric_type     sqlite3_api->value_numeric_type
#define sqlite3_value_text             sqlite3_api->value_text
#define sqlite3_value_text16           sqlite3_api->value_text16
#define sqlite3_value_text16be         sqlite3_api->value_text16be
#define sqlite3_value_text16le         sqlite3_api->value_text16le
#define sqlite3_value_type             sqlite3_api->value_type
#define sqlite3_vmprintf               sqlite3_api->vmprintf
#define sqlite3_vsnprintf              sqlite3_api->xvsnprintf
#define sqlite3_overload_function      sqlite3_api->overload_function
#define sqlite3_prepare_v2             sqlite3_api->prepare_v2
#define sqlite3_prepare16_v2           sqlite3_api->prepare16_v2
#define sqlite3_clear_bindings         sqlite3_api->clear_bindings
#define sqlite3_bind_zeroblob          sqlite3_api->bind_zeroblob
#define sqlite3_blob_bytes             sqlite3_api->blob_bytes
#define sqlite3_blob_close             sqlite3_api->blob_close
#define sqlite3_blob_open              sqlite3_api->blob_open
#define sqlite3_blob_read              sqlite3_api->blob_read
#define sqlite3_blob_write             sqlite3_api->blob_write
#define sqlite3_create_collation_v2    sqlite3_api->create_collation_v2
#define sqlite3_file_control           sqlite3_api->file_control
#define sqlite3_memory_highwater       sqlite3_api->memory_highwater
#define sqlite3_memory_used            sqlite3_api->memory_used
#define sqlite3_mutex_alloc            sqlite3_api->mutex_alloc
#define sqlite3_mutex_enter            sqlite3_api->mutex_enter
#define sqlite3_mutex_free             sqlite3_api->mutex_free
#define sqlite3_mutex_leave            sqlite3_api->mutex_leave
#define sqlite3_mutex_try              sqlite3_api->mutex_try
#define sqlite3_open_v2                sqlite3_api->open_v2
#define sqlite3_release_memory         sqlite3_api->release_memory
#define sqlite3_result_error_nomem     sqlite3_api->result_error_nomem
#define sqlite3_result_error_toobig    sqlite3_api->result_error_toobig
#define sqlite3_sleep                  sqlite3_api->sleep
#define sqlite3_soft_heap_limit        sqlite3_api->soft_heap_limit
#define sqlite3_vfs_find               sqlite3_api->vfs_find
#define sqlite3_vfs_register           sqlite3_api->vfs_register
#define sqlite3_vfs_unregister         sqlite3_api->vfs_unregister
#define sqlite3_threadsafe             sqlite3_api->xthreadsafe
#define sqlite3_result_zeroblob        sqlite3_api->result_zeroblob
#define sqlite3_result_error_code      sqlite3_api->result_error_code
#define sqlite3_test_control           sqlite3_api->test_control
#define sqlite3_randomness             sqlite3_api->randomness
#define sqlite3_context_db_handle      sqlite3_api->context_db_handle
#define sqlite3_extended_result_codes  sqlite3_api->extended_result_codes
#define sqlite3_limit                  sqlite3_api->limit
#define sqlite3_next_stmt              sqlite3_api->next_stmt
#define sqlite3_sql                    sqlite3_api->sql
#define sqlite3_status                 sqlite3_api->status
#define sqlite3_backup_finish          sqlite3_api->backup_finish
#define sqlite3_backup_init            sqlite3_api->backup_init
#define sqlite3_backup_pagecount       sqlite3_api->backup_pagecount
#define sqlite3_backup_remaining       sqlite3_api->backup_remaining
#define sqlite3_backup_step            sqlite3_api->backup_step
#define sqlite3_compileoption_get      sqlite3_api->compileoption_get
#define sqlite3_compileoption_used     sqlite3_api->compileoption_used
#define sqlite3_create_function_v2     sqlite3_api->create_function_v2
#define sqlite3_db_config              sqlite3_api->db_config
#define sqlite3_db_mutex               sqlite3_api->db_mutex
#define sqlite3_db_status              sqlite3_api->db_status
#define sqlite3_extended_errcode       sqlite3_api->extended_errcode
#define sqlite3_log                    sqlite3_api->log
#define sqlite3_soft_heap_limit64      sqlite3_api->soft_heap_limit64
#define sqlite3_sourceid               sqlite3_api->sourceid
#define sqlite3_stmt_status            sqlite3_api->stmt_status
#define sqlite3_strnicmp               sqlite3_api->strnicmp
#define sqlite3_unlock_notify          sqlite3_api->unlock_notify
#define sqlite3_wal_autocheckpoint     sqlite3_api->wal_autocheckpoint
#define sqlite3_wal_checkpoint         sqlite3_api->wal_checkpoint
#define sqlite3_wal_hook               sqlite3_api->wal_hook
#define sqlite3_blob_reopen            sqlite3_api->blob_reopen
#define sqlite3_vtab_config            sqlite3_api->vtab_config
#define sqlite3_vtab_on_conflict       sqlite3_api->vtab_on_conflict
/* Version 3.7.16 and later */
#define sqlite3_close_v2               sqlite3_api->close_v2
#define sqlite3_db_filename            sqlite3_api->db_filename
#define sqlite3_db_readonly            sqlite3_api->db_readonly
#define sqlite3_db_release_memory      sqlite3_api->db_release_memory
#define sqlite3_errstr                 sqlite3_api->errstr
#define sqlite3_stmt_busy              sqlite3_api->stmt_busy
#define sqlite3_stmt_readonly          sqlite3_api->stmt_readonly
#define sqlite3_stricmp                sqlite3_api->stricmp
#define sqlite3_uri_boolean            sqlite3_api->uri_boolean
#define sqlite3_uri_int64              sqlite3_api->uri_int64
#define sqlite3_uri_parameter          sqlite3_api->uri_parameter
#define sqlite3_uri_vsnprintf          sqlite3_api->xvsnprintf
#define sqlite3_wal_checkpoint_v2      sqlite3_api->wal_checkpoint_v2
/* Version 3.8.7 and later */
#define sqlite3_auto_extension         sqlite3_api->auto_extension
#define sqlite3_bind_blob64            sqlite3_api->bind_blob64
#define sqlite3_bind_text64            sqlite3_api->bind_text64
#define sqlite3_cancel_auto_extension  sqlite3_api->cancel_auto_extension
#define sqlite3_load_extension         sqlite3_api->load_extension
#define sqlite3_malloc64               sqlite3_api->malloc64
#define sqlite3_msize                  sqlite3_api->msize
#define sqlite3_realloc64              sqlite3_api->realloc64
#define sqlite3_reset_auto_extension   sqlite3_api->reset_auto_extension
#define sqlite3_result_blob64          sqlite3_api->result_blob64
#define sqlite3_result_text64          sqlite3_api->result_text64
#define sqlite3_strglob                sqlite3_api->strglob
/* Version 3.8.11 and later */
#define sqlite3_value_dup              sqlite3_api->value_dup
#define sqlite3_value_free             sqlite3_api->value_free
#define sqlite3_result_zeroblob64      sqlite3_api->result_zeroblob64
#define sqlite3_bind_zeroblob64        sqlite3_api->bind_zeroblob64
/* Version 3.9.0 and later */
#define sqlite3_value_subtype          sqlite3_api->value_subtype
#define sqlite3_result_subtype         sqlite3_api->result_subtype
/* Version 3.10.0 and later */
#define sqlite3_status64               sqlite3_api->status64
#define sqlite3_strlike                sqlite3_api->strlike
#define sqlite3_db_cacheflush          sqlite3_api->db_cacheflush
/* Version 3.12.0 and later */
#define sqlite3_system_errno           sqlite3_api->system_errno
/* Version 3.14.0 and later */
#define sqlite3_trace_v2               sqlite3_api->trace_v2
#define sqlite3_expanded_sql           sqlite3_api->expanded_sql
/* Version 3.18.0 and later */
#define sqlite3_set_last_insert_rowid  sqlite3_api->set_last_insert_rowid
/* Version 3.20.0 and later */
#define sqlite3_prepare_v3             sqlite3_api->prepare_v3
#define sqlite3_prepare16_v3           sqlite3_api->prepare16_v3
#define sqlite3_bind_pointer           sqlite3_api->bind_pointer
#define sqlite3_result_pointer         sqlite3_api->result_pointer
#define sqlite3_value_pointer          sqlite3_api->value_pointer
/* Version 3.22.0 and later */
#define sqlite3_vtab_nochange          sqlite3_api->vtab_nochange
#define sqlite3_value_nochange         sqlite3_api->value_nochange
#define sqlite3_vtab_collation         sqlite3_api->vtab_collation
/* Version 3.24.0 and later */
#define sqlite3_keyword_count          sqlite3_api->keyword_count
#define sqlite3_keyword_name           sqlite3_api->keyword_name
#define sqlite3_keyword_check          sqlite3_api->keyword_check
#define sqlite3_str_new                sqlite3_api->str_new
#define sqlite3_str_finish             sqlite3_api->str_finish
#define sqlite3_str_appendf            sqlite3_api->str_appendf
#define sqlite3_str_vappendf           sqlite3_api->str_vappendf
#define sqlite3_str_append             sqlite3_api->str_append
#define sqlite3_str_appendall          sqlite3_api->str_appendall
#define sqlite3_str_appendchar         sqlite3_api->str_appendchar
#define sqlite3_str_reset              sqlite3_api->str_reset
#define sqlite3_str_errcode            sqlite3_api->str_errcode
#define sqlite3_str_length             sqlite3_api->str_length
#define sqlite3_str_value              sqlite3_api->str_value
/* Version 3.25.0 and later */
#define sqlite3_create_window_function sqlite3_api->create_window_function
/* Version 3.26.0 and later */
#define sqlite3_normalized_sql         sqlite3_api->normalized_sql
/* Version 3.28.0 and later */
#define sqlite3_stmt_isexplain         sqlite3_api->stmt_isexplain
#define sqlite3_value_frombind         sqlite3_api->value_frombind
/* Version 3.30.0 and later */
#define sqlite3_drop_modules           sqlite3_api->drop_modules
/* Version 3.31.0 and later */
#define sqlite3_hard_heap_limit64      sqlite3_api->hard_heap_limit64
#define sqlite3_uri_key                sqlite3_api->uri_key
#define sqlite3_filename_database      sqlite3_api->filename_database
#define sqlite3_filename_journal       sqlite3_api->filename_journal
#define sqlite3_filename_wal           sqlite3_api->filename_wal
/* Version 3.32.0 and later */
#define sqlite3_create_filename        sqlite3_api->create_filename
#define sqlite3_free_filename          sqlite3_api->free_filename
#define sqlite3_database_file_object   sqlite3_api->database_file_object
/* Version 3.34.0 and later */
#define sqlite3_txn_state              sqlite3_api->txn_state
/* Version 3.36.1 and later */
#define sqlite3_changes64              sqlite3_api->changes64
#define sqlite3_total_changes64        sqlite3_api->total_changes64
/* Version 3.37.0 and later */
#define sqlite3_autovacuum_pages       sqlite3_api->autovacuum_pages
/* Version 3.38.0 and later */
#define sqlite3_error_offset           sqlite3_api->error_offset
#define sqlite3_vtab_rhs_value         sqlite3_api->vtab_rhs_value
#define sqlite3_vtab_distinct          sqlite3_api->vtab_distinct
#define sqlite3_vtab_in                sqlite3_api->vtab_in
#define sqlite3_vtab_in_first          sqlite3_api->vtab_in_first
#define sqlite3_vtab_in_next           sqlite3_api->vtab_in_next
/* Version 3.39.0 and later */
#ifndef SQLITE_OMIT_DESERIALIZE
#define sqlite3_deserialize            sqlite3_api->deserialize
#define sqlite3_serialize              sqlite3_api->serialize
#endif
#define sqlite3_db_name                sqlite3_api->db_name
/* Version 3.40.0 and later */
#define sqlite3_value_encoding         sqlite3_api->value_encoding
/* Version 3.41.0 and later */
#define sqlite3_is_interrupted         sqlite3_api->is_interrupted
/* Version 3.43.0 and later */
#define sqlite3_stmt_explain           sqlite3_api->stmt_explain
/* Version 3.44.0 and later */
#define sqlite3_get_clientdata         sqlite3_api->get_clientdata
#define sqlite3_set_clientdata         sqlite3_api->set_clientdata
#endif /* !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION) */
#if !defined(SQLITE_CORE) && !defined(SQLITE_OMIT_LOAD_EXTENSION)
  /* This case when the file really is being compiled as a loadable
  ** extension */
# define SQLITE_EXTENSION_INIT1     const sqlite3_api_routines *sqlite3_api=0;
# define SQLITE_EXTENSION_INIT2(v)  sqlite3_api=v;
# define SQLITE_EXTENSION_INIT3     \
    extern const sqlite3_api_routines *sqlite3_api;
#else
  /* This case when the file is being statically linked into the
  ** application */
# define SQLITE_EXTENSION_INIT1     /*no-op*/
# define SQLITE_EXTENSION_INIT2(v)  (void)v; /* unused parameter */
# define SQLITE_EXTENSION_INIT3     /*no-op*/
#endif
#endif /* SQLITE3EXT_H */