LAPTOP-T815PCOQ\25526
2024-11-25 6365b1d493ca23688fa1fb9a8fc51513dc6bb6d8
1.完成上下切换轴 2.补全未追踪的文件
已添加9个文件
已修改2个文件
270919 ■■■■■ 文件已修改
SourceCode/Bond/BondEq/CProjectPageComponents.cpp 233 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/CProjectPageComponents.h 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/DBManager/AxisManager.cpp 245 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/DBManager/AxisManager.h 75 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/GB2860SQLite.cpp 320 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/GB2860SQLite.h 26 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/View/AxisSettingsDlg.cpp 70 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
SourceCode/Bond/BondEq/View/AxisSettingsDlg.h 20 ●●●●● 补丁 | 查看 | 原始文档 | 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/CProjectPageComponents.cpp
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,233 @@
// CProjectPageComponents.cpp: å®žçŽ°æ–‡ä»¶
//
#include "stdafx.h"
#include "BondEq.h"
#include "CProjectPageComponents.h"
#include "afxdialogex.h"
#include "Alarm.h"
// CProjectPageComponents å¯¹è¯æ¡†
IMPLEMENT_DYNAMIC(CProjectPageComponents, CDialogEx)
CProjectPageComponents::CProjectPageComponents(CWnd* pParent /*=nullptr*/)
    : CDialogEx(IDD_PROJECT_PAGE_COMPONENTS, pParent)
{
    m_crBkgnd = PROPAGE_BACKGROUND_COLOR;
    m_hbrBkgnd = nullptr;
    m_pObserver = nullptr;
}
CProjectPageComponents::~CProjectPageComponents()
{
}
void CProjectPageComponents::DoDataExchange(CDataExchange* pDX)
{
    CDialogEx::DoDataExchange(pDX);
    DDX_Control(pDX, IDC_TREE1, m_treeComponents);
}
BEGIN_MESSAGE_MAP(CProjectPageComponents, CDialogEx)
    ON_WM_CTLCOLOR()
    ON_WM_DESTROY()
    ON_WM_SIZE()
    ON_NOTIFY(TVN_SELCHANGED, IDC_TREE1, &CProjectPageComponents::OnTvnSelchangedTree1)
    ON_MESSAGE(ID_MSG_TREE_CLICK_ITEM, OnTreeClickItem)
END_MESSAGE_MAP()
// CEQPageComponents æ¶ˆæ¯å¤„理程序
void CProjectPageComponents::InitRxWindows()
{
    /* code */
    // è®¢é˜…数据
    IRxWindows* pRxWindows = RX_GetRxWindows();
    pRxWindows->enableLog(5);
    if (m_pObserver == NULL) {
        m_pObserver = pRxWindows->allocObserver([&](IAny* pAny) -> void {
            // onNext
            pAny->addRef();
            int code = pAny->getCode();
            if (RX_CODE_DATA1_MATERIAL_RECEIVED == code) {
                CComponent* pComponent;
                if (pAny->getPtrValue("ptr", (void*&)pComponent)) {
                    HTREEITEM hItem = getTreeItem(pComponent);
                    if (hItem != nullptr) {
                        m_treeComponents.ShowItemBadgeDotMode(hItem);
                    }
                }
            }
            else if(RX_CODE_DATA1_MATERIAL_REMOVEED == code) {
                CComponent* pComponent;
                if (pAny->getPtrValue("ptr", (void*&)pComponent)) {
                    HTREEITEM hItem = getTreeItem(pComponent);
                    if (hItem != nullptr) {
                        m_treeComponents.HideItemBadge(hItem);
                    }
                }
            }
            else if (RX_CODE_ALARM_EVENT == code) {
                CComponent* pComponent = nullptr;
                CAlarm* pAlarm = nullptr;
                pAny->getObject("obj", (IRxObject*&)pAlarm);
                pAny->getPtrValue("ptr", (void*&)pComponent);
                ASSERT(pComponent);
                ASSERT(pAlarm);
                HTREEITEM hItem = getTreeItem(pComponent);
                if (hItem != nullptr) {
                    if(pAlarm->getStatus() == 1)
                        m_treeComponents.ShowItemBadgeDotMode(hItem);
                    else if (pAlarm->getStatus() == 2)
                        m_treeComponents.HideItemBadge(hItem);
                }
            }
            else if (RX_CODE_PLC1_CONNECTTD == code) {
                CComponent* pComponent;
                if (pAny->getPtrValue("ptr", (void*&)pComponent)) {
                    HTREEITEM hItem = getTreeItem(pComponent);
                    if (hItem != nullptr) {
                        m_treeComponents.ShowItemBadgeDotMode(hItem);
                    }
                }
            }
            else if (RX_CODE_PLC1_DISCONNECTTD == code) {
                CComponent* pComponent;
                if (pAny->getPtrValue("ptr", (void*&)pComponent)) {
                    HTREEITEM hItem = getTreeItem(pComponent);
                    if (hItem != nullptr) {
                        m_treeComponents.HideItemBadge(hItem);
                    }
                }
            }
            pAny->release();
        }, [&]() -> void {
            // onComplete
        }, [&](IThrowable* pThrowable) -> void {
            // onErrorm
            pThrowable->printf();
        });
        theApp.m_model.getObservable()->observeOn(pRxWindows->mainThread())
            ->subscribe(m_pObserver);
    }
}
BOOL CProjectPageComponents::OnInitDialog()
{
    CDialogEx::OnInitDialog();
    // ç»„件列表
    m_treeComponents.SetBkColor(PROPAGE_BACKGROUND_COLOR);
    m_treeComponents.SetItemHeight(50);
    const std::vector<CComponent*>& components = theApp.m_model.getBonder().getComponents();
    for (auto item : components) {
        HTREEITEM hItemComponent = m_treeComponents.InsertItem(item->getName().c_str());
        m_treeComponents.SetItemData(hItemComponent, (DWORD_PTR)item);
        if (item->getClassName().compare("CAlarmMonitor") == 0) {
            m_treeComponents.SetItemBadge(hItemComponent, TREE_BADGE2_BACKGROUND, TREE_BADGE2_FOREGROUND);
        }
        else {
            m_treeComponents.SetItemBadge(hItemComponent, TREE_BADGE_BACKGROUND, TREE_BADGE_FOREGROUND);
        }
    }
    InitRxWindows();
    return TRUE;  // return TRUE unless you set the focus to a control
                  // å¼‚常: OCX å±žæ€§é¡µåº”返回 FALSE
}
HBRUSH CProjectPageComponents::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
    HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
    if (nCtlColor == CTLCOLOR_STATIC) {
        pDC->SetBkColor(m_crBkgnd);
    }
    if (m_hbrBkgnd == nullptr) {
        m_hbrBkgnd = CreateSolidBrush(m_crBkgnd);
    }
    return m_hbrBkgnd;
}
void CProjectPageComponents::OnDestroy()
{
    CDialogEx::OnDestroy();
    if (m_hbrBkgnd != nullptr) {
        ::DeleteObject(m_hbrBkgnd);
    }
    ASSERT(m_pObserver != NULL);
    m_pObserver->unsubscribe();
    m_pObserver = NULL;
}
void CProjectPageComponents::OnSize(UINT nType, int cx, int cy)
{
    CDialogEx::OnSize(nType, cx, cy);
    if (GetDlgItem(IDC_TREE1) == nullptr) return;
    CRect rcClient;
    CWnd* pItem;
    GetClientRect(&rcClient);
    pItem = GetDlgItem(IDC_TREE1);
    pItem->MoveWindow(12, 12, rcClient.Width() - 24, rcClient.Height() - 24);
}
void CProjectPageComponents::OnTvnSelchangedTree1(NMHDR* pNMHDR, LRESULT* pResult)
{
    LPNMTREEVIEW pNMTreeView = reinterpret_cast<LPNMTREEVIEW>(pNMHDR);
    HTREEITEM hItem = pNMTreeView->itemNew.hItem;
    ASSERT(hItem);
    CComponent* pComponent = (CComponent*)m_treeComponents.GetItemData(hItem);
    ASSERT(pComponent);
    // theApp.m_model.notifyPtr(RX_CODE_SELECT_COMPONENT, pComponent);
    *pResult = 0;
}
LRESULT CProjectPageComponents::OnTreeClickItem(WPARAM wParam, LPARAM lParam)
{
    HTREEITEM hItem = (HTREEITEM)wParam;
    ASSERT(hItem);
    CComponent* pComponent = (CComponent*)m_treeComponents.GetItemData(hItem);
    ASSERT(pComponent);
    theApp.m_model.notifyPtr(RX_CODE_SELECT_COMPONENT, pComponent);
    return 0;
}
HTREEITEM CProjectPageComponents::getTreeItem(CComponent* pComponent)
{
    HTREEITEM hItem = m_treeComponents.GetChildItem(nullptr);
    while (hItem != nullptr) {
        CComponent* p = (CComponent*)m_treeComponents.GetItemData(hItem);
        if (p == pComponent) {
            return hItem;
        }
        hItem = m_treeComponents.GetNextSiblingItem(hItem);
    }
    return nullptr;
}
SourceCode/Bond/BondEq/CProjectPageComponents.h
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,43 @@
#pragma once
#include "ApredTreeCtrl.h"
// CEQPageComponents å¯¹è¯æ¡†
class CProjectPageComponents : public CDialogEx
{
    DECLARE_DYNAMIC(CProjectPageComponents)
public:
    CProjectPageComponents(CWnd* pParent = nullptr);   // æ ‡å‡†æž„造函数
    virtual ~CProjectPageComponents();
private:
    void InitRxWindows();
    HTREEITEM getTreeItem(CComponent* pComponent);
private:
    COLORREF m_crBkgnd;
    HBRUSH m_hbrBkgnd;
    CApredTreeCtrl m_treeComponents;
    IObserver* m_pObserver;
// å¯¹è¯æ¡†æ•°æ®
#ifdef AFX_DESIGN_TIME
    enum { IDD = IDD_EQPAGE_COMPONENTS };
#endif
protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV æ”¯æŒ
    DECLARE_MESSAGE_MAP()
public:
    virtual BOOL OnInitDialog();
    afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor);
    afx_msg void OnDestroy();
    afx_msg void OnSize(UINT nType, int cx, int cy);
    afx_msg void OnTvnSelchangedTree1(NMHDR* pNMHDR, LRESULT* pResult);
    afx_msg LRESULT OnTreeClickItem(WPARAM wParam, LPARAM lParam);
};
SourceCode/Bond/BondEq/DBManager/AxisManager.cpp
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,245 @@
#include "stdafx.h"
#include <sstream>
#include <stdexcept>
#include <mutex>
// é™æ€æˆå‘˜åˆå§‹åŒ–
std::mutex AxisManager::m_mutex;
// èŽ·å–å•ä¾‹å®žä¾‹
AxisManager& AxisManager::getInstance() {
    static AxisManager instance;
    return instance;
}
AxisManager::AxisManager() : m_pDB(nullptr) {}
AxisManager::~AxisManager() {
    m_pDB = nullptr;
}
// è®¾ç½®æ•°æ®åº“连接
void AxisManager::setDatabase(BL::Database* db) {
    std::lock_guard<std::mutex> lock(m_mutex);
    m_pDB = db;
}
// åˆå§‹åŒ–轴表和定位点表
bool AxisManager::initializeTables() {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    const std::string createAxesTableQuery = R"(
        CREATE TABLE IF NOT EXISTS axes (
            axis_id INTEGER PRIMARY KEY,
            axis_no TEXT NOT NULL,
            description TEXT NOT NULL,
            start_address TEXT,
            jog_distance REAL,
            manual_speed REAL,
            max_manual_speed REAL,
            min_manual_speed REAL,
            auto_speed REAL,
            max_auto_speed REAL,
            min_auto_speed REAL,
            acceleration_time REAL,
            deceleration_time REAL
        )
    )";
    const std::string createPositionsTableQuery = R"(
        CREATE TABLE IF NOT EXISTS positions (
            position_id INTEGER PRIMARY KEY AUTOINCREMENT,
            axis_id INTEGER NOT NULL,
            description TEXT,
            position_value REAL,
            plc_address TEXT,
            FOREIGN KEY (axis_id) REFERENCES axes(axis_id)
        )
    )";
    return m_pDB->executeQuery(createAxesTableQuery) && m_pDB->executeQuery(createPositionsTableQuery);
}
// åˆå§‹åŒ–默认数据
bool AxisManager::initializeDefaultData() {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    for (int axisId = 1; axisId <= 12; ++axisId) {
        std::ostringstream axisQuery;
        axisQuery << "INSERT OR IGNORE INTO axes (axis_id, axis_no, description, start_address, jog_distance, manual_speed, "
            << "max_manual_speed, min_manual_speed, auto_speed, max_auto_speed, min_auto_speed, acceleration_time, deceleration_time) "
            << "VALUES (" << axisId << ", 'M" << axisId * 10 << "', 'è½´ " << axisId << "', 'D" << (5090 + axisId * 2) << "', "
            << "0.5, 10.0, 20.0, 5.0, 15.0, 25.0, 10.0, 0.2, 0.3)";
        m_pDB->executeQuery(axisQuery.str());
    }
    for (int axisId = 1; axisId <= 12; ++axisId) {
        for (int positionIndex = 1; positionIndex <= 25; ++positionIndex) {
            std::ostringstream positionQuery;
            positionQuery << "INSERT OR IGNORE INTO positions (axis_id, description, position_value, plc_address) "
                << "VALUES (" << axisId << ", '定位点 " << positionIndex << "', " << (positionIndex * 10.0) << ", "
                << "'D" << (5240 + positionIndex * 2) << "')";
            m_pDB->executeQuery(positionQuery.str());
        }
    }
    return true;
}
// æ·»åŠ æˆ–æ›´æ–°è½´ä¿¡æ¯
bool AxisManager::saveAxis(int axisId, const std::string& axisNo, const std::string& description,
    const std::string& startAddress, double jogDistance, double manualSpeed,
    double maxManualSpeed, double minManualSpeed, double autoSpeed,
    double maxAutoSpeed, double minAutoSpeed, double accelerationTime,
    double decelerationTime) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "INSERT INTO axes (axis_id, axis_no, description, start_address, jog_distance, manual_speed, "
        << "max_manual_speed, min_manual_speed, auto_speed, max_auto_speed, min_auto_speed, acceleration_time, deceleration_time) "
        << "VALUES (" << axisId << ", '" << axisNo << "', '" << description << "', '" << startAddress << "', "
        << jogDistance << ", " << manualSpeed << ", " << maxManualSpeed << ", " << minManualSpeed << ", " << autoSpeed
        << ", " << maxAutoSpeed << ", " << minAutoSpeed << ", " << accelerationTime << ", " << decelerationTime << ") "
        << "ON CONFLICT(axis_id) DO UPDATE SET "
        << "axis_no=excluded.axis_no, description=excluded.description, start_address=excluded.start_address, "
        << "jog_distance=excluded.jog_distance, manual_speed=excluded.manual_speed, max_manual_speed=excluded.max_manual_speed, "
        << "min_manual_speed=excluded.min_manual_speed, auto_speed=excluded.auto_speed, max_auto_speed=excluded.max_auto_speed, "
        << "min_auto_speed=excluded.min_auto_speed, acceleration_time=excluded.acceleration_time, deceleration_time=excluded.deceleration_time";
    std::lock_guard<std::mutex> lock(m_mutex);
    return m_pDB->executeQuery(query.str());
}
// èŽ·å–å•ä¸ªè½´ä¿¡æ¯
std::vector<std::string> AxisManager::getAxis(int axisId) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "SELECT * FROM axes WHERE axis_id = " << axisId;
    auto result = m_pDB->fetchResults(query.str());
    return !result.empty() ? result[0] : std::vector<std::string>();
}
// èŽ·å–æ‰€æœ‰è½´ä¿¡æ¯
std::vector<std::vector<std::string>> AxisManager::getAllAxes() {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    return m_pDB->fetchResults("SELECT * FROM axes ORDER BY axis_id");
}
// åˆ é™¤æŒ‡å®šè½´
bool AxisManager::deleteAxis(int axisId) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "DELETE FROM axes WHERE axis_id = " << axisId;
    std::lock_guard<std::mutex> lock(m_mutex);
    return m_pDB->executeQuery(query.str());
}
// æ·»åŠ æˆ–æ›´æ–°å®šä½ç‚¹
bool AxisManager::savePosition(int axisId, const std::string& description, double positionValue, const std::string& plcAddress) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "INSERT INTO positions (axis_id, description, position_value, plc_address) VALUES ("
        << axisId << ", '" << description << "', " << positionValue << ", '" << plcAddress << "') "
        << "ON CONFLICT(axis_id) DO UPDATE SET "
        << "description=excluded.description, position_value=excluded.position_value, plc_address=excluded.plc_address";
    std::lock_guard<std::mutex> lock(m_mutex);
    return m_pDB->executeQuery(query.str());
}
// èŽ·å–è½´çš„æ‰€æœ‰å®šä½ç‚¹
std::vector<std::vector<std::string>> AxisManager::getPositions(int axisId, int pageNumber, int pageSize) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    int offset = (pageNumber - 1) * pageSize;
    std::ostringstream query;
    query << "SELECT * FROM positions WHERE axis_id = " << axisId << " LIMIT " << pageSize << " OFFSET " << offset;
    return m_pDB->fetchResults(query.str());
}
// èŽ·å–å®šä½ç‚¹æ€»æ•°
int AxisManager::getTotalPositionCount(int axisId) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "SELECT COUNT(*) FROM positions WHERE axis_id = " << axisId;
    auto result = m_pDB->fetchResults(query.str());
    return (!result.empty() && !result[0].empty()) ? std::stoi(result[0][0]) : 0;
}
// åˆ é™¤æŒ‡å®šå®šä½ç‚¹
bool AxisManager::deletePosition(int positionId) {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::ostringstream query;
    query << "DELETE FROM positions WHERE position_id = " << positionId;
    std::lock_guard<std::mutex> lock(m_mutex);
    return m_pDB->executeQuery(query.str());
}
// èŽ·å–æ‰€æœ‰çš„è½´ID
std::vector<int> AxisManager::getUsedAxisIds() {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::vector<int> usedAxisIds;
    std::string query = "SELECT axis_id FROM axes ORDER BY axis_id";
    auto results = m_pDB->fetchResults(query);
    for (const auto& row : results) {
        if (!row.empty()) {
            usedAxisIds.push_back(std::stoi(row[0]));
        }
    }
    return usedAxisIds;
}
// èŽ·å–æ‰€æœ‰è½´çš„è½´NO
std::vector<std::string> AxisManager::getAllAxisNumbers() {
    if (!m_pDB) {
        throw std::runtime_error("Database connection is not set.");
    }
    std::vector<std::string> axisNumbers;
    std::string query = "SELECT axis_no FROM axes ORDER BY axis_id";
    auto results = m_pDB->fetchResults(query);
    for (const auto& row : results) {
        if (!row.empty()) {
            axisNumbers.push_back(row[0]);
        }
    }
    return axisNumbers;
}
SourceCode/Bond/BondEq/DBManager/AxisManager.h
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,75 @@
#ifndef AXIS_MANAGER_H
#define AXIS_MANAGER_H
#include <string>
#include <vector>
#include <mutex>
#include "Database.h"
// è½´ç®¡ç†ç±»
class AxisManager {
public:
    // èŽ·å–å•ä¾‹å®žä¾‹
    static AxisManager& getInstance();
    // è®¾ç½®æ•°æ®åº“连接
    void setDatabase(BL::Database* db);
    // åˆå§‹åŒ–轴表和定位点表
    bool initializeTables();
    // åˆå§‹åŒ–默认数据
    bool initializeDefaultData();
    // æ·»åŠ æˆ–æ›´æ–°è½´ä¿¡æ¯
    bool saveAxis(int axisId, const std::string& axisNo, const std::string& description,
        const std::string& startAddress, double jogDistance, double manualSpeed,
        double maxManualSpeed, double minManualSpeed, double autoSpeed,
        double maxAutoSpeed, double minAutoSpeed, double accelerationTime,
        double decelerationTime);
    // èŽ·å–å•ä¸ªè½´ä¿¡æ¯
    std::vector<std::string> getAxis(int axisId);
    // èŽ·å–æ‰€æœ‰è½´ä¿¡æ¯
    std::vector<std::vector<std::string>> getAllAxes();
    // åˆ é™¤æŒ‡å®šè½´
    bool deleteAxis(int axisId);
    // æ·»åŠ æˆ–æ›´æ–°å®šä½ç‚¹
    bool savePosition(int axisId, const std::string& description, double positionValue,
        const std::string& plcAddress);
    // èŽ·å–è½´çš„æ‰€æœ‰å®šä½ç‚¹
    std::vector<std::vector<std::string>> getPositions(int axisId, int pageNumber, int pageSize);
    // èŽ·å–å®šä½ç‚¹æ€»æ•°
    int getTotalPositionCount(int axisId);
    // åˆ é™¤æŒ‡å®šå®šä½ç‚¹
    bool deletePosition(int positionId);
    // èŽ·å–æ‰€æœ‰çš„è½´ID
    std::vector<int> getUsedAxisIds();
    // èŽ·å–æ‰€æœ‰è½´çš„è½´NO
    std::vector<std::string> getAllAxisNumbers();
private:
    // ç§æœ‰æž„造函数和析构函数
    AxisManager();
    ~AxisManager();
    // ç¦æ­¢æ‹·è´å’Œèµ‹å€¼
    AxisManager(const AxisManager&) = delete;
    AxisManager& operator=(const AxisManager&) = delete;
    // æ•°æ®åº“连接
    BL::Database* m_pDB;
    // çº¿ç¨‹å®‰å…¨é”
    static std::mutex m_mutex;
};
#endif // AXIS_MANAGER_H
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/View/AxisSettingsDlg.cpp
@@ -190,6 +190,19 @@
    label.UpdateWindow();            // ç«‹å³åˆ·æ–°
}
int CAxisSettingsDlg::getCurrentSelectedAxisID()
{
    int currentIndex = m_comboAxisNO.GetCurSel();
    if (currentIndex == CB_ERR) {
        AfxMessageBox(_T("请选择一个有效的轴编号!"));
        return -1;
    }
    CString axisIDStr;
    m_comboAxisNO.GetLBText(currentIndex, axisIDStr);
    return _ttoi(axisIDStr);
}
void CAxisSettingsDlg::initializeAxisIDCombo()
{
    // èŽ·å–æ‰€æœ‰è½´çš„è½´NO
@@ -214,15 +227,7 @@
void CAxisSettingsDlg::refreshAxisDetails()
{
    // èŽ·å–å½“å‰é€‰ä¸­çš„è½´ID
    int currentIndex = m_comboAxisNO.GetCurSel();
    if (currentIndex == CB_ERR) {
        AfxMessageBox(_T("请选择一个有效的轴编号!"));
        return;
    }
    CString axisIDStr;
    m_comboAxisNO.GetLBText(currentIndex, axisIDStr);
    int axisId = _ttoi(axisIDStr);
    int axisId = getCurrentSelectedAxisID();
    // èŽ·å–è½´ä¿¡æ¯
    auto axisDetails = AxisManager::getInstance().getAxis(axisId);
@@ -255,15 +260,7 @@
    const int pageSize = 5;
    // èŽ·å–å½“å‰é€‰ä¸­çš„è½´ID
    int currentIndex = m_comboAxisNO.GetCurSel();
    if (currentIndex == CB_ERR) {
        AfxMessageBox(_T("请选择一个有效的轴编号!"));
        return;
    }
    CString axisIDStr;
    m_comboAxisNO.GetLBText(currentIndex, axisIDStr);
    int axisId = _ttoi(axisIDStr);
    int axisId = getCurrentSelectedAxisID();
    // èŽ·å–å®šä½ç‚¹æ•°æ®
    auto positions = AxisManager::getInstance().getPositions(axisId, pageNumber, pageSize);
@@ -311,6 +308,27 @@
            if (pPosition) pPosition->SetWindowText(_T(""));
        }
    }
}
void CAxisSettingsDlg::updateAxisSelection(int offset)
{
    int currentIndex = m_comboAxisNO.GetCurSel();
    if (currentIndex == CB_ERR) {
        AfxMessageBox(_T("请选择一个有效的轴编号!"));
        return;
    }
    int newIndex = currentIndex + offset;
    if (newIndex < 0 || newIndex >= m_comboAxisNO.GetCount()) {
        CString error;
        error.Format(_T("已经到达%s一个轴!"), offset < 0 ? _T("上") : _T("下"));
        AfxMessageBox(error);
        return;
    }
    m_comboAxisNO.SetCurSel(newIndex);
    refreshAxisDetails();
    refreshPositionDetails(1);
}
BEGIN_MESSAGE_MAP(CAxisSettingsDlg, CDialogEx)
@@ -465,11 +483,27 @@
void CAxisSettingsDlg::OnBnClickedButtonAxisLast()
{
    // TODO: åœ¨æ­¤æ·»åŠ æŽ§ä»¶é€šçŸ¥å¤„ç†ç¨‹åºä»£ç 
    try {
        updateAxisSelection(-1);
    }
    catch (const std::exception& ex) {
        CString errorMsg;
        errorMsg.Format(_T("获取下一个轴失败:%s"), CString(ex.what()));
        AfxMessageBox(errorMsg, MB_ICONERROR);
    }
}
void CAxisSettingsDlg::OnBnClickedButtonAxisNext()
{
    // TODO: åœ¨æ­¤æ·»åŠ æŽ§ä»¶é€šçŸ¥å¤„ç†ç¨‹åºä»£ç 
    try {
        updateAxisSelection(1);
    }
    catch (const std::exception& ex) {
        CString errorMsg;
        errorMsg.Format(_T("获取上一个轴失败:%s"), CString(ex.what()));
        AfxMessageBox(errorMsg, MB_ICONERROR);
    }
}
void CAxisSettingsDlg::OnBnClickedButtonAxisAnchorPointGroup1()
SourceCode/Bond/BondEq/View/AxisSettingsDlg.h
@@ -29,9 +29,11 @@
    void AdjustControlFont(CWnd* pWnd, int nWidth, int nHeight);
    void AdjustLabelFont(CBLLabel& label);
    void SetStatusColor(CBLLabel& label, BOOL bStatus);
    int getCurrentSelectedAxisID();
    void initializeAxisIDCombo();
    void refreshAxisDetails();
    void refreshPositionDetails(int pageNumber);
    void updateAxisSelection(int offset);
private:
    CPLC* m_pPLC;
@@ -39,21 +41,11 @@
    int m_nInitialHeight;
    // æŽ§ä»¶
    CBLLabel m_staticFLS;
    CBLLabel m_staticDOG;
    CBLLabel m_staticRLS;
    CBLLabel m_staticReady;
    CBLLabel m_staticBusy;
    CBLLabel m_staticErr;
    CBLLabel m_staticFLS, m_staticDOG, m_staticRLS, m_staticReady, m_staticBusy, m_staticErr;
    CComboBox m_comboAxisNO;
    CStatic m_staticAxisNO;
    CStatic m_staticAxisDescription;
    CStatic m_staticStartAddress;
    CEdit m_editManualSpeed;
    CEdit m_editAutoSpeed;
    CEdit m_editAccelerationTime;
    CEdit m_editDecelerationTime;
    CEdit m_editJogDistance;
    CStatic m_staticAxisNO, m_staticAxisDescription, m_staticStartAddress;
    CEdit m_editManualSpeed, m_editAutoSpeed, m_editAccelerationTime, m_editDecelerationTime, m_editJogDistance;
    std::map<int, CRect> m_mapCtrlLayouts;
    std::map<int, CFont*> m_mapFonts;
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 */