mirror of
https://github.com/status-im/status-go.git
synced 2025-01-26 06:30:23 +00:00
chore: moved collectibles ownership cache to db
This commit is contained in:
parent
85d8e83394
commit
57424e076c
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,8 @@
|
|||||||
|
CREATE TABLE IF NOT EXISTS collectibles_ownership_cache (
|
||||||
|
chain_id UNSIGNED BIGINT NOT NULL,
|
||||||
|
contract_address VARCHAR NOT NULL,
|
||||||
|
token_id BLOB NOT NULL,
|
||||||
|
owner_address VARCHAR NOT NULL
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE INDEX IF NOT EXISTS collectibles_ownership_filter_entries ON collectibles_ownership_cache (chain_id, owner_address);
|
1
go.mod
1
go.mod
@ -78,6 +78,7 @@ require (
|
|||||||
github.com/andybalholm/brotli v1.0.5
|
github.com/andybalholm/brotli v1.0.5
|
||||||
github.com/gorilla/sessions v1.2.1
|
github.com/gorilla/sessions v1.2.1
|
||||||
github.com/ipfs/go-log/v2 v2.5.1
|
github.com/ipfs/go-log/v2 v2.5.1
|
||||||
|
github.com/jmoiron/sqlx v1.3.5
|
||||||
github.com/ladydascalie/currency v1.6.0
|
github.com/ladydascalie/currency v1.6.0
|
||||||
github.com/meirf/gopart v0.0.0-20180520194036-37e9492a85a8
|
github.com/meirf/gopart v0.0.0-20180520194036-37e9492a85a8
|
||||||
github.com/mutecomm/go-sqlcipher/v4 v4.4.2
|
github.com/mutecomm/go-sqlcipher/v4 v4.4.2
|
||||||
|
4
go.sum
4
go.sum
@ -852,6 +852,8 @@ github.com/go-sourcemap/sourcemap v2.1.3+incompatible/go.mod h1:F8jJfvm2KbVjc5Nq
|
|||||||
github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
|
github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
|
||||||
github.com/go-sql-driver/mysql v1.4.1/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
|
github.com/go-sql-driver/mysql v1.4.1/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
|
||||||
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
||||||
|
github.com/go-sql-driver/mysql v1.6.0 h1:BCTh4TKNUYmOmMUcQ3IipzF5prigylS7XXjEkfCHuOE=
|
||||||
|
github.com/go-sql-driver/mysql v1.6.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
||||||
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
||||||
github.com/go-stack/stack v1.8.1 h1:ntEHSVwIt7PNXNpgPmVfMrNhLtgjlmnZha2kOpuRiDw=
|
github.com/go-stack/stack v1.8.1 h1:ntEHSVwIt7PNXNpgPmVfMrNhLtgjlmnZha2kOpuRiDw=
|
||||||
github.com/go-stack/stack v1.8.1/go.mod h1:dcoOX6HbPZSZptuspn9bctJ+N/CnF5gGygcUP3XYfe4=
|
github.com/go-stack/stack v1.8.1/go.mod h1:dcoOX6HbPZSZptuspn9bctJ+N/CnF5gGygcUP3XYfe4=
|
||||||
@ -1229,6 +1231,8 @@ github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHW
|
|||||||
github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U=
|
github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U=
|
||||||
github.com/jmoiron/sqlx v1.2.0/go.mod h1:1FEQNm3xlJgrMD+FBdI9+xvCksHtbpVBBw5dYhBSsks=
|
github.com/jmoiron/sqlx v1.2.0/go.mod h1:1FEQNm3xlJgrMD+FBdI9+xvCksHtbpVBBw5dYhBSsks=
|
||||||
github.com/jmoiron/sqlx v1.3.1/go.mod h1:2BljVx/86SuTyjE+aPYlHCTNvZrnJXghYGpNiXLBMCQ=
|
github.com/jmoiron/sqlx v1.3.1/go.mod h1:2BljVx/86SuTyjE+aPYlHCTNvZrnJXghYGpNiXLBMCQ=
|
||||||
|
github.com/jmoiron/sqlx v1.3.5 h1:vFFPA71p1o5gAeqtEAwLU4dnX2napprKtHr7PYIcN3g=
|
||||||
|
github.com/jmoiron/sqlx v1.3.5/go.mod h1:nRVWtLre0KfCLJvgxzCsLVMogSvQ1zNJtpYr2Ccp0mQ=
|
||||||
github.com/joefitzgerald/rainbow-reporter v0.1.0/go.mod h1:481CNgqmVHQZzdIbN52CupLJyoVwB10FQ/IQlF1pdL8=
|
github.com/joefitzgerald/rainbow-reporter v0.1.0/go.mod h1:481CNgqmVHQZzdIbN52CupLJyoVwB10FQ/IQlF1pdL8=
|
||||||
github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg=
|
github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg=
|
||||||
github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo=
|
github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo=
|
||||||
|
@ -2,6 +2,7 @@ package collectibles
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"database/sql"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
"strings"
|
"strings"
|
||||||
@ -20,6 +21,9 @@ import (
|
|||||||
"github.com/status-im/status-go/services/wallet/thirdparty/opensea"
|
"github.com/status-im/status-go/services/wallet/thirdparty/opensea"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const FetchNoLimit = 0
|
||||||
|
const FetchFromStartCursor = ""
|
||||||
|
|
||||||
const requestTimeout = 5 * time.Second
|
const requestTimeout = 5 * time.Second
|
||||||
|
|
||||||
const hystrixContractOwnershipClientName = "contractOwnershipClient"
|
const hystrixContractOwnershipClientName = "contractOwnershipClient"
|
||||||
@ -39,11 +43,10 @@ type Manager struct {
|
|||||||
opensea *opensea.Client
|
opensea *opensea.Client
|
||||||
nftCache map[walletCommon.ChainID]map[string]thirdparty.CollectibleData
|
nftCache map[walletCommon.ChainID]map[string]thirdparty.CollectibleData
|
||||||
nftCacheLock sync.RWMutex
|
nftCacheLock sync.RWMutex
|
||||||
ownershipCache map[walletCommon.ChainID]map[common.Address][]thirdparty.CollectibleUniqueID
|
ownershipDB *OwnershipDB
|
||||||
ownershipCacheLock sync.RWMutex
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewManager(rpcClient *rpc.Client, mainContractOwnershipProvider thirdparty.CollectibleContractOwnershipProvider, fallbackContractOwnershipProvider thirdparty.CollectibleContractOwnershipProvider, opensea *opensea.Client) *Manager {
|
func NewManager(rpcClient *rpc.Client, db *sql.DB, mainContractOwnershipProvider thirdparty.CollectibleContractOwnershipProvider, fallbackContractOwnershipProvider thirdparty.CollectibleContractOwnershipProvider, opensea *opensea.Client) *Manager {
|
||||||
hystrix.ConfigureCommand(hystrixContractOwnershipClientName, hystrix.CommandConfig{
|
hystrix.ConfigureCommand(hystrixContractOwnershipClientName, hystrix.CommandConfig{
|
||||||
Timeout: 10000,
|
Timeout: 10000,
|
||||||
MaxConcurrentRequests: 100,
|
MaxConcurrentRequests: 100,
|
||||||
@ -57,7 +60,7 @@ func NewManager(rpcClient *rpc.Client, mainContractOwnershipProvider thirdparty.
|
|||||||
fallbackContractOwnershipProvider: fallbackContractOwnershipProvider,
|
fallbackContractOwnershipProvider: fallbackContractOwnershipProvider,
|
||||||
opensea: opensea,
|
opensea: opensea,
|
||||||
nftCache: make(map[walletCommon.ChainID]map[string]thirdparty.CollectibleData),
|
nftCache: make(map[walletCommon.ChainID]map[string]thirdparty.CollectibleData),
|
||||||
ownershipCache: make(map[walletCommon.ChainID]map[common.Address][]thirdparty.CollectibleUniqueID),
|
ownershipDB: NewOwnershipDB(db),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,7 +129,7 @@ func (o *Manager) FetchBalancesByOwnerAndContractAddress(chainID walletCommon.Ch
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Try with more direct endpoint first (OpenSea)
|
// Try with more direct endpoint first (OpenSea)
|
||||||
assetsContainer, err := o.FetchAllAssetsByOwnerAndContractAddress(chainID, ownerAddress, contractAddresses, "", 0)
|
assetsContainer, err := o.FetchAllAssetsByOwnerAndContractAddress(chainID, ownerAddress, contractAddresses, FetchFromStartCursor, FetchNoLimit)
|
||||||
if err == opensea.ErrChainIDNotSupported {
|
if err == opensea.ErrChainIDNotSupported {
|
||||||
// Use contract ownership providers
|
// Use contract ownership providers
|
||||||
for _, contractAddress := range contractAddresses {
|
for _, contractAddress := range contractAddresses {
|
||||||
@ -188,7 +191,7 @@ func (o *Manager) FetchAllAssetsByOwner(chainID walletCommon.ChainID, owner comm
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (o *Manager) UpdateOwnedCollectibles(chainID walletCommon.ChainID, owner common.Address) error {
|
func (o *Manager) UpdateOwnedCollectibles(chainID walletCommon.ChainID, owner common.Address) error {
|
||||||
assetContainer, err := o.FetchAllAssetsByOwner(chainID, owner, "", 0)
|
assetContainer, err := o.FetchAllAssetsByOwner(chainID, owner, FetchFromStartCursor, FetchNoLimit)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -207,37 +210,18 @@ func (o *Manager) UpdateOwnedCollectibles(chainID walletCommon.ChainID, owner co
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (o *Manager) GetOwnedCollectibles(chainIDs []walletCommon.ChainID, owners []common.Address, offset int, limit int) ([]thirdparty.CollectibleUniqueID, bool, error) {
|
func (o *Manager) GetOwnedCollectibles(chainIDs []walletCommon.ChainID, owners []common.Address, offset int, limit int) ([]thirdparty.CollectibleUniqueID, bool, error) {
|
||||||
o.ownershipCacheLock.RLock()
|
// Request one more than limit, to check if DB has more available
|
||||||
defer o.ownershipCacheLock.RUnlock()
|
ids, err := o.ownershipDB.GetOwnedCollectibles(chainIDs, owners, offset, limit+1)
|
||||||
|
if err != nil {
|
||||||
ids := make([]thirdparty.CollectibleUniqueID, 0)
|
return nil, false, err
|
||||||
|
|
||||||
for _, chainID := range chainIDs {
|
|
||||||
if _, ok := o.ownershipCache[chainID]; !ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
for _, owner := range owners {
|
|
||||||
ids = append(ids, o.ownershipCache[chainID][owner]...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// For compatibility with SQL OFFSET, skip first 'offset' elems
|
hasMore := len(ids) > limit
|
||||||
lowIdx := offset + 1
|
if hasMore {
|
||||||
|
ids = ids[:limit]
|
||||||
if len(ids) <= lowIdx {
|
|
||||||
return nil, false, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
highIdx := offset + limit
|
return ids, hasMore, nil
|
||||||
if len(ids) < highIdx {
|
|
||||||
highIdx = len(ids)
|
|
||||||
}
|
|
||||||
|
|
||||||
hasMore := len(ids) > highIdx
|
|
||||||
|
|
||||||
ret := ids[lowIdx:highIdx]
|
|
||||||
|
|
||||||
return ret, hasMore, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *Manager) FetchAssetsByCollectibleUniqueID(uniqueIDs []thirdparty.CollectibleUniqueID) ([]thirdparty.CollectibleData, error) {
|
func (o *Manager) FetchAssetsByCollectibleUniqueID(uniqueIDs []thirdparty.CollectibleUniqueID) ([]thirdparty.CollectibleData, error) {
|
||||||
@ -320,21 +304,11 @@ func (o *Manager) processOwnedAssets(chainID walletCommon.ChainID, address commo
|
|||||||
ownership = append(ownership, asset.ID)
|
ownership = append(ownership, asset.ID)
|
||||||
}
|
}
|
||||||
|
|
||||||
o.setCacheOwnedCollectibles(chainID, address, ownership)
|
return o.setCacheOwnedCollectibles(chainID, address, ownership)
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *Manager) setCacheOwnedCollectibles(chainID walletCommon.ChainID, address common.Address, ownership []thirdparty.CollectibleUniqueID) {
|
func (o *Manager) setCacheOwnedCollectibles(chainID walletCommon.ChainID, address common.Address, ownership []thirdparty.CollectibleUniqueID) error {
|
||||||
o.ownershipCacheLock.Lock()
|
return o.ownershipDB.Update(chainID, address, ownership)
|
||||||
defer o.ownershipCacheLock.Unlock()
|
|
||||||
|
|
||||||
if _, ok := o.ownershipCache[chainID]; !ok {
|
|
||||||
o.ownershipCache[chainID] = make(map[common.Address][]thirdparty.CollectibleUniqueID)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Ownership data should be fully replaced with newest list
|
|
||||||
o.ownershipCache[chainID][address] = ownership
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *Manager) processAssets(assets []thirdparty.CollectibleData) error {
|
func (o *Manager) processAssets(assets []thirdparty.CollectibleData) error {
|
||||||
|
@ -2,7 +2,6 @@ package collectibles
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"database/sql"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
@ -22,16 +21,16 @@ const (
|
|||||||
|
|
||||||
type refreshOwnedCollectiblesCommand struct {
|
type refreshOwnedCollectiblesCommand struct {
|
||||||
manager *Manager
|
manager *Manager
|
||||||
db *sql.DB
|
accountsDB *accounts.Database
|
||||||
eventFeed *event.Feed
|
walletFeed *event.Feed
|
||||||
networkManager *network.Manager
|
networkManager *network.Manager
|
||||||
}
|
}
|
||||||
|
|
||||||
func newRefreshOwnedCollectiblesCommand(manager *Manager, db *sql.DB, eventFeed *event.Feed, networkManager *network.Manager) *refreshOwnedCollectiblesCommand {
|
func newRefreshOwnedCollectiblesCommand(manager *Manager, accountsDB *accounts.Database, walletFeed *event.Feed, networkManager *network.Manager) *refreshOwnedCollectiblesCommand {
|
||||||
return &refreshOwnedCollectiblesCommand{
|
return &refreshOwnedCollectiblesCommand{
|
||||||
manager: manager,
|
manager: manager,
|
||||||
db: db,
|
accountsDB: accountsDB,
|
||||||
eventFeed: eventFeed,
|
walletFeed: walletFeed,
|
||||||
networkManager: networkManager,
|
networkManager: networkManager,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -56,7 +55,7 @@ func (c *refreshOwnedCollectiblesCommand) Run(ctx context.Context) (err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *refreshOwnedCollectiblesCommand) triggerEvent(eventType walletevent.EventType, account statustypes.Address, message string) {
|
func (c *refreshOwnedCollectiblesCommand) triggerEvent(eventType walletevent.EventType, account statustypes.Address, message string) {
|
||||||
c.eventFeed.Send(walletevent.Event{
|
c.walletFeed.Send(walletevent.Event{
|
||||||
Type: eventType,
|
Type: eventType,
|
||||||
Accounts: []common.Address{
|
Accounts: []common.Address{
|
||||||
common.Address(account),
|
common.Address(account),
|
||||||
@ -66,12 +65,7 @@ func (c *refreshOwnedCollectiblesCommand) triggerEvent(eventType walletevent.Eve
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *refreshOwnedCollectiblesCommand) updateOwnershipForAllAccounts(ctx context.Context) error {
|
func (c *refreshOwnedCollectiblesCommand) updateOwnershipForAllAccounts(ctx context.Context) error {
|
||||||
accountsDB, err := accounts.NewDB(c.db)
|
addresses, err := c.accountsDB.GetWalletAddresses()
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
addresses, err := accountsDB.GetWalletAddresses()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
140
services/wallet/collectibles/ownership_db.go
Normal file
140
services/wallet/collectibles/ownership_db.go
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
package collectibles
|
||||||
|
|
||||||
|
import (
|
||||||
|
"database/sql"
|
||||||
|
"fmt"
|
||||||
|
"math/big"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum/common"
|
||||||
|
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
|
|
||||||
|
"github.com/status-im/status-go/services/wallet/bigint"
|
||||||
|
w_common "github.com/status-im/status-go/services/wallet/common"
|
||||||
|
"github.com/status-im/status-go/services/wallet/thirdparty"
|
||||||
|
)
|
||||||
|
|
||||||
|
type OwnershipDB struct {
|
||||||
|
db *sql.DB
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewOwnershipDB(sqlDb *sql.DB) *OwnershipDB {
|
||||||
|
return &OwnershipDB{
|
||||||
|
db: sqlDb,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const ownershipColumns = "chain_id, contract_address, token_id, owner_address"
|
||||||
|
const selectOwnershipColumns = "chain_id, contract_address, token_id"
|
||||||
|
|
||||||
|
// statementCreator allows to pass transaction or database to use in consumer.
|
||||||
|
type statementCreator interface {
|
||||||
|
Prepare(query string) (*sql.Stmt, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
func removeAddressOwnership(creator statementCreator, chainID w_common.ChainID, ownerAddress common.Address) error {
|
||||||
|
deleteOwnership, err := creator.Prepare("DELETE FROM collectibles_ownership_cache WHERE chain_id = ? AND owner_address = ?")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = deleteOwnership.Exec(chainID, ownerAddress)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func insertAddressOwnership(creator statementCreator, ownerAddress common.Address, collectibles []thirdparty.CollectibleUniqueID) error {
|
||||||
|
insertOwnership, err := creator.Prepare(fmt.Sprintf(`INSERT INTO collectibles_ownership_cache (%s)
|
||||||
|
VALUES (?, ?, ?, ?)`, ownershipColumns))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, c := range collectibles {
|
||||||
|
_, err = insertOwnership.Exec(c.ChainID, c.ContractAddress, (*bigint.SQLBigIntBytes)(c.TokenID.Int), ownerAddress)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *OwnershipDB) Update(chainID w_common.ChainID, ownerAddress common.Address, collectibles []thirdparty.CollectibleUniqueID) (err error) {
|
||||||
|
var (
|
||||||
|
tx *sql.Tx
|
||||||
|
)
|
||||||
|
tx, err = o.db.Begin()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
if err == nil {
|
||||||
|
err = tx.Commit()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
_ = tx.Rollback()
|
||||||
|
}()
|
||||||
|
|
||||||
|
// Remove previous ownership data
|
||||||
|
err = removeAddressOwnership(tx, chainID, ownerAddress)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Insert new ownership data
|
||||||
|
err = insertAddressOwnership(tx, ownerAddress, collectibles)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func rowsToCollectibles(rows *sql.Rows) ([]thirdparty.CollectibleUniqueID, error) {
|
||||||
|
var ids []thirdparty.CollectibleUniqueID
|
||||||
|
for rows.Next() {
|
||||||
|
id := thirdparty.CollectibleUniqueID{
|
||||||
|
TokenID: &bigint.BigInt{Int: big.NewInt(0)},
|
||||||
|
}
|
||||||
|
err := rows.Scan(
|
||||||
|
&id.ChainID,
|
||||||
|
&id.ContractAddress,
|
||||||
|
(*bigint.SQLBigIntBytes)(id.TokenID.Int),
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
ids = append(ids, id)
|
||||||
|
}
|
||||||
|
|
||||||
|
return ids, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *OwnershipDB) GetOwnedCollectibles(chainIDs []w_common.ChainID, ownerAddresses []common.Address, offset int, limit int) ([]thirdparty.CollectibleUniqueID, error) {
|
||||||
|
query, args, err := sqlx.In(fmt.Sprintf(`SELECT %s
|
||||||
|
FROM collectibles_ownership_cache
|
||||||
|
WHERE chain_id IN (?) AND owner_address IN (?)
|
||||||
|
LIMIT ? OFFSET ?`, selectOwnershipColumns), chainIDs, ownerAddresses, limit, offset)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
stmt, err := o.db.Prepare(query)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer stmt.Close()
|
||||||
|
|
||||||
|
rows, err := stmt.Query(args...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer rows.Close()
|
||||||
|
|
||||||
|
return rowsToCollectibles(rows)
|
||||||
|
}
|
115
services/wallet/collectibles/ownership_db_test.go
Normal file
115
services/wallet/collectibles/ownership_db_test.go
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
package collectibles
|
||||||
|
|
||||||
|
import (
|
||||||
|
"math/big"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum/common"
|
||||||
|
|
||||||
|
"github.com/status-im/status-go/appdatabase"
|
||||||
|
"github.com/status-im/status-go/services/wallet/bigint"
|
||||||
|
w_common "github.com/status-im/status-go/services/wallet/common"
|
||||||
|
"github.com/status-im/status-go/services/wallet/thirdparty"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func setupOwnershipDBTest(t *testing.T) (*OwnershipDB, func()) {
|
||||||
|
db, err := appdatabase.InitializeDB(":memory:", "wallet-collecitibles-ownership-db-tests", 1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
return NewOwnershipDB(db), func() {
|
||||||
|
require.NoError(t, db.Close())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func generateTestCollectibles(chainID w_common.ChainID, count int) (result []thirdparty.CollectibleUniqueID) {
|
||||||
|
result = make([]thirdparty.CollectibleUniqueID, 0, count)
|
||||||
|
for i := 0; i < count; i++ {
|
||||||
|
bigI := big.NewInt(int64(i))
|
||||||
|
newCollectible := thirdparty.CollectibleUniqueID{
|
||||||
|
ChainID: chainID,
|
||||||
|
ContractAddress: common.BigToAddress(bigI),
|
||||||
|
TokenID: &bigint.BigInt{Int: bigI},
|
||||||
|
}
|
||||||
|
result = append(result, newCollectible)
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestUpdateOwnership(t *testing.T) {
|
||||||
|
oDB, cleanDB := setupOwnershipDBTest(t)
|
||||||
|
defer cleanDB()
|
||||||
|
|
||||||
|
ownerAddress1 := common.HexToAddress("0x1234")
|
||||||
|
chainID0 := w_common.ChainID(0)
|
||||||
|
ownedListChain0 := generateTestCollectibles(chainID0, 10)
|
||||||
|
chainID1 := w_common.ChainID(1)
|
||||||
|
ownedListChain1 := generateTestCollectibles(chainID1, 15)
|
||||||
|
|
||||||
|
ownedList1 := append(ownedListChain0, ownedListChain1...)
|
||||||
|
|
||||||
|
ownerAddress2 := common.HexToAddress("0x5678")
|
||||||
|
chainID2 := w_common.ChainID(2)
|
||||||
|
ownedListChain2 := generateTestCollectibles(chainID2, 20)
|
||||||
|
|
||||||
|
ownedList2 := ownedListChain2
|
||||||
|
|
||||||
|
fullList := append(ownedList1, ownedList2...)
|
||||||
|
|
||||||
|
randomAddress := common.HexToAddress("0xABCD")
|
||||||
|
|
||||||
|
var err error
|
||||||
|
|
||||||
|
err = oDB.Update(chainID0, ownerAddress1, ownedListChain0)
|
||||||
|
require.NoError(t, err)
|
||||||
|
err = oDB.Update(chainID1, ownerAddress1, ownedListChain1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
err = oDB.Update(chainID2, ownerAddress2, ownedListChain2)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
loadedList, err := oDB.GetOwnedCollectibles([]w_common.ChainID{chainID0}, []common.Address{ownerAddress1}, 0, len(fullList))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, ownedListChain0, loadedList)
|
||||||
|
|
||||||
|
loadedList, err = oDB.GetOwnedCollectibles([]w_common.ChainID{chainID0, chainID1}, []common.Address{ownerAddress1, randomAddress}, 0, len(fullList))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, ownedList1, loadedList)
|
||||||
|
|
||||||
|
loadedList, err = oDB.GetOwnedCollectibles([]w_common.ChainID{chainID2}, []common.Address{ownerAddress2}, 0, len(fullList))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, ownedList2, loadedList)
|
||||||
|
|
||||||
|
loadedList, err = oDB.GetOwnedCollectibles([]w_common.ChainID{chainID0, chainID1, chainID2}, []common.Address{ownerAddress1, ownerAddress2}, 0, len(fullList))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, fullList, loadedList)
|
||||||
|
|
||||||
|
loadedList, err = oDB.GetOwnedCollectibles([]w_common.ChainID{chainID0}, []common.Address{randomAddress}, 0, len(fullList))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Empty(t, loadedList)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLargeTokenID(t *testing.T) {
|
||||||
|
oDB, cleanDB := setupOwnershipDBTest(t)
|
||||||
|
defer cleanDB()
|
||||||
|
|
||||||
|
ownerAddress := common.HexToAddress("0xABCD")
|
||||||
|
chainID := w_common.ChainID(0)
|
||||||
|
|
||||||
|
ownedListChain := []thirdparty.CollectibleUniqueID{
|
||||||
|
{
|
||||||
|
ChainID: chainID,
|
||||||
|
ContractAddress: common.HexToAddress("0x1234"),
|
||||||
|
TokenID: &bigint.BigInt{Int: big.NewInt(0).SetBytes([]byte("0x1234567890123456789012345678901234567890"))},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var err error
|
||||||
|
|
||||||
|
err = oDB.Update(chainID, ownerAddress, ownedListChain)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
loadedList, err := oDB.GetOwnedCollectibles([]w_common.ChainID{chainID}, []common.Address{ownerAddress}, 0, len(ownedListChain))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, ownedListChain, loadedList)
|
||||||
|
}
|
@ -165,7 +165,7 @@ func (s *Service) startPeriodicalOwnershipFetch() {
|
|||||||
|
|
||||||
command := newRefreshOwnedCollectiblesCommand(
|
command := newRefreshOwnedCollectiblesCommand(
|
||||||
s.manager,
|
s.manager,
|
||||||
s.db,
|
s.accountsDB,
|
||||||
s.walletFeed,
|
s.walletFeed,
|
||||||
s.networkManager,
|
s.networkManager,
|
||||||
)
|
)
|
||||||
|
@ -108,7 +108,7 @@ func NewService(
|
|||||||
alchemyClient := alchemy.NewClient(config.WalletConfig.AlchemyAPIKeys)
|
alchemyClient := alchemy.NewClient(config.WalletConfig.AlchemyAPIKeys)
|
||||||
infuraClient := infura.NewClient(config.WalletConfig.InfuraAPIKey, config.WalletConfig.InfuraAPIKeySecret)
|
infuraClient := infura.NewClient(config.WalletConfig.InfuraAPIKey, config.WalletConfig.InfuraAPIKeySecret)
|
||||||
openseaClient := opensea.NewClient(config.WalletConfig.OpenseaAPIKey, walletFeed)
|
openseaClient := opensea.NewClient(config.WalletConfig.OpenseaAPIKey, walletFeed)
|
||||||
collectiblesManager := collectibles.NewManager(rpcClient, alchemyClient, infuraClient, openseaClient)
|
collectiblesManager := collectibles.NewManager(rpcClient, db, alchemyClient, infuraClient, openseaClient)
|
||||||
collectibles := collectibles.NewService(db, walletFeed, accountsDB, accountFeed, rpcClient.NetworkManager, collectiblesManager)
|
collectibles := collectibles.NewService(db, walletFeed, accountsDB, accountFeed, rpcClient.NetworkManager, collectiblesManager)
|
||||||
return &Service{
|
return &Service{
|
||||||
db: db,
|
db: db,
|
||||||
|
@ -1,150 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2015 Pieter Wuille *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <secp256k1.h>
|
|
||||||
|
|
||||||
#include "lax_der_parsing.h"
|
|
||||||
|
|
||||||
int ecdsa_signature_parse_der_lax(const secp256k1_context* ctx, secp256k1_ecdsa_signature* sig, const unsigned char *input, size_t inputlen) {
|
|
||||||
size_t rpos, rlen, spos, slen;
|
|
||||||
size_t pos = 0;
|
|
||||||
size_t lenbyte;
|
|
||||||
unsigned char tmpsig[64] = {0};
|
|
||||||
int overflow = 0;
|
|
||||||
|
|
||||||
/* Hack to initialize sig with a correctly-parsed but invalid signature. */
|
|
||||||
secp256k1_ecdsa_signature_parse_compact(ctx, sig, tmpsig);
|
|
||||||
|
|
||||||
/* Sequence tag byte */
|
|
||||||
if (pos == inputlen || input[pos] != 0x30) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
pos++;
|
|
||||||
|
|
||||||
/* Sequence length bytes */
|
|
||||||
if (pos == inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lenbyte = input[pos++];
|
|
||||||
if (lenbyte & 0x80) {
|
|
||||||
lenbyte -= 0x80;
|
|
||||||
if (pos + lenbyte > inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
pos += lenbyte;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Integer tag byte for R */
|
|
||||||
if (pos == inputlen || input[pos] != 0x02) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
pos++;
|
|
||||||
|
|
||||||
/* Integer length for R */
|
|
||||||
if (pos == inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lenbyte = input[pos++];
|
|
||||||
if (lenbyte & 0x80) {
|
|
||||||
lenbyte -= 0x80;
|
|
||||||
if (pos + lenbyte > inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
while (lenbyte > 0 && input[pos] == 0) {
|
|
||||||
pos++;
|
|
||||||
lenbyte--;
|
|
||||||
}
|
|
||||||
if (lenbyte >= sizeof(size_t)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
rlen = 0;
|
|
||||||
while (lenbyte > 0) {
|
|
||||||
rlen = (rlen << 8) + input[pos];
|
|
||||||
pos++;
|
|
||||||
lenbyte--;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
rlen = lenbyte;
|
|
||||||
}
|
|
||||||
if (rlen > inputlen - pos) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
rpos = pos;
|
|
||||||
pos += rlen;
|
|
||||||
|
|
||||||
/* Integer tag byte for S */
|
|
||||||
if (pos == inputlen || input[pos] != 0x02) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
pos++;
|
|
||||||
|
|
||||||
/* Integer length for S */
|
|
||||||
if (pos == inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lenbyte = input[pos++];
|
|
||||||
if (lenbyte & 0x80) {
|
|
||||||
lenbyte -= 0x80;
|
|
||||||
if (pos + lenbyte > inputlen) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
while (lenbyte > 0 && input[pos] == 0) {
|
|
||||||
pos++;
|
|
||||||
lenbyte--;
|
|
||||||
}
|
|
||||||
if (lenbyte >= sizeof(size_t)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
slen = 0;
|
|
||||||
while (lenbyte > 0) {
|
|
||||||
slen = (slen << 8) + input[pos];
|
|
||||||
pos++;
|
|
||||||
lenbyte--;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
slen = lenbyte;
|
|
||||||
}
|
|
||||||
if (slen > inputlen - pos) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
spos = pos;
|
|
||||||
pos += slen;
|
|
||||||
|
|
||||||
/* Ignore leading zeroes in R */
|
|
||||||
while (rlen > 0 && input[rpos] == 0) {
|
|
||||||
rlen--;
|
|
||||||
rpos++;
|
|
||||||
}
|
|
||||||
/* Copy R value */
|
|
||||||
if (rlen > 32) {
|
|
||||||
overflow = 1;
|
|
||||||
} else {
|
|
||||||
memcpy(tmpsig + 32 - rlen, input + rpos, rlen);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Ignore leading zeroes in S */
|
|
||||||
while (slen > 0 && input[spos] == 0) {
|
|
||||||
slen--;
|
|
||||||
spos++;
|
|
||||||
}
|
|
||||||
/* Copy S value */
|
|
||||||
if (slen > 32) {
|
|
||||||
overflow = 1;
|
|
||||||
} else {
|
|
||||||
memcpy(tmpsig + 64 - slen, input + spos, slen);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!overflow) {
|
|
||||||
overflow = !secp256k1_ecdsa_signature_parse_compact(ctx, sig, tmpsig);
|
|
||||||
}
|
|
||||||
if (overflow) {
|
|
||||||
memset(tmpsig, 0, 64);
|
|
||||||
secp256k1_ecdsa_signature_parse_compact(ctx, sig, tmpsig);
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
@ -1,91 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2015 Pieter Wuille *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
/****
|
|
||||||
* Please do not link this file directly. It is not part of the libsecp256k1
|
|
||||||
* project and does not promise any stability in its API, functionality or
|
|
||||||
* presence. Projects which use this code should instead copy this header
|
|
||||||
* and its accompanying .c file directly into their codebase.
|
|
||||||
****/
|
|
||||||
|
|
||||||
/* This file defines a function that parses DER with various errors and
|
|
||||||
* violations. This is not a part of the library itself, because the allowed
|
|
||||||
* violations are chosen arbitrarily and do not follow or establish any
|
|
||||||
* standard.
|
|
||||||
*
|
|
||||||
* In many places it matters that different implementations do not only accept
|
|
||||||
* the same set of valid signatures, but also reject the same set of signatures.
|
|
||||||
* The only means to accomplish that is by strictly obeying a standard, and not
|
|
||||||
* accepting anything else.
|
|
||||||
*
|
|
||||||
* Nonetheless, sometimes there is a need for compatibility with systems that
|
|
||||||
* use signatures which do not strictly obey DER. The snippet below shows how
|
|
||||||
* certain violations are easily supported. You may need to adapt it.
|
|
||||||
*
|
|
||||||
* Do not use this for new systems. Use well-defined DER or compact signatures
|
|
||||||
* instead if you have the choice (see secp256k1_ecdsa_signature_parse_der and
|
|
||||||
* secp256k1_ecdsa_signature_parse_compact).
|
|
||||||
*
|
|
||||||
* The supported violations are:
|
|
||||||
* - All numbers are parsed as nonnegative integers, even though X.609-0207
|
|
||||||
* section 8.3.3 specifies that integers are always encoded as two's
|
|
||||||
* complement.
|
|
||||||
* - Integers can have length 0, even though section 8.3.1 says they can't.
|
|
||||||
* - Integers with overly long padding are accepted, violation section
|
|
||||||
* 8.3.2.
|
|
||||||
* - 127-byte long length descriptors are accepted, even though section
|
|
||||||
* 8.1.3.5.c says that they are not.
|
|
||||||
* - Trailing garbage data inside or after the signature is ignored.
|
|
||||||
* - The length descriptor of the sequence is ignored.
|
|
||||||
*
|
|
||||||
* Compared to for example OpenSSL, many violations are NOT supported:
|
|
||||||
* - Using overly long tag descriptors for the sequence or integers inside,
|
|
||||||
* violating section 8.1.2.2.
|
|
||||||
* - Encoding primitive integers as constructed values, violating section
|
|
||||||
* 8.3.1.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _SECP256K1_CONTRIB_LAX_DER_PARSING_H_
|
|
||||||
#define _SECP256K1_CONTRIB_LAX_DER_PARSING_H_
|
|
||||||
|
|
||||||
#include <secp256k1.h>
|
|
||||||
|
|
||||||
# ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/** Parse a signature in "lax DER" format
|
|
||||||
*
|
|
||||||
* Returns: 1 when the signature could be parsed, 0 otherwise.
|
|
||||||
* Args: ctx: a secp256k1 context object
|
|
||||||
* Out: sig: a pointer to a signature object
|
|
||||||
* In: input: a pointer to the signature to be parsed
|
|
||||||
* inputlen: the length of the array pointed to be input
|
|
||||||
*
|
|
||||||
* This function will accept any valid DER encoded signature, even if the
|
|
||||||
* encoded numbers are out of range. In addition, it will accept signatures
|
|
||||||
* which violate the DER spec in various ways. Its purpose is to allow
|
|
||||||
* validation of the Bitcoin blockchain, which includes non-DER signatures
|
|
||||||
* from before the network rules were updated to enforce DER. Note that
|
|
||||||
* the set of supported violations is a strict subset of what OpenSSL will
|
|
||||||
* accept.
|
|
||||||
*
|
|
||||||
* After the call, sig will always be initialized. If parsing failed or the
|
|
||||||
* encoded numbers are out of range, signature validation with it is
|
|
||||||
* guaranteed to fail for every message and public key.
|
|
||||||
*/
|
|
||||||
int ecdsa_signature_parse_der_lax(
|
|
||||||
const secp256k1_context* ctx,
|
|
||||||
secp256k1_ecdsa_signature* sig,
|
|
||||||
const unsigned char *input,
|
|
||||||
size_t inputlen
|
|
||||||
) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(3);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,113 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2014, 2015 Pieter Wuille *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <secp256k1.h>
|
|
||||||
|
|
||||||
#include "lax_der_privatekey_parsing.h"
|
|
||||||
|
|
||||||
int ec_privkey_import_der(const secp256k1_context* ctx, unsigned char *out32, const unsigned char *privkey, size_t privkeylen) {
|
|
||||||
const unsigned char *end = privkey + privkeylen;
|
|
||||||
int lenb = 0;
|
|
||||||
int len = 0;
|
|
||||||
memset(out32, 0, 32);
|
|
||||||
/* sequence header */
|
|
||||||
if (end < privkey+1 || *privkey != 0x30) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
privkey++;
|
|
||||||
/* sequence length constructor */
|
|
||||||
if (end < privkey+1 || !(*privkey & 0x80)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lenb = *privkey & ~0x80; privkey++;
|
|
||||||
if (lenb < 1 || lenb > 2) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (end < privkey+lenb) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
/* sequence length */
|
|
||||||
len = privkey[lenb-1] | (lenb > 1 ? privkey[lenb-2] << 8 : 0);
|
|
||||||
privkey += lenb;
|
|
||||||
if (end < privkey+len) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
/* sequence element 0: version number (=1) */
|
|
||||||
if (end < privkey+3 || privkey[0] != 0x02 || privkey[1] != 0x01 || privkey[2] != 0x01) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
privkey += 3;
|
|
||||||
/* sequence element 1: octet string, up to 32 bytes */
|
|
||||||
if (end < privkey+2 || privkey[0] != 0x04 || privkey[1] > 0x20 || end < privkey+2+privkey[1]) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
memcpy(out32 + 32 - privkey[1], privkey + 2, privkey[1]);
|
|
||||||
if (!secp256k1_ec_seckey_verify(ctx, out32)) {
|
|
||||||
memset(out32, 0, 32);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int ec_privkey_export_der(const secp256k1_context *ctx, unsigned char *privkey, size_t *privkeylen, const unsigned char *key32, int compressed) {
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
size_t pubkeylen = 0;
|
|
||||||
if (!secp256k1_ec_pubkey_create(ctx, &pubkey, key32)) {
|
|
||||||
*privkeylen = 0;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (compressed) {
|
|
||||||
static const unsigned char begin[] = {
|
|
||||||
0x30,0x81,0xD3,0x02,0x01,0x01,0x04,0x20
|
|
||||||
};
|
|
||||||
static const unsigned char middle[] = {
|
|
||||||
0xA0,0x81,0x85,0x30,0x81,0x82,0x02,0x01,0x01,0x30,0x2C,0x06,0x07,0x2A,0x86,0x48,
|
|
||||||
0xCE,0x3D,0x01,0x01,0x02,0x21,0x00,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFE,0xFF,0xFF,0xFC,0x2F,0x30,0x06,0x04,0x01,0x00,0x04,0x01,0x07,0x04,
|
|
||||||
0x21,0x02,0x79,0xBE,0x66,0x7E,0xF9,0xDC,0xBB,0xAC,0x55,0xA0,0x62,0x95,0xCE,0x87,
|
|
||||||
0x0B,0x07,0x02,0x9B,0xFC,0xDB,0x2D,0xCE,0x28,0xD9,0x59,0xF2,0x81,0x5B,0x16,0xF8,
|
|
||||||
0x17,0x98,0x02,0x21,0x00,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFF,0xFF,0xFE,0xBA,0xAE,0xDC,0xE6,0xAF,0x48,0xA0,0x3B,0xBF,0xD2,0x5E,
|
|
||||||
0x8C,0xD0,0x36,0x41,0x41,0x02,0x01,0x01,0xA1,0x24,0x03,0x22,0x00
|
|
||||||
};
|
|
||||||
unsigned char *ptr = privkey;
|
|
||||||
memcpy(ptr, begin, sizeof(begin)); ptr += sizeof(begin);
|
|
||||||
memcpy(ptr, key32, 32); ptr += 32;
|
|
||||||
memcpy(ptr, middle, sizeof(middle)); ptr += sizeof(middle);
|
|
||||||
pubkeylen = 33;
|
|
||||||
secp256k1_ec_pubkey_serialize(ctx, ptr, &pubkeylen, &pubkey, SECP256K1_EC_COMPRESSED);
|
|
||||||
ptr += pubkeylen;
|
|
||||||
*privkeylen = ptr - privkey;
|
|
||||||
} else {
|
|
||||||
static const unsigned char begin[] = {
|
|
||||||
0x30,0x82,0x01,0x13,0x02,0x01,0x01,0x04,0x20
|
|
||||||
};
|
|
||||||
static const unsigned char middle[] = {
|
|
||||||
0xA0,0x81,0xA5,0x30,0x81,0xA2,0x02,0x01,0x01,0x30,0x2C,0x06,0x07,0x2A,0x86,0x48,
|
|
||||||
0xCE,0x3D,0x01,0x01,0x02,0x21,0x00,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFE,0xFF,0xFF,0xFC,0x2F,0x30,0x06,0x04,0x01,0x00,0x04,0x01,0x07,0x04,
|
|
||||||
0x41,0x04,0x79,0xBE,0x66,0x7E,0xF9,0xDC,0xBB,0xAC,0x55,0xA0,0x62,0x95,0xCE,0x87,
|
|
||||||
0x0B,0x07,0x02,0x9B,0xFC,0xDB,0x2D,0xCE,0x28,0xD9,0x59,0xF2,0x81,0x5B,0x16,0xF8,
|
|
||||||
0x17,0x98,0x48,0x3A,0xDA,0x77,0x26,0xA3,0xC4,0x65,0x5D,0xA4,0xFB,0xFC,0x0E,0x11,
|
|
||||||
0x08,0xA8,0xFD,0x17,0xB4,0x48,0xA6,0x85,0x54,0x19,0x9C,0x47,0xD0,0x8F,0xFB,0x10,
|
|
||||||
0xD4,0xB8,0x02,0x21,0x00,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
|
||||||
0xFF,0xFF,0xFF,0xFF,0xFE,0xBA,0xAE,0xDC,0xE6,0xAF,0x48,0xA0,0x3B,0xBF,0xD2,0x5E,
|
|
||||||
0x8C,0xD0,0x36,0x41,0x41,0x02,0x01,0x01,0xA1,0x44,0x03,0x42,0x00
|
|
||||||
};
|
|
||||||
unsigned char *ptr = privkey;
|
|
||||||
memcpy(ptr, begin, sizeof(begin)); ptr += sizeof(begin);
|
|
||||||
memcpy(ptr, key32, 32); ptr += 32;
|
|
||||||
memcpy(ptr, middle, sizeof(middle)); ptr += sizeof(middle);
|
|
||||||
pubkeylen = 65;
|
|
||||||
secp256k1_ec_pubkey_serialize(ctx, ptr, &pubkeylen, &pubkey, SECP256K1_EC_UNCOMPRESSED);
|
|
||||||
ptr += pubkeylen;
|
|
||||||
*privkeylen = ptr - privkey;
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
@ -1,90 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2014, 2015 Pieter Wuille *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
/****
|
|
||||||
* Please do not link this file directly. It is not part of the libsecp256k1
|
|
||||||
* project and does not promise any stability in its API, functionality or
|
|
||||||
* presence. Projects which use this code should instead copy this header
|
|
||||||
* and its accompanying .c file directly into their codebase.
|
|
||||||
****/
|
|
||||||
|
|
||||||
/* This file contains code snippets that parse DER private keys with
|
|
||||||
* various errors and violations. This is not a part of the library
|
|
||||||
* itself, because the allowed violations are chosen arbitrarily and
|
|
||||||
* do not follow or establish any standard.
|
|
||||||
*
|
|
||||||
* It also contains code to serialize private keys in a compatible
|
|
||||||
* manner.
|
|
||||||
*
|
|
||||||
* These functions are meant for compatibility with applications
|
|
||||||
* that require BER encoded keys. When working with secp256k1-specific
|
|
||||||
* code, the simple 32-byte private keys normally used by the
|
|
||||||
* library are sufficient.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _SECP256K1_CONTRIB_BER_PRIVATEKEY_H_
|
|
||||||
#define _SECP256K1_CONTRIB_BER_PRIVATEKEY_H_
|
|
||||||
|
|
||||||
#include <secp256k1.h>
|
|
||||||
|
|
||||||
# ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/** Export a private key in DER format.
|
|
||||||
*
|
|
||||||
* Returns: 1 if the private key was valid.
|
|
||||||
* Args: ctx: pointer to a context object, initialized for signing (cannot
|
|
||||||
* be NULL)
|
|
||||||
* Out: privkey: pointer to an array for storing the private key in BER.
|
|
||||||
* Should have space for 279 bytes, and cannot be NULL.
|
|
||||||
* privkeylen: Pointer to an int where the length of the private key in
|
|
||||||
* privkey will be stored.
|
|
||||||
* In: seckey: pointer to a 32-byte secret key to export.
|
|
||||||
* compressed: 1 if the key should be exported in
|
|
||||||
* compressed format, 0 otherwise
|
|
||||||
*
|
|
||||||
* This function is purely meant for compatibility with applications that
|
|
||||||
* require BER encoded keys. When working with secp256k1-specific code, the
|
|
||||||
* simple 32-byte private keys are sufficient.
|
|
||||||
*
|
|
||||||
* Note that this function does not guarantee correct DER output. It is
|
|
||||||
* guaranteed to be parsable by secp256k1_ec_privkey_import_der
|
|
||||||
*/
|
|
||||||
SECP256K1_WARN_UNUSED_RESULT int ec_privkey_export_der(
|
|
||||||
const secp256k1_context* ctx,
|
|
||||||
unsigned char *privkey,
|
|
||||||
size_t *privkeylen,
|
|
||||||
const unsigned char *seckey,
|
|
||||||
int compressed
|
|
||||||
) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(3) SECP256K1_ARG_NONNULL(4);
|
|
||||||
|
|
||||||
/** Import a private key in DER format.
|
|
||||||
* Returns: 1 if a private key was extracted.
|
|
||||||
* Args: ctx: pointer to a context object (cannot be NULL).
|
|
||||||
* Out: seckey: pointer to a 32-byte array for storing the private key.
|
|
||||||
* (cannot be NULL).
|
|
||||||
* In: privkey: pointer to a private key in DER format (cannot be NULL).
|
|
||||||
* privkeylen: length of the DER private key pointed to be privkey.
|
|
||||||
*
|
|
||||||
* This function will accept more than just strict DER, and even allow some BER
|
|
||||||
* violations. The public key stored inside the DER-encoded private key is not
|
|
||||||
* verified for correctness, nor are the curve parameters. Use this function
|
|
||||||
* only if you know in advance it is supposed to contain a secp256k1 private
|
|
||||||
* key.
|
|
||||||
*/
|
|
||||||
SECP256K1_WARN_UNUSED_RESULT int ec_privkey_import_der(
|
|
||||||
const secp256k1_context* ctx,
|
|
||||||
unsigned char *seckey,
|
|
||||||
const unsigned char *privkey,
|
|
||||||
size_t privkeylen
|
|
||||||
) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(3);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,377 +0,0 @@
|
|||||||
#include <stdlib.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include "org_bitcoin_NativeSecp256k1.h"
|
|
||||||
#include "include/secp256k1.h"
|
|
||||||
#include "include/secp256k1_ecdh.h"
|
|
||||||
#include "include/secp256k1_recovery.h"
|
|
||||||
|
|
||||||
|
|
||||||
SECP256K1_API jlong JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ctx_1clone
|
|
||||||
(JNIEnv* env, jclass classObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
const secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
|
|
||||||
jlong ctx_clone_l = (uintptr_t) secp256k1_context_clone(ctx);
|
|
||||||
|
|
||||||
(void)classObject;(void)env;
|
|
||||||
|
|
||||||
return ctx_clone_l;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1context_1randomize
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
|
|
||||||
const unsigned char* seed = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return secp256k1_context_randomize(ctx, seed);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API void JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1destroy_1context
|
|
||||||
(JNIEnv* env, jclass classObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
|
|
||||||
secp256k1_context_destroy(ctx);
|
|
||||||
|
|
||||||
(void)classObject;(void)env;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdsa_1verify
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint siglen, jint publen)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
|
|
||||||
unsigned char* data = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* sigdata = { (unsigned char*) (data + 32) };
|
|
||||||
const unsigned char* pubdata = { (unsigned char*) (data + siglen + 32) };
|
|
||||||
|
|
||||||
secp256k1_ecdsa_signature sig;
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
|
|
||||||
int ret = secp256k1_ecdsa_signature_parse_der(ctx, &sig, sigdata, siglen);
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
ret = secp256k1_ec_pubkey_parse(ctx, &pubkey, pubdata, publen);
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
ret = secp256k1_ecdsa_verify(ctx, &sig, data, &pubkey);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdsa_1sign
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
unsigned char* data = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
unsigned char* secKey = (unsigned char*) (data + 32);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray sigArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
|
|
||||||
secp256k1_ecdsa_signature sig[72];
|
|
||||||
|
|
||||||
int ret = secp256k1_ecdsa_sign(ctx, sig, data, secKey, NULL, NULL );
|
|
||||||
|
|
||||||
unsigned char outputSer[72];
|
|
||||||
size_t outputLen = 72;
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
int ret2 = secp256k1_ecdsa_signature_serialize_der(ctx,outputSer, &outputLen, sig ); (void)ret2;
|
|
||||||
}
|
|
||||||
|
|
||||||
intsarray[0] = outputLen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
sigArray = (*env)->NewByteArray(env, outputLen);
|
|
||||||
(*env)->SetByteArrayRegion(env, sigArray, 0, outputLen, (jbyte*)outputSer);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, sigArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ec_1seckey_1verify
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
unsigned char* secKey = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return secp256k1_ec_seckey_verify(ctx, secKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ec_1pubkey_1create
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
const unsigned char* secKey = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray pubkeyArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
|
|
||||||
int ret = secp256k1_ec_pubkey_create(ctx, &pubkey, secKey);
|
|
||||||
|
|
||||||
unsigned char outputSer[65];
|
|
||||||
size_t outputLen = 65;
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
int ret2 = secp256k1_ec_pubkey_serialize(ctx,outputSer, &outputLen, &pubkey,SECP256K1_EC_UNCOMPRESSED );(void)ret2;
|
|
||||||
}
|
|
||||||
|
|
||||||
intsarray[0] = outputLen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
pubkeyArray = (*env)->NewByteArray(env, outputLen);
|
|
||||||
(*env)->SetByteArrayRegion(env, pubkeyArray, 0, outputLen, (jbyte*)outputSer);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, pubkeyArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1privkey_1tweak_1add
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
unsigned char* privkey = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* tweak = (unsigned char*) (privkey + 32);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray privArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
|
|
||||||
int privkeylen = 32;
|
|
||||||
|
|
||||||
int ret = secp256k1_ec_privkey_tweak_add(ctx, privkey, tweak);
|
|
||||||
|
|
||||||
intsarray[0] = privkeylen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
privArray = (*env)->NewByteArray(env, privkeylen);
|
|
||||||
(*env)->SetByteArrayRegion(env, privArray, 0, privkeylen, (jbyte*)privkey);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, privArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1privkey_1tweak_1mul
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
unsigned char* privkey = (unsigned char*) (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* tweak = (unsigned char*) (privkey + 32);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray privArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
|
|
||||||
int privkeylen = 32;
|
|
||||||
|
|
||||||
int ret = secp256k1_ec_privkey_tweak_mul(ctx, privkey, tweak);
|
|
||||||
|
|
||||||
intsarray[0] = privkeylen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
privArray = (*env)->NewByteArray(env, privkeylen);
|
|
||||||
(*env)->SetByteArrayRegion(env, privArray, 0, privkeylen, (jbyte*)privkey);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, privArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1pubkey_1tweak_1add
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint publen)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
/* secp256k1_pubkey* pubkey = (secp256k1_pubkey*) (*env)->GetDirectBufferAddress(env, byteBufferObject);*/
|
|
||||||
unsigned char* pkey = (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* tweak = (unsigned char*) (pkey + publen);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray pubArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
unsigned char outputSer[65];
|
|
||||||
size_t outputLen = 65;
|
|
||||||
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
int ret = secp256k1_ec_pubkey_parse(ctx, &pubkey, pkey, publen);
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
ret = secp256k1_ec_pubkey_tweak_add(ctx, &pubkey, tweak);
|
|
||||||
}
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
int ret2 = secp256k1_ec_pubkey_serialize(ctx,outputSer, &outputLen, &pubkey,SECP256K1_EC_UNCOMPRESSED );(void)ret2;
|
|
||||||
}
|
|
||||||
|
|
||||||
intsarray[0] = outputLen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
pubArray = (*env)->NewByteArray(env, outputLen);
|
|
||||||
(*env)->SetByteArrayRegion(env, pubArray, 0, outputLen, (jbyte*)outputSer);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, pubArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1pubkey_1tweak_1mul
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint publen)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
unsigned char* pkey = (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* tweak = (unsigned char*) (pkey + publen);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray pubArray, intsByteArray;
|
|
||||||
unsigned char intsarray[2];
|
|
||||||
unsigned char outputSer[65];
|
|
||||||
size_t outputLen = 65;
|
|
||||||
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
int ret = secp256k1_ec_pubkey_parse(ctx, &pubkey, pkey, publen);
|
|
||||||
|
|
||||||
if ( ret ) {
|
|
||||||
ret = secp256k1_ec_pubkey_tweak_mul(ctx, &pubkey, tweak);
|
|
||||||
}
|
|
||||||
|
|
||||||
if( ret ) {
|
|
||||||
int ret2 = secp256k1_ec_pubkey_serialize(ctx,outputSer, &outputLen, &pubkey,SECP256K1_EC_UNCOMPRESSED );(void)ret2;
|
|
||||||
}
|
|
||||||
|
|
||||||
intsarray[0] = outputLen;
|
|
||||||
intsarray[1] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
pubArray = (*env)->NewByteArray(env, outputLen);
|
|
||||||
(*env)->SetByteArrayRegion(env, pubArray, 0, outputLen, (jbyte*)outputSer);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, pubArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 2);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 2, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jlong JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdsa_1pubkey_1combine
|
|
||||||
(JNIEnv * env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint numkeys)
|
|
||||||
{
|
|
||||||
(void)classObject;(void)env;(void)byteBufferObject;(void)ctx_l;(void)numkeys;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdh
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint publen)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = (secp256k1_context*)(uintptr_t)ctx_l;
|
|
||||||
const unsigned char* secdata = (*env)->GetDirectBufferAddress(env, byteBufferObject);
|
|
||||||
const unsigned char* pubdata = (const unsigned char*) (secdata + 32);
|
|
||||||
|
|
||||||
jobjectArray retArray;
|
|
||||||
jbyteArray outArray, intsByteArray;
|
|
||||||
unsigned char intsarray[1];
|
|
||||||
secp256k1_pubkey pubkey;
|
|
||||||
unsigned char nonce_res[32];
|
|
||||||
size_t outputLen = 32;
|
|
||||||
|
|
||||||
int ret = secp256k1_ec_pubkey_parse(ctx, &pubkey, pubdata, publen);
|
|
||||||
|
|
||||||
if (ret) {
|
|
||||||
ret = secp256k1_ecdh(
|
|
||||||
ctx,
|
|
||||||
nonce_res,
|
|
||||||
&pubkey,
|
|
||||||
secdata
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
intsarray[0] = ret;
|
|
||||||
|
|
||||||
retArray = (*env)->NewObjectArray(env, 2,
|
|
||||||
(*env)->FindClass(env, "[B"),
|
|
||||||
(*env)->NewByteArray(env, 1));
|
|
||||||
|
|
||||||
outArray = (*env)->NewByteArray(env, outputLen);
|
|
||||||
(*env)->SetByteArrayRegion(env, outArray, 0, 32, (jbyte*)nonce_res);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 0, outArray);
|
|
||||||
|
|
||||||
intsByteArray = (*env)->NewByteArray(env, 1);
|
|
||||||
(*env)->SetByteArrayRegion(env, intsByteArray, 0, 1, (jbyte*)intsarray);
|
|
||||||
(*env)->SetObjectArrayElement(env, retArray, 1, intsByteArray);
|
|
||||||
|
|
||||||
(void)classObject;
|
|
||||||
|
|
||||||
return retArray;
|
|
||||||
}
|
|
@ -1,119 +0,0 @@
|
|||||||
/* DO NOT EDIT THIS FILE - it is machine generated */
|
|
||||||
#include <jni.h>
|
|
||||||
#include "include/secp256k1.h"
|
|
||||||
/* Header for class org_bitcoin_NativeSecp256k1 */
|
|
||||||
|
|
||||||
#ifndef _Included_org_bitcoin_NativeSecp256k1
|
|
||||||
#define _Included_org_bitcoin_NativeSecp256k1
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ctx_clone
|
|
||||||
* Signature: (J)J
|
|
||||||
*/
|
|
||||||
SECP256K1_API jlong JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ctx_1clone
|
|
||||||
(JNIEnv *, jclass, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_context_randomize
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)I
|
|
||||||
*/
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1context_1randomize
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_privkey_tweak_add
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1privkey_1tweak_1add
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_privkey_tweak_mul
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1privkey_1tweak_1mul
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_pubkey_tweak_add
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;JI)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1pubkey_1tweak_1add
|
|
||||||
(JNIEnv *, jclass, jobject, jlong, jint);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_pubkey_tweak_mul
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;JI)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1pubkey_1tweak_1mul
|
|
||||||
(JNIEnv *, jclass, jobject, jlong, jint);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_destroy_context
|
|
||||||
* Signature: (J)V
|
|
||||||
*/
|
|
||||||
SECP256K1_API void JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1destroy_1context
|
|
||||||
(JNIEnv *, jclass, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ecdsa_verify
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;JII)I
|
|
||||||
*/
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdsa_1verify
|
|
||||||
(JNIEnv *, jclass, jobject, jlong, jint, jint);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ecdsa_sign
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdsa_1sign
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ec_seckey_verify
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)I
|
|
||||||
*/
|
|
||||||
SECP256K1_API jint JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ec_1seckey_1verify
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ec_pubkey_create
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;J)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ec_1pubkey_1create
|
|
||||||
(JNIEnv *, jclass, jobject, jlong);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ec_pubkey_parse
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;JI)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ec_1pubkey_1parse
|
|
||||||
(JNIEnv *, jclass, jobject, jlong, jint);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_NativeSecp256k1
|
|
||||||
* Method: secp256k1_ecdh
|
|
||||||
* Signature: (Ljava/nio/ByteBuffer;JI)[[B
|
|
||||||
*/
|
|
||||||
SECP256K1_API jobjectArray JNICALL Java_org_bitcoin_NativeSecp256k1_secp256k1_1ecdh
|
|
||||||
(JNIEnv* env, jclass classObject, jobject byteBufferObject, jlong ctx_l, jint publen);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
@ -1,15 +0,0 @@
|
|||||||
#include <stdlib.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include "org_bitcoin_Secp256k1Context.h"
|
|
||||||
#include "include/secp256k1.h"
|
|
||||||
|
|
||||||
SECP256K1_API jlong JNICALL Java_org_bitcoin_Secp256k1Context_secp256k1_1init_1context
|
|
||||||
(JNIEnv* env, jclass classObject)
|
|
||||||
{
|
|
||||||
secp256k1_context *ctx = secp256k1_context_create(SECP256K1_CONTEXT_SIGN | SECP256K1_CONTEXT_VERIFY);
|
|
||||||
|
|
||||||
(void)classObject;(void)env;
|
|
||||||
|
|
||||||
return (uintptr_t)ctx;
|
|
||||||
}
|
|
||||||
|
|
@ -1,22 +0,0 @@
|
|||||||
/* DO NOT EDIT THIS FILE - it is machine generated */
|
|
||||||
#include <jni.h>
|
|
||||||
#include "include/secp256k1.h"
|
|
||||||
/* Header for class org_bitcoin_Secp256k1Context */
|
|
||||||
|
|
||||||
#ifndef _Included_org_bitcoin_Secp256k1Context
|
|
||||||
#define _Included_org_bitcoin_Secp256k1Context
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
/*
|
|
||||||
* Class: org_bitcoin_Secp256k1Context
|
|
||||||
* Method: secp256k1_init_context
|
|
||||||
* Signature: ()J
|
|
||||||
*/
|
|
||||||
SECP256K1_API jlong JNICALL Java_org_bitcoin_Secp256k1Context_secp256k1_1init_1context
|
|
||||||
(JNIEnv *, jclass);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
@ -1,54 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2015 Andrew Poelstra *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
#ifndef _SECP256K1_MODULE_ECDH_MAIN_
|
|
||||||
#define _SECP256K1_MODULE_ECDH_MAIN_
|
|
||||||
|
|
||||||
#include "include/secp256k1_ecdh.h"
|
|
||||||
#include "ecmult_const_impl.h"
|
|
||||||
|
|
||||||
int secp256k1_ecdh(const secp256k1_context* ctx, unsigned char *result, const secp256k1_pubkey *point, const unsigned char *scalar) {
|
|
||||||
int ret = 0;
|
|
||||||
int overflow = 0;
|
|
||||||
secp256k1_gej res;
|
|
||||||
secp256k1_ge pt;
|
|
||||||
secp256k1_scalar s;
|
|
||||||
VERIFY_CHECK(ctx != NULL);
|
|
||||||
ARG_CHECK(result != NULL);
|
|
||||||
ARG_CHECK(point != NULL);
|
|
||||||
ARG_CHECK(scalar != NULL);
|
|
||||||
|
|
||||||
secp256k1_pubkey_load(ctx, &pt, point);
|
|
||||||
secp256k1_scalar_set_b32(&s, scalar, &overflow);
|
|
||||||
if (overflow || secp256k1_scalar_is_zero(&s)) {
|
|
||||||
ret = 0;
|
|
||||||
} else {
|
|
||||||
unsigned char x[32];
|
|
||||||
unsigned char y[1];
|
|
||||||
secp256k1_sha256_t sha;
|
|
||||||
|
|
||||||
secp256k1_ecmult_const(&res, &pt, &s);
|
|
||||||
secp256k1_ge_set_gej(&pt, &res);
|
|
||||||
/* Compute a hash of the point in compressed form
|
|
||||||
* Note we cannot use secp256k1_eckey_pubkey_serialize here since it does not
|
|
||||||
* expect its output to be secret and has a timing sidechannel. */
|
|
||||||
secp256k1_fe_normalize(&pt.x);
|
|
||||||
secp256k1_fe_normalize(&pt.y);
|
|
||||||
secp256k1_fe_get_b32(x, &pt.x);
|
|
||||||
y[0] = 0x02 | secp256k1_fe_is_odd(&pt.y);
|
|
||||||
|
|
||||||
secp256k1_sha256_initialize(&sha);
|
|
||||||
secp256k1_sha256_write(&sha, y, sizeof(y));
|
|
||||||
secp256k1_sha256_write(&sha, x, sizeof(x));
|
|
||||||
secp256k1_sha256_finalize(&sha, result);
|
|
||||||
ret = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
secp256k1_scalar_clear(&s);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,105 +0,0 @@
|
|||||||
/**********************************************************************
|
|
||||||
* Copyright (c) 2015 Andrew Poelstra *
|
|
||||||
* Distributed under the MIT software license, see the accompanying *
|
|
||||||
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
#ifndef _SECP256K1_MODULE_ECDH_TESTS_
|
|
||||||
#define _SECP256K1_MODULE_ECDH_TESTS_
|
|
||||||
|
|
||||||
void test_ecdh_api(void) {
|
|
||||||
/* Setup context that just counts errors */
|
|
||||||
secp256k1_context *tctx = secp256k1_context_create(SECP256K1_CONTEXT_SIGN);
|
|
||||||
secp256k1_pubkey point;
|
|
||||||
unsigned char res[32];
|
|
||||||
unsigned char s_one[32] = { 0 };
|
|
||||||
int32_t ecount = 0;
|
|
||||||
s_one[31] = 1;
|
|
||||||
|
|
||||||
secp256k1_context_set_error_callback(tctx, counting_illegal_callback_fn, &ecount);
|
|
||||||
secp256k1_context_set_illegal_callback(tctx, counting_illegal_callback_fn, &ecount);
|
|
||||||
CHECK(secp256k1_ec_pubkey_create(tctx, &point, s_one) == 1);
|
|
||||||
|
|
||||||
/* Check all NULLs are detected */
|
|
||||||
CHECK(secp256k1_ecdh(tctx, res, &point, s_one) == 1);
|
|
||||||
CHECK(ecount == 0);
|
|
||||||
CHECK(secp256k1_ecdh(tctx, NULL, &point, s_one) == 0);
|
|
||||||
CHECK(ecount == 1);
|
|
||||||
CHECK(secp256k1_ecdh(tctx, res, NULL, s_one) == 0);
|
|
||||||
CHECK(ecount == 2);
|
|
||||||
CHECK(secp256k1_ecdh(tctx, res, &point, NULL) == 0);
|
|
||||||
CHECK(ecount == 3);
|
|
||||||
CHECK(secp256k1_ecdh(tctx, res, &point, s_one) == 1);
|
|
||||||
CHECK(ecount == 3);
|
|
||||||
|
|
||||||
/* Cleanup */
|
|
||||||
secp256k1_context_destroy(tctx);
|
|
||||||
}
|
|
||||||
|
|
||||||
void test_ecdh_generator_basepoint(void) {
|
|
||||||
unsigned char s_one[32] = { 0 };
|
|
||||||
secp256k1_pubkey point[2];
|
|
||||||
int i;
|
|
||||||
|
|
||||||
s_one[31] = 1;
|
|
||||||
/* Check against pubkey creation when the basepoint is the generator */
|
|
||||||
for (i = 0; i < 100; ++i) {
|
|
||||||
secp256k1_sha256_t sha;
|
|
||||||
unsigned char s_b32[32];
|
|
||||||
unsigned char output_ecdh[32];
|
|
||||||
unsigned char output_ser[32];
|
|
||||||
unsigned char point_ser[33];
|
|
||||||
size_t point_ser_len = sizeof(point_ser);
|
|
||||||
secp256k1_scalar s;
|
|
||||||
|
|
||||||
random_scalar_order(&s);
|
|
||||||
secp256k1_scalar_get_b32(s_b32, &s);
|
|
||||||
|
|
||||||
/* compute using ECDH function */
|
|
||||||
CHECK(secp256k1_ec_pubkey_create(ctx, &point[0], s_one) == 1);
|
|
||||||
CHECK(secp256k1_ecdh(ctx, output_ecdh, &point[0], s_b32) == 1);
|
|
||||||
/* compute "explicitly" */
|
|
||||||
CHECK(secp256k1_ec_pubkey_create(ctx, &point[1], s_b32) == 1);
|
|
||||||
CHECK(secp256k1_ec_pubkey_serialize(ctx, point_ser, &point_ser_len, &point[1], SECP256K1_EC_COMPRESSED) == 1);
|
|
||||||
CHECK(point_ser_len == sizeof(point_ser));
|
|
||||||
secp256k1_sha256_initialize(&sha);
|
|
||||||
secp256k1_sha256_write(&sha, point_ser, point_ser_len);
|
|
||||||
secp256k1_sha256_finalize(&sha, output_ser);
|
|
||||||
/* compare */
|
|
||||||
CHECK(memcmp(output_ecdh, output_ser, sizeof(output_ser)) == 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void test_bad_scalar(void) {
|
|
||||||
unsigned char s_zero[32] = { 0 };
|
|
||||||
unsigned char s_overflow[32] = {
|
|
||||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
||||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe,
|
|
||||||
0xba, 0xae, 0xdc, 0xe6, 0xaf, 0x48, 0xa0, 0x3b,
|
|
||||||
0xbf, 0xd2, 0x5e, 0x8c, 0xd0, 0x36, 0x41, 0x41
|
|
||||||
};
|
|
||||||
unsigned char s_rand[32] = { 0 };
|
|
||||||
unsigned char output[32];
|
|
||||||
secp256k1_scalar rand;
|
|
||||||
secp256k1_pubkey point;
|
|
||||||
|
|
||||||
/* Create random point */
|
|
||||||
random_scalar_order(&rand);
|
|
||||||
secp256k1_scalar_get_b32(s_rand, &rand);
|
|
||||||
CHECK(secp256k1_ec_pubkey_create(ctx, &point, s_rand) == 1);
|
|
||||||
|
|
||||||
/* Try to multiply it by bad values */
|
|
||||||
CHECK(secp256k1_ecdh(ctx, output, &point, s_zero) == 0);
|
|
||||||
CHECK(secp256k1_ecdh(ctx, output, &point, s_overflow) == 0);
|
|
||||||
/* ...and a good one */
|
|
||||||
s_overflow[31] -= 1;
|
|
||||||
CHECK(secp256k1_ecdh(ctx, output, &point, s_overflow) == 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void run_ecdh_tests(void) {
|
|
||||||
test_ecdh_api();
|
|
||||||
test_ecdh_generator_basepoint();
|
|
||||||
test_bad_scalar();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
25
vendor/github.com/jmoiron/sqlx/.gitignore
generated
vendored
Normal file
25
vendor/github.com/jmoiron/sqlx/.gitignore
generated
vendored
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
# Compiled Object files, Static and Dynamic libs (Shared Objects)
|
||||||
|
*.o
|
||||||
|
*.a
|
||||||
|
*.so
|
||||||
|
|
||||||
|
# Folders
|
||||||
|
_obj
|
||||||
|
_test
|
||||||
|
.idea
|
||||||
|
|
||||||
|
# Architecture specific extensions/prefixes
|
||||||
|
*.[568vq]
|
||||||
|
[568vq].out
|
||||||
|
|
||||||
|
*.cgo1.go
|
||||||
|
*.cgo2.c
|
||||||
|
_cgo_defun.c
|
||||||
|
_cgo_gotypes.go
|
||||||
|
_cgo_export.*
|
||||||
|
|
||||||
|
_testmain.go
|
||||||
|
|
||||||
|
*.exe
|
||||||
|
tags
|
||||||
|
environ
|
26
vendor/github.com/jmoiron/sqlx/.travis.yml
generated
vendored
Normal file
26
vendor/github.com/jmoiron/sqlx/.travis.yml
generated
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# vim: ft=yaml sw=2 ts=2
|
||||||
|
|
||||||
|
language: go
|
||||||
|
|
||||||
|
# enable database services
|
||||||
|
services:
|
||||||
|
- mysql
|
||||||
|
- postgresql
|
||||||
|
|
||||||
|
# create test database
|
||||||
|
before_install:
|
||||||
|
- mysql -e 'CREATE DATABASE IF NOT EXISTS sqlxtest;'
|
||||||
|
- psql -c 'create database sqlxtest;' -U postgres
|
||||||
|
- go get github.com/mattn/goveralls
|
||||||
|
- export SQLX_MYSQL_DSN="travis:@/sqlxtest?parseTime=true"
|
||||||
|
- export SQLX_POSTGRES_DSN="postgres://postgres:@localhost/sqlxtest?sslmode=disable"
|
||||||
|
- export SQLX_SQLITE_DSN="$HOME/sqlxtest.db"
|
||||||
|
|
||||||
|
# go versions to test
|
||||||
|
go:
|
||||||
|
- "1.15.x"
|
||||||
|
- "1.16.x"
|
||||||
|
|
||||||
|
# run tests w/ coverage
|
||||||
|
script:
|
||||||
|
- travis_retry $GOPATH/bin/goveralls -service=travis-ci
|
23
vendor/github.com/jmoiron/sqlx/LICENSE
generated
vendored
Normal file
23
vendor/github.com/jmoiron/sqlx/LICENSE
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
Copyright (c) 2013, Jason Moiron
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person
|
||||||
|
obtaining a copy of this software and associated documentation
|
||||||
|
files (the "Software"), to deal in the Software without
|
||||||
|
restriction, including without limitation the rights to use,
|
||||||
|
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the
|
||||||
|
Software is furnished to do so, subject to the following
|
||||||
|
conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||||
|
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||||
|
OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
213
vendor/github.com/jmoiron/sqlx/README.md
generated
vendored
Normal file
213
vendor/github.com/jmoiron/sqlx/README.md
generated
vendored
Normal file
@ -0,0 +1,213 @@
|
|||||||
|
# sqlx
|
||||||
|
|
||||||
|
[![Build Status](https://travis-ci.org/jmoiron/sqlx.svg?branch=master)](https://travis-ci.org/jmoiron/sqlx) [![Coverage Status](https://coveralls.io/repos/github/jmoiron/sqlx/badge.svg?branch=master)](https://coveralls.io/github/jmoiron/sqlx?branch=master) [![Godoc](http://img.shields.io/badge/godoc-reference-blue.svg?style=flat)](https://godoc.org/github.com/jmoiron/sqlx) [![license](http://img.shields.io/badge/license-MIT-red.svg?style=flat)](https://raw.githubusercontent.com/jmoiron/sqlx/master/LICENSE)
|
||||||
|
|
||||||
|
sqlx is a library which provides a set of extensions on go's standard
|
||||||
|
`database/sql` library. The sqlx versions of `sql.DB`, `sql.TX`, `sql.Stmt`,
|
||||||
|
et al. all leave the underlying interfaces untouched, so that their interfaces
|
||||||
|
are a superset on the standard ones. This makes it relatively painless to
|
||||||
|
integrate existing codebases using database/sql with sqlx.
|
||||||
|
|
||||||
|
Major additional concepts are:
|
||||||
|
|
||||||
|
* Marshal rows into structs (with embedded struct support), maps, and slices
|
||||||
|
* Named parameter support including prepared statements
|
||||||
|
* `Get` and `Select` to go quickly from query to struct/slice
|
||||||
|
|
||||||
|
In addition to the [godoc API documentation](http://godoc.org/github.com/jmoiron/sqlx),
|
||||||
|
there is also some [user documentation](http://jmoiron.github.io/sqlx/) that
|
||||||
|
explains how to use `database/sql` along with sqlx.
|
||||||
|
|
||||||
|
## Recent Changes
|
||||||
|
|
||||||
|
1.3.0:
|
||||||
|
|
||||||
|
* `sqlx.DB.Connx(context.Context) *sqlx.Conn`
|
||||||
|
* `sqlx.BindDriver(driverName, bindType)`
|
||||||
|
* support for `[]map[string]interface{}` to do "batch" insertions
|
||||||
|
* allocation & perf improvements for `sqlx.In`
|
||||||
|
|
||||||
|
DB.Connx returns an `sqlx.Conn`, which is an `sql.Conn`-alike consistent with
|
||||||
|
sqlx's wrapping of other types.
|
||||||
|
|
||||||
|
`BindDriver` allows users to control the bindvars that sqlx will use for drivers,
|
||||||
|
and add new drivers at runtime. This results in a very slight performance hit
|
||||||
|
when resolving the driver into a bind type (~40ns per call), but it allows users
|
||||||
|
to specify what bindtype their driver uses even when sqlx has not been updated
|
||||||
|
to know about it by default.
|
||||||
|
|
||||||
|
### Backwards Compatibility
|
||||||
|
|
||||||
|
Compatibility with the most recent two versions of Go is a requirement for any
|
||||||
|
new changes. Compatibility beyond that is not guaranteed.
|
||||||
|
|
||||||
|
Versioning is done with Go modules. Breaking changes (eg. removing deprecated API)
|
||||||
|
will get major version number bumps.
|
||||||
|
|
||||||
|
## install
|
||||||
|
|
||||||
|
go get github.com/jmoiron/sqlx
|
||||||
|
|
||||||
|
## issues
|
||||||
|
|
||||||
|
Row headers can be ambiguous (`SELECT 1 AS a, 2 AS a`), and the result of
|
||||||
|
`Columns()` does not fully qualify column names in queries like:
|
||||||
|
|
||||||
|
```sql
|
||||||
|
SELECT a.id, a.name, b.id, b.name FROM foos AS a JOIN foos AS b ON a.parent = b.id;
|
||||||
|
```
|
||||||
|
|
||||||
|
making a struct or map destination ambiguous. Use `AS` in your queries
|
||||||
|
to give columns distinct names, `rows.Scan` to scan them manually, or
|
||||||
|
`SliceScan` to get a slice of results.
|
||||||
|
|
||||||
|
## usage
|
||||||
|
|
||||||
|
Below is an example which shows some common use cases for sqlx. Check
|
||||||
|
[sqlx_test.go](https://github.com/jmoiron/sqlx/blob/master/sqlx_test.go) for more
|
||||||
|
usage.
|
||||||
|
|
||||||
|
|
||||||
|
```go
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"database/sql"
|
||||||
|
"fmt"
|
||||||
|
"log"
|
||||||
|
|
||||||
|
_ "github.com/lib/pq"
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
|
)
|
||||||
|
|
||||||
|
var schema = `
|
||||||
|
CREATE TABLE person (
|
||||||
|
first_name text,
|
||||||
|
last_name text,
|
||||||
|
email text
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE place (
|
||||||
|
country text,
|
||||||
|
city text NULL,
|
||||||
|
telcode integer
|
||||||
|
)`
|
||||||
|
|
||||||
|
type Person struct {
|
||||||
|
FirstName string `db:"first_name"`
|
||||||
|
LastName string `db:"last_name"`
|
||||||
|
Email string
|
||||||
|
}
|
||||||
|
|
||||||
|
type Place struct {
|
||||||
|
Country string
|
||||||
|
City sql.NullString
|
||||||
|
TelCode int
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
// this Pings the database trying to connect
|
||||||
|
// use sqlx.Open() for sql.Open() semantics
|
||||||
|
db, err := sqlx.Connect("postgres", "user=foo dbname=bar sslmode=disable")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// exec the schema or fail; multi-statement Exec behavior varies between
|
||||||
|
// database drivers; pq will exec them all, sqlite3 won't, ymmv
|
||||||
|
db.MustExec(schema)
|
||||||
|
|
||||||
|
tx := db.MustBegin()
|
||||||
|
tx.MustExec("INSERT INTO person (first_name, last_name, email) VALUES ($1, $2, $3)", "Jason", "Moiron", "jmoiron@jmoiron.net")
|
||||||
|
tx.MustExec("INSERT INTO person (first_name, last_name, email) VALUES ($1, $2, $3)", "John", "Doe", "johndoeDNE@gmail.net")
|
||||||
|
tx.MustExec("INSERT INTO place (country, city, telcode) VALUES ($1, $2, $3)", "United States", "New York", "1")
|
||||||
|
tx.MustExec("INSERT INTO place (country, telcode) VALUES ($1, $2)", "Hong Kong", "852")
|
||||||
|
tx.MustExec("INSERT INTO place (country, telcode) VALUES ($1, $2)", "Singapore", "65")
|
||||||
|
// Named queries can use structs, so if you have an existing struct (i.e. person := &Person{}) that you have populated, you can pass it in as &person
|
||||||
|
tx.NamedExec("INSERT INTO person (first_name, last_name, email) VALUES (:first_name, :last_name, :email)", &Person{"Jane", "Citizen", "jane.citzen@example.com"})
|
||||||
|
tx.Commit()
|
||||||
|
|
||||||
|
// Query the database, storing results in a []Person (wrapped in []interface{})
|
||||||
|
people := []Person{}
|
||||||
|
db.Select(&people, "SELECT * FROM person ORDER BY first_name ASC")
|
||||||
|
jason, john := people[0], people[1]
|
||||||
|
|
||||||
|
fmt.Printf("%#v\n%#v", jason, john)
|
||||||
|
// Person{FirstName:"Jason", LastName:"Moiron", Email:"jmoiron@jmoiron.net"}
|
||||||
|
// Person{FirstName:"John", LastName:"Doe", Email:"johndoeDNE@gmail.net"}
|
||||||
|
|
||||||
|
// You can also get a single result, a la QueryRow
|
||||||
|
jason = Person{}
|
||||||
|
err = db.Get(&jason, "SELECT * FROM person WHERE first_name=$1", "Jason")
|
||||||
|
fmt.Printf("%#v\n", jason)
|
||||||
|
// Person{FirstName:"Jason", LastName:"Moiron", Email:"jmoiron@jmoiron.net"}
|
||||||
|
|
||||||
|
// if you have null fields and use SELECT *, you must use sql.Null* in your struct
|
||||||
|
places := []Place{}
|
||||||
|
err = db.Select(&places, "SELECT * FROM place ORDER BY telcode ASC")
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
usa, singsing, honkers := places[0], places[1], places[2]
|
||||||
|
|
||||||
|
fmt.Printf("%#v\n%#v\n%#v\n", usa, singsing, honkers)
|
||||||
|
// Place{Country:"United States", City:sql.NullString{String:"New York", Valid:true}, TelCode:1}
|
||||||
|
// Place{Country:"Singapore", City:sql.NullString{String:"", Valid:false}, TelCode:65}
|
||||||
|
// Place{Country:"Hong Kong", City:sql.NullString{String:"", Valid:false}, TelCode:852}
|
||||||
|
|
||||||
|
// Loop through rows using only one struct
|
||||||
|
place := Place{}
|
||||||
|
rows, err := db.Queryx("SELECT * FROM place")
|
||||||
|
for rows.Next() {
|
||||||
|
err := rows.StructScan(&place)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
fmt.Printf("%#v\n", place)
|
||||||
|
}
|
||||||
|
// Place{Country:"United States", City:sql.NullString{String:"New York", Valid:true}, TelCode:1}
|
||||||
|
// Place{Country:"Hong Kong", City:sql.NullString{String:"", Valid:false}, TelCode:852}
|
||||||
|
// Place{Country:"Singapore", City:sql.NullString{String:"", Valid:false}, TelCode:65}
|
||||||
|
|
||||||
|
// Named queries, using `:name` as the bindvar. Automatic bindvar support
|
||||||
|
// which takes into account the dbtype based on the driverName on sqlx.Open/Connect
|
||||||
|
_, err = db.NamedExec(`INSERT INTO person (first_name,last_name,email) VALUES (:first,:last,:email)`,
|
||||||
|
map[string]interface{}{
|
||||||
|
"first": "Bin",
|
||||||
|
"last": "Smuth",
|
||||||
|
"email": "bensmith@allblacks.nz",
|
||||||
|
})
|
||||||
|
|
||||||
|
// Selects Mr. Smith from the database
|
||||||
|
rows, err = db.NamedQuery(`SELECT * FROM person WHERE first_name=:fn`, map[string]interface{}{"fn": "Bin"})
|
||||||
|
|
||||||
|
// Named queries can also use structs. Their bind names follow the same rules
|
||||||
|
// as the name -> db mapping, so struct fields are lowercased and the `db` tag
|
||||||
|
// is taken into consideration.
|
||||||
|
rows, err = db.NamedQuery(`SELECT * FROM person WHERE first_name=:first_name`, jason)
|
||||||
|
|
||||||
|
|
||||||
|
// batch insert
|
||||||
|
|
||||||
|
// batch insert with structs
|
||||||
|
personStructs := []Person{
|
||||||
|
{FirstName: "Ardie", LastName: "Savea", Email: "asavea@ab.co.nz"},
|
||||||
|
{FirstName: "Sonny Bill", LastName: "Williams", Email: "sbw@ab.co.nz"},
|
||||||
|
{FirstName: "Ngani", LastName: "Laumape", Email: "nlaumape@ab.co.nz"},
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = db.NamedExec(`INSERT INTO person (first_name, last_name, email)
|
||||||
|
VALUES (:first_name, :last_name, :email)`, personStructs)
|
||||||
|
|
||||||
|
// batch insert with maps
|
||||||
|
personMaps := []map[string]interface{}{
|
||||||
|
{"first_name": "Ardie", "last_name": "Savea", "email": "asavea@ab.co.nz"},
|
||||||
|
{"first_name": "Sonny Bill", "last_name": "Williams", "email": "sbw@ab.co.nz"},
|
||||||
|
{"first_name": "Ngani", "last_name": "Laumape", "email": "nlaumape@ab.co.nz"},
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = db.NamedExec(`INSERT INTO person (first_name, last_name, email)
|
||||||
|
VALUES (:first_name, :last_name, :email)`, personMaps)
|
||||||
|
}
|
||||||
|
```
|
265
vendor/github.com/jmoiron/sqlx/bind.go
generated
vendored
Normal file
265
vendor/github.com/jmoiron/sqlx/bind.go
generated
vendored
Normal file
@ -0,0 +1,265 @@
|
|||||||
|
package sqlx
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"database/sql/driver"
|
||||||
|
"errors"
|
||||||
|
"reflect"
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
|
"github.com/jmoiron/sqlx/reflectx"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Bindvar types supported by Rebind, BindMap and BindStruct.
|
||||||
|
const (
|
||||||
|
UNKNOWN = iota
|
||||||
|
QUESTION
|
||||||
|
DOLLAR
|
||||||
|
NAMED
|
||||||
|
AT
|
||||||
|
)
|
||||||
|
|
||||||
|
var defaultBinds = map[int][]string{
|
||||||
|
DOLLAR: []string{"postgres", "pgx", "pq-timeouts", "cloudsqlpostgres", "ql", "nrpostgres", "cockroach"},
|
||||||
|
QUESTION: []string{"mysql", "sqlite3", "nrmysql", "nrsqlite3"},
|
||||||
|
NAMED: []string{"oci8", "ora", "goracle", "godror"},
|
||||||
|
AT: []string{"sqlserver"},
|
||||||
|
}
|
||||||
|
|
||||||
|
var binds sync.Map
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
for bind, drivers := range defaultBinds {
|
||||||
|
for _, driver := range drivers {
|
||||||
|
BindDriver(driver, bind)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// BindType returns the bindtype for a given database given a drivername.
|
||||||
|
func BindType(driverName string) int {
|
||||||
|
itype, ok := binds.Load(driverName)
|
||||||
|
if !ok {
|
||||||
|
return UNKNOWN
|
||||||
|
}
|
||||||
|
return itype.(int)
|
||||||
|
}
|
||||||
|
|
||||||
|
// BindDriver sets the BindType for driverName to bindType.
|
||||||
|
func BindDriver(driverName string, bindType int) {
|
||||||
|
binds.Store(driverName, bindType)
|
||||||
|
}
|
||||||
|
|
||||||
|
// FIXME: this should be able to be tolerant of escaped ?'s in queries without
|
||||||
|
// losing much speed, and should be to avoid confusion.
|
||||||
|
|
||||||
|
// Rebind a query from the default bindtype (QUESTION) to the target bindtype.
|
||||||
|
func Rebind(bindType int, query string) string {
|
||||||
|
switch bindType {
|
||||||
|
case QUESTION, UNKNOWN:
|
||||||
|
return query
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add space enough for 10 params before we have to allocate
|
||||||
|
rqb := make([]byte, 0, len(query)+10)
|
||||||
|
|
||||||
|
var i, j int
|
||||||
|
|
||||||
|
for i = strings.Index(query, "?"); i != -1; i = strings.Index(query, "?") {
|
||||||
|
rqb = append(rqb, query[:i]...)
|
||||||
|
|
||||||
|
switch bindType {
|
||||||
|
case DOLLAR:
|
||||||
|
rqb = append(rqb, '$')
|
||||||
|
case NAMED:
|
||||||
|
rqb = append(rqb, ':', 'a', 'r', 'g')
|
||||||
|
case AT:
|
||||||
|
rqb = append(rqb, '@', 'p')
|
||||||
|
}
|
||||||
|
|
||||||
|
j++
|
||||||
|
rqb = strconv.AppendInt(rqb, int64(j), 10)
|
||||||
|
|
||||||
|
query = query[i+1:]
|
||||||
|
}
|
||||||
|
|
||||||
|
return string(append(rqb, query...))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Experimental implementation of Rebind which uses a bytes.Buffer. The code is
|
||||||
|
// much simpler and should be more resistant to odd unicode, but it is twice as
|
||||||
|
// slow. Kept here for benchmarking purposes and to possibly replace Rebind if
|
||||||
|
// problems arise with its somewhat naive handling of unicode.
|
||||||
|
func rebindBuff(bindType int, query string) string {
|
||||||
|
if bindType != DOLLAR {
|
||||||
|
return query
|
||||||
|
}
|
||||||
|
|
||||||
|
b := make([]byte, 0, len(query))
|
||||||
|
rqb := bytes.NewBuffer(b)
|
||||||
|
j := 1
|
||||||
|
for _, r := range query {
|
||||||
|
if r == '?' {
|
||||||
|
rqb.WriteRune('$')
|
||||||
|
rqb.WriteString(strconv.Itoa(j))
|
||||||
|
j++
|
||||||
|
} else {
|
||||||
|
rqb.WriteRune(r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return rqb.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
func asSliceForIn(i interface{}) (v reflect.Value, ok bool) {
|
||||||
|
if i == nil {
|
||||||
|
return reflect.Value{}, false
|
||||||
|
}
|
||||||
|
|
||||||
|
v = reflect.ValueOf(i)
|
||||||
|
t := reflectx.Deref(v.Type())
|
||||||
|
|
||||||
|
// Only expand slices
|
||||||
|
if t.Kind() != reflect.Slice {
|
||||||
|
return reflect.Value{}, false
|
||||||
|
}
|
||||||
|
|
||||||
|
// []byte is a driver.Value type so it should not be expanded
|
||||||
|
if t == reflect.TypeOf([]byte{}) {
|
||||||
|
return reflect.Value{}, false
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return v, true
|
||||||
|
}
|
||||||
|
|
||||||
|
// In expands slice values in args, returning the modified query string
|
||||||
|
// and a new arg list that can be executed by a database. The `query` should
|
||||||
|
// use the `?` bindVar. The return value uses the `?` bindVar.
|
||||||
|
func In(query string, args ...interface{}) (string, []interface{}, error) {
|
||||||
|
// argMeta stores reflect.Value and length for slices and
|
||||||
|
// the value itself for non-slice arguments
|
||||||
|
type argMeta struct {
|
||||||
|
v reflect.Value
|
||||||
|
i interface{}
|
||||||
|
length int
|
||||||
|
}
|
||||||
|
|
||||||
|
var flatArgsCount int
|
||||||
|
var anySlices bool
|
||||||
|
|
||||||
|
var stackMeta [32]argMeta
|
||||||
|
|
||||||
|
var meta []argMeta
|
||||||
|
if len(args) <= len(stackMeta) {
|
||||||
|
meta = stackMeta[:len(args)]
|
||||||
|
} else {
|
||||||
|
meta = make([]argMeta, len(args))
|
||||||
|
}
|
||||||
|
|
||||||
|
for i, arg := range args {
|
||||||
|
if a, ok := arg.(driver.Valuer); ok {
|
||||||
|
var err error
|
||||||
|
arg, err = a.Value()
|
||||||
|
if err != nil {
|
||||||
|
return "", nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if v, ok := asSliceForIn(arg); ok {
|
||||||
|
meta[i].length = v.Len()
|
||||||
|
meta[i].v = v
|
||||||
|
|
||||||
|
anySlices = true
|
||||||
|
flatArgsCount += meta[i].length
|
||||||
|
|
||||||
|
if meta[i].length == 0 {
|
||||||
|
return "", nil, errors.New("empty slice passed to 'in' query")
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
meta[i].i = arg
|
||||||
|
flatArgsCount++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// don't do any parsing if there aren't any slices; note that this means
|
||||||
|
// some errors that we might have caught below will not be returned.
|
||||||
|
if !anySlices {
|
||||||
|
return query, args, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
newArgs := make([]interface{}, 0, flatArgsCount)
|
||||||
|
|
||||||
|
var buf strings.Builder
|
||||||
|
buf.Grow(len(query) + len(", ?")*flatArgsCount)
|
||||||
|
|
||||||
|
var arg, offset int
|
||||||
|
|
||||||
|
for i := strings.IndexByte(query[offset:], '?'); i != -1; i = strings.IndexByte(query[offset:], '?') {
|
||||||
|
if arg >= len(meta) {
|
||||||
|
// if an argument wasn't passed, lets return an error; this is
|
||||||
|
// not actually how database/sql Exec/Query works, but since we are
|
||||||
|
// creating an argument list programmatically, we want to be able
|
||||||
|
// to catch these programmer errors earlier.
|
||||||
|
return "", nil, errors.New("number of bindVars exceeds arguments")
|
||||||
|
}
|
||||||
|
|
||||||
|
argMeta := meta[arg]
|
||||||
|
arg++
|
||||||
|
|
||||||
|
// not a slice, continue.
|
||||||
|
// our questionmark will either be written before the next expansion
|
||||||
|
// of a slice or after the loop when writing the rest of the query
|
||||||
|
if argMeta.length == 0 {
|
||||||
|
offset = offset + i + 1
|
||||||
|
newArgs = append(newArgs, argMeta.i)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// write everything up to and including our ? character
|
||||||
|
buf.WriteString(query[:offset+i+1])
|
||||||
|
|
||||||
|
for si := 1; si < argMeta.length; si++ {
|
||||||
|
buf.WriteString(", ?")
|
||||||
|
}
|
||||||
|
|
||||||
|
newArgs = appendReflectSlice(newArgs, argMeta.v, argMeta.length)
|
||||||
|
|
||||||
|
// slice the query and reset the offset. this avoids some bookkeeping for
|
||||||
|
// the write after the loop
|
||||||
|
query = query[offset+i+1:]
|
||||||
|
offset = 0
|
||||||
|
}
|
||||||
|
|
||||||
|
buf.WriteString(query)
|
||||||
|
|
||||||
|
if arg < len(meta) {
|
||||||
|
return "", nil, errors.New("number of bindVars less than number arguments")
|
||||||
|
}
|
||||||
|
|
||||||
|
return buf.String(), newArgs, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func appendReflectSlice(args []interface{}, v reflect.Value, vlen int) []interface{} {
|
||||||
|
switch val := v.Interface().(type) {
|
||||||
|
case []interface{}:
|
||||||
|
args = append(args, val...)
|
||||||
|
case []int:
|
||||||
|
for i := range val {
|
||||||
|
args = append(args, val[i])
|
||||||
|
}
|
||||||
|
case []string:
|
||||||
|
for i := range val {
|
||||||
|
args = append(args, val[i])
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
for si := 0; si < vlen; si++ {
|
||||||
|
args = append(args, v.Index(si).Interface())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return args
|
||||||
|
}
|
12
vendor/github.com/jmoiron/sqlx/doc.go
generated
vendored
Normal file
12
vendor/github.com/jmoiron/sqlx/doc.go
generated
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
// Package sqlx provides general purpose extensions to database/sql.
|
||||||
|
//
|
||||||
|
// It is intended to seamlessly wrap database/sql and provide convenience
|
||||||
|
// methods which are useful in the development of database driven applications.
|
||||||
|
// None of the underlying database/sql methods are changed. Instead all extended
|
||||||
|
// behavior is implemented through new methods defined on wrapper types.
|
||||||
|
//
|
||||||
|
// Additions include scanning into structs, named query support, rebinding
|
||||||
|
// queries for different drivers, convenient shorthands for common error handling
|
||||||
|
// and more.
|
||||||
|
//
|
||||||
|
package sqlx
|
458
vendor/github.com/jmoiron/sqlx/named.go
generated
vendored
Normal file
458
vendor/github.com/jmoiron/sqlx/named.go
generated
vendored
Normal file
@ -0,0 +1,458 @@
|
|||||||
|
package sqlx
|
||||||
|
|
||||||
|
// Named Query Support
|
||||||
|
//
|
||||||
|
// * BindMap - bind query bindvars to map/struct args
|
||||||
|
// * NamedExec, NamedQuery - named query w/ struct or map
|
||||||
|
// * NamedStmt - a pre-compiled named query which is a prepared statement
|
||||||
|
//
|
||||||
|
// Internal Interfaces:
|
||||||
|
//
|
||||||
|
// * compileNamedQuery - rebind a named query, returning a query and list of names
|
||||||
|
// * bindArgs, bindMapArgs, bindAnyArgs - given a list of names, return an arglist
|
||||||
|
//
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"database/sql"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"reflect"
|
||||||
|
"regexp"
|
||||||
|
"strconv"
|
||||||
|
"unicode"
|
||||||
|
|
||||||
|
"github.com/jmoiron/sqlx/reflectx"
|
||||||
|
)
|
||||||
|
|
||||||
|
// NamedStmt is a prepared statement that executes named queries. Prepare it
|
||||||
|
// how you would execute a NamedQuery, but pass in a struct or map when executing.
|
||||||
|
type NamedStmt struct {
|
||||||
|
Params []string
|
||||||
|
QueryString string
|
||||||
|
Stmt *Stmt
|
||||||
|
}
|
||||||
|
|
||||||
|
// Close closes the named statement.
|
||||||
|
func (n *NamedStmt) Close() error {
|
||||||
|
return n.Stmt.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exec executes a named statement using the struct passed.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) Exec(arg interface{}) (sql.Result, error) {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return *new(sql.Result), err
|
||||||
|
}
|
||||||
|
return n.Stmt.Exec(args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Query executes a named statement using the struct argument, returning rows.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) Query(arg interface{}) (*sql.Rows, error) {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return n.Stmt.Query(args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRow executes a named statement against the database. Because sqlx cannot
|
||||||
|
// create a *sql.Row with an error condition pre-set for binding errors, sqlx
|
||||||
|
// returns a *sqlx.Row instead.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryRow(arg interface{}) *Row {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return &Row{err: err}
|
||||||
|
}
|
||||||
|
return n.Stmt.QueryRowx(args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExec execs a NamedStmt, panicing on error
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) MustExec(arg interface{}) sql.Result {
|
||||||
|
res, err := n.Exec(arg)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
|
// Queryx using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) Queryx(arg interface{}) (*Rows, error) {
|
||||||
|
r, err := n.Query(arg)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, Mapper: n.Stmt.Mapper, unsafe: isUnsafe(n)}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowx this NamedStmt. Because of limitations with QueryRow, this is
|
||||||
|
// an alias for QueryRow.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryRowx(arg interface{}) *Row {
|
||||||
|
return n.QueryRow(arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Select using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) Select(dest interface{}, arg interface{}) error {
|
||||||
|
rows, err := n.Queryx(arg)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// if something happens here, we want to make sure the rows are Closed
|
||||||
|
defer rows.Close()
|
||||||
|
return scanAll(rows, dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) Get(dest interface{}, arg interface{}) error {
|
||||||
|
r := n.QueryRowx(arg)
|
||||||
|
return r.scanAny(dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unsafe creates an unsafe version of the NamedStmt
|
||||||
|
func (n *NamedStmt) Unsafe() *NamedStmt {
|
||||||
|
r := &NamedStmt{Params: n.Params, Stmt: n.Stmt, QueryString: n.QueryString}
|
||||||
|
r.Stmt.unsafe = true
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
|
// A union interface of preparer and binder, required to be able to prepare
|
||||||
|
// named statements (as the bindtype must be determined).
|
||||||
|
type namedPreparer interface {
|
||||||
|
Preparer
|
||||||
|
binder
|
||||||
|
}
|
||||||
|
|
||||||
|
func prepareNamed(p namedPreparer, query string) (*NamedStmt, error) {
|
||||||
|
bindType := BindType(p.DriverName())
|
||||||
|
q, args, err := compileNamedQuery([]byte(query), bindType)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
stmt, err := Preparex(p, q)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &NamedStmt{
|
||||||
|
QueryString: q,
|
||||||
|
Params: args,
|
||||||
|
Stmt: stmt,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// convertMapStringInterface attempts to convert v to map[string]interface{}.
|
||||||
|
// Unlike v.(map[string]interface{}), this function works on named types that
|
||||||
|
// are convertible to map[string]interface{} as well.
|
||||||
|
func convertMapStringInterface(v interface{}) (map[string]interface{}, bool) {
|
||||||
|
var m map[string]interface{}
|
||||||
|
mtype := reflect.TypeOf(m)
|
||||||
|
t := reflect.TypeOf(v)
|
||||||
|
if !t.ConvertibleTo(mtype) {
|
||||||
|
return nil, false
|
||||||
|
}
|
||||||
|
return reflect.ValueOf(v).Convert(mtype).Interface().(map[string]interface{}), true
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func bindAnyArgs(names []string, arg interface{}, m *reflectx.Mapper) ([]interface{}, error) {
|
||||||
|
if maparg, ok := convertMapStringInterface(arg); ok {
|
||||||
|
return bindMapArgs(names, maparg)
|
||||||
|
}
|
||||||
|
return bindArgs(names, arg, m)
|
||||||
|
}
|
||||||
|
|
||||||
|
// private interface to generate a list of interfaces from a given struct
|
||||||
|
// type, given a list of names to pull out of the struct. Used by public
|
||||||
|
// BindStruct interface.
|
||||||
|
func bindArgs(names []string, arg interface{}, m *reflectx.Mapper) ([]interface{}, error) {
|
||||||
|
arglist := make([]interface{}, 0, len(names))
|
||||||
|
|
||||||
|
// grab the indirected value of arg
|
||||||
|
v := reflect.ValueOf(arg)
|
||||||
|
for v = reflect.ValueOf(arg); v.Kind() == reflect.Ptr; {
|
||||||
|
v = v.Elem()
|
||||||
|
}
|
||||||
|
|
||||||
|
err := m.TraversalsByNameFunc(v.Type(), names, func(i int, t []int) error {
|
||||||
|
if len(t) == 0 {
|
||||||
|
return fmt.Errorf("could not find name %s in %#v", names[i], arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
val := reflectx.FieldByIndexesReadOnly(v, t)
|
||||||
|
arglist = append(arglist, val.Interface())
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
|
return arglist, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// like bindArgs, but for maps.
|
||||||
|
func bindMapArgs(names []string, arg map[string]interface{}) ([]interface{}, error) {
|
||||||
|
arglist := make([]interface{}, 0, len(names))
|
||||||
|
|
||||||
|
for _, name := range names {
|
||||||
|
val, ok := arg[name]
|
||||||
|
if !ok {
|
||||||
|
return arglist, fmt.Errorf("could not find name %s in %#v", name, arg)
|
||||||
|
}
|
||||||
|
arglist = append(arglist, val)
|
||||||
|
}
|
||||||
|
return arglist, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// bindStruct binds a named parameter query with fields from a struct argument.
|
||||||
|
// The rules for binding field names to parameter names follow the same
|
||||||
|
// conventions as for StructScan, including obeying the `db` struct tags.
|
||||||
|
func bindStruct(bindType int, query string, arg interface{}, m *reflectx.Mapper) (string, []interface{}, error) {
|
||||||
|
bound, names, err := compileNamedQuery([]byte(query), bindType)
|
||||||
|
if err != nil {
|
||||||
|
return "", []interface{}{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
arglist, err := bindAnyArgs(names, arg, m)
|
||||||
|
if err != nil {
|
||||||
|
return "", []interface{}{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return bound, arglist, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var valuesReg = regexp.MustCompile(`\)\s*(?i)VALUES\s*\(`)
|
||||||
|
|
||||||
|
func findMatchingClosingBracketIndex(s string) int {
|
||||||
|
count := 0
|
||||||
|
for i, ch := range s {
|
||||||
|
if ch == '(' {
|
||||||
|
count++
|
||||||
|
}
|
||||||
|
if ch == ')' {
|
||||||
|
count--
|
||||||
|
if count == 0 {
|
||||||
|
return i
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
func fixBound(bound string, loop int) string {
|
||||||
|
loc := valuesReg.FindStringIndex(bound)
|
||||||
|
// defensive guard when "VALUES (...)" not found
|
||||||
|
if len(loc) < 2 {
|
||||||
|
return bound
|
||||||
|
}
|
||||||
|
|
||||||
|
openingBracketIndex := loc[1] - 1
|
||||||
|
index := findMatchingClosingBracketIndex(bound[openingBracketIndex:])
|
||||||
|
// defensive guard. must have closing bracket
|
||||||
|
if index == 0 {
|
||||||
|
return bound
|
||||||
|
}
|
||||||
|
closingBracketIndex := openingBracketIndex + index + 1
|
||||||
|
|
||||||
|
var buffer bytes.Buffer
|
||||||
|
|
||||||
|
buffer.WriteString(bound[0:closingBracketIndex])
|
||||||
|
for i := 0; i < loop-1; i++ {
|
||||||
|
buffer.WriteString(",")
|
||||||
|
buffer.WriteString(bound[openingBracketIndex:closingBracketIndex])
|
||||||
|
}
|
||||||
|
buffer.WriteString(bound[closingBracketIndex:])
|
||||||
|
return buffer.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
// bindArray binds a named parameter query with fields from an array or slice of
|
||||||
|
// structs argument.
|
||||||
|
func bindArray(bindType int, query string, arg interface{}, m *reflectx.Mapper) (string, []interface{}, error) {
|
||||||
|
// do the initial binding with QUESTION; if bindType is not question,
|
||||||
|
// we can rebind it at the end.
|
||||||
|
bound, names, err := compileNamedQuery([]byte(query), QUESTION)
|
||||||
|
if err != nil {
|
||||||
|
return "", []interface{}{}, err
|
||||||
|
}
|
||||||
|
arrayValue := reflect.ValueOf(arg)
|
||||||
|
arrayLen := arrayValue.Len()
|
||||||
|
if arrayLen == 0 {
|
||||||
|
return "", []interface{}{}, fmt.Errorf("length of array is 0: %#v", arg)
|
||||||
|
}
|
||||||
|
var arglist = make([]interface{}, 0, len(names)*arrayLen)
|
||||||
|
for i := 0; i < arrayLen; i++ {
|
||||||
|
elemArglist, err := bindAnyArgs(names, arrayValue.Index(i).Interface(), m)
|
||||||
|
if err != nil {
|
||||||
|
return "", []interface{}{}, err
|
||||||
|
}
|
||||||
|
arglist = append(arglist, elemArglist...)
|
||||||
|
}
|
||||||
|
if arrayLen > 1 {
|
||||||
|
bound = fixBound(bound, arrayLen)
|
||||||
|
}
|
||||||
|
// adjust binding type if we weren't on question
|
||||||
|
if bindType != QUESTION {
|
||||||
|
bound = Rebind(bindType, bound)
|
||||||
|
}
|
||||||
|
return bound, arglist, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// bindMap binds a named parameter query with a map of arguments.
|
||||||
|
func bindMap(bindType int, query string, args map[string]interface{}) (string, []interface{}, error) {
|
||||||
|
bound, names, err := compileNamedQuery([]byte(query), bindType)
|
||||||
|
if err != nil {
|
||||||
|
return "", []interface{}{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
arglist, err := bindMapArgs(names, args)
|
||||||
|
return bound, arglist, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// -- Compilation of Named Queries
|
||||||
|
|
||||||
|
// Allow digits and letters in bind params; additionally runes are
|
||||||
|
// checked against underscores, meaning that bind params can have be
|
||||||
|
// alphanumeric with underscores. Mind the difference between unicode
|
||||||
|
// digits and numbers, where '5' is a digit but '五' is not.
|
||||||
|
var allowedBindRunes = []*unicode.RangeTable{unicode.Letter, unicode.Digit}
|
||||||
|
|
||||||
|
// FIXME: this function isn't safe for unicode named params, as a failing test
|
||||||
|
// can testify. This is not a regression but a failure of the original code
|
||||||
|
// as well. It should be modified to range over runes in a string rather than
|
||||||
|
// bytes, even though this is less convenient and slower. Hopefully the
|
||||||
|
// addition of the prepared NamedStmt (which will only do this once) will make
|
||||||
|
// up for the slightly slower ad-hoc NamedExec/NamedQuery.
|
||||||
|
|
||||||
|
// compile a NamedQuery into an unbound query (using the '?' bindvar) and
|
||||||
|
// a list of names.
|
||||||
|
func compileNamedQuery(qs []byte, bindType int) (query string, names []string, err error) {
|
||||||
|
names = make([]string, 0, 10)
|
||||||
|
rebound := make([]byte, 0, len(qs))
|
||||||
|
|
||||||
|
inName := false
|
||||||
|
last := len(qs) - 1
|
||||||
|
currentVar := 1
|
||||||
|
name := make([]byte, 0, 10)
|
||||||
|
|
||||||
|
for i, b := range qs {
|
||||||
|
// a ':' while we're in a name is an error
|
||||||
|
if b == ':' {
|
||||||
|
// if this is the second ':' in a '::' escape sequence, append a ':'
|
||||||
|
if inName && i > 0 && qs[i-1] == ':' {
|
||||||
|
rebound = append(rebound, ':')
|
||||||
|
inName = false
|
||||||
|
continue
|
||||||
|
} else if inName {
|
||||||
|
err = errors.New("unexpected `:` while reading named param at " + strconv.Itoa(i))
|
||||||
|
return query, names, err
|
||||||
|
}
|
||||||
|
inName = true
|
||||||
|
name = []byte{}
|
||||||
|
} else if inName && i > 0 && b == '=' && len(name) == 0 {
|
||||||
|
rebound = append(rebound, ':', '=')
|
||||||
|
inName = false
|
||||||
|
continue
|
||||||
|
// if we're in a name, and this is an allowed character, continue
|
||||||
|
} else if inName && (unicode.IsOneOf(allowedBindRunes, rune(b)) || b == '_' || b == '.') && i != last {
|
||||||
|
// append the byte to the name if we are in a name and not on the last byte
|
||||||
|
name = append(name, b)
|
||||||
|
// if we're in a name and it's not an allowed character, the name is done
|
||||||
|
} else if inName {
|
||||||
|
inName = false
|
||||||
|
// if this is the final byte of the string and it is part of the name, then
|
||||||
|
// make sure to add it to the name
|
||||||
|
if i == last && unicode.IsOneOf(allowedBindRunes, rune(b)) {
|
||||||
|
name = append(name, b)
|
||||||
|
}
|
||||||
|
// add the string representation to the names list
|
||||||
|
names = append(names, string(name))
|
||||||
|
// add a proper bindvar for the bindType
|
||||||
|
switch bindType {
|
||||||
|
// oracle only supports named type bind vars even for positional
|
||||||
|
case NAMED:
|
||||||
|
rebound = append(rebound, ':')
|
||||||
|
rebound = append(rebound, name...)
|
||||||
|
case QUESTION, UNKNOWN:
|
||||||
|
rebound = append(rebound, '?')
|
||||||
|
case DOLLAR:
|
||||||
|
rebound = append(rebound, '$')
|
||||||
|
for _, b := range strconv.Itoa(currentVar) {
|
||||||
|
rebound = append(rebound, byte(b))
|
||||||
|
}
|
||||||
|
currentVar++
|
||||||
|
case AT:
|
||||||
|
rebound = append(rebound, '@', 'p')
|
||||||
|
for _, b := range strconv.Itoa(currentVar) {
|
||||||
|
rebound = append(rebound, byte(b))
|
||||||
|
}
|
||||||
|
currentVar++
|
||||||
|
}
|
||||||
|
// add this byte to string unless it was not part of the name
|
||||||
|
if i != last {
|
||||||
|
rebound = append(rebound, b)
|
||||||
|
} else if !unicode.IsOneOf(allowedBindRunes, rune(b)) {
|
||||||
|
rebound = append(rebound, b)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// this is a normal byte and should just go onto the rebound query
|
||||||
|
rebound = append(rebound, b)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return string(rebound), names, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// BindNamed binds a struct or a map to a query with named parameters.
|
||||||
|
// DEPRECATED: use sqlx.Named` instead of this, it may be removed in future.
|
||||||
|
func BindNamed(bindType int, query string, arg interface{}) (string, []interface{}, error) {
|
||||||
|
return bindNamedMapper(bindType, query, arg, mapper())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Named takes a query using named parameters and an argument and
|
||||||
|
// returns a new query with a list of args that can be executed by
|
||||||
|
// a database. The return value uses the `?` bindvar.
|
||||||
|
func Named(query string, arg interface{}) (string, []interface{}, error) {
|
||||||
|
return bindNamedMapper(QUESTION, query, arg, mapper())
|
||||||
|
}
|
||||||
|
|
||||||
|
func bindNamedMapper(bindType int, query string, arg interface{}, m *reflectx.Mapper) (string, []interface{}, error) {
|
||||||
|
t := reflect.TypeOf(arg)
|
||||||
|
k := t.Kind()
|
||||||
|
switch {
|
||||||
|
case k == reflect.Map && t.Key().Kind() == reflect.String:
|
||||||
|
m, ok := convertMapStringInterface(arg)
|
||||||
|
if !ok {
|
||||||
|
return "", nil, fmt.Errorf("sqlx.bindNamedMapper: unsupported map type: %T", arg)
|
||||||
|
}
|
||||||
|
return bindMap(bindType, query, m)
|
||||||
|
case k == reflect.Array || k == reflect.Slice:
|
||||||
|
return bindArray(bindType, query, arg, m)
|
||||||
|
default:
|
||||||
|
return bindStruct(bindType, query, arg, m)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedQuery binds a named query and then runs Query on the result using the
|
||||||
|
// provided Ext (sqlx.Tx, sqlx.Db). It works with both structs and with
|
||||||
|
// map[string]interface{} types.
|
||||||
|
func NamedQuery(e Ext, query string, arg interface{}) (*Rows, error) {
|
||||||
|
q, args, err := bindNamedMapper(BindType(e.DriverName()), query, arg, mapperFor(e))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return e.Queryx(q, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedExec uses BindStruct to get a query executable by the driver and
|
||||||
|
// then runs Exec on the result. Returns an error from the binding
|
||||||
|
// or the query execution itself.
|
||||||
|
func NamedExec(e Ext, query string, arg interface{}) (sql.Result, error) {
|
||||||
|
q, args, err := bindNamedMapper(BindType(e.DriverName()), query, arg, mapperFor(e))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return e.Exec(q, args...)
|
||||||
|
}
|
132
vendor/github.com/jmoiron/sqlx/named_context.go
generated
vendored
Normal file
132
vendor/github.com/jmoiron/sqlx/named_context.go
generated
vendored
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
// +build go1.8
|
||||||
|
|
||||||
|
package sqlx
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"database/sql"
|
||||||
|
)
|
||||||
|
|
||||||
|
// A union interface of contextPreparer and binder, required to be able to
|
||||||
|
// prepare named statements with context (as the bindtype must be determined).
|
||||||
|
type namedPreparerContext interface {
|
||||||
|
PreparerContext
|
||||||
|
binder
|
||||||
|
}
|
||||||
|
|
||||||
|
func prepareNamedContext(ctx context.Context, p namedPreparerContext, query string) (*NamedStmt, error) {
|
||||||
|
bindType := BindType(p.DriverName())
|
||||||
|
q, args, err := compileNamedQuery([]byte(query), bindType)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
stmt, err := PreparexContext(ctx, p, q)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &NamedStmt{
|
||||||
|
QueryString: q,
|
||||||
|
Params: args,
|
||||||
|
Stmt: stmt,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ExecContext executes a named statement using the struct passed.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) ExecContext(ctx context.Context, arg interface{}) (sql.Result, error) {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return *new(sql.Result), err
|
||||||
|
}
|
||||||
|
return n.Stmt.ExecContext(ctx, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryContext executes a named statement using the struct argument, returning rows.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryContext(ctx context.Context, arg interface{}) (*sql.Rows, error) {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return n.Stmt.QueryContext(ctx, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowContext executes a named statement against the database. Because sqlx cannot
|
||||||
|
// create a *sql.Row with an error condition pre-set for binding errors, sqlx
|
||||||
|
// returns a *sqlx.Row instead.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryRowContext(ctx context.Context, arg interface{}) *Row {
|
||||||
|
args, err := bindAnyArgs(n.Params, arg, n.Stmt.Mapper)
|
||||||
|
if err != nil {
|
||||||
|
return &Row{err: err}
|
||||||
|
}
|
||||||
|
return n.Stmt.QueryRowxContext(ctx, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExecContext execs a NamedStmt, panicing on error
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) MustExecContext(ctx context.Context, arg interface{}) sql.Result {
|
||||||
|
res, err := n.ExecContext(ctx, arg)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryxContext using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryxContext(ctx context.Context, arg interface{}) (*Rows, error) {
|
||||||
|
r, err := n.QueryContext(ctx, arg)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, Mapper: n.Stmt.Mapper, unsafe: isUnsafe(n)}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowxContext this NamedStmt. Because of limitations with QueryRow, this is
|
||||||
|
// an alias for QueryRow.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) QueryRowxContext(ctx context.Context, arg interface{}) *Row {
|
||||||
|
return n.QueryRowContext(ctx, arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) SelectContext(ctx context.Context, dest interface{}, arg interface{}) error {
|
||||||
|
rows, err := n.QueryxContext(ctx, arg)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// if something happens here, we want to make sure the rows are Closed
|
||||||
|
defer rows.Close()
|
||||||
|
return scanAll(rows, dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext using this NamedStmt
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (n *NamedStmt) GetContext(ctx context.Context, dest interface{}, arg interface{}) error {
|
||||||
|
r := n.QueryRowxContext(ctx, arg)
|
||||||
|
return r.scanAny(dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedQueryContext binds a named query and then runs Query on the result using the
|
||||||
|
// provided Ext (sqlx.Tx, sqlx.Db). It works with both structs and with
|
||||||
|
// map[string]interface{} types.
|
||||||
|
func NamedQueryContext(ctx context.Context, e ExtContext, query string, arg interface{}) (*Rows, error) {
|
||||||
|
q, args, err := bindNamedMapper(BindType(e.DriverName()), query, arg, mapperFor(e))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return e.QueryxContext(ctx, q, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedExecContext uses BindStruct to get a query executable by the driver and
|
||||||
|
// then runs Exec on the result. Returns an error from the binding
|
||||||
|
// or the query execution itself.
|
||||||
|
func NamedExecContext(ctx context.Context, e ExtContext, query string, arg interface{}) (sql.Result, error) {
|
||||||
|
q, args, err := bindNamedMapper(BindType(e.DriverName()), query, arg, mapperFor(e))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return e.ExecContext(ctx, q, args...)
|
||||||
|
}
|
17
vendor/github.com/jmoiron/sqlx/reflectx/README.md
generated
vendored
Normal file
17
vendor/github.com/jmoiron/sqlx/reflectx/README.md
generated
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
# reflectx
|
||||||
|
|
||||||
|
The sqlx package has special reflect needs. In particular, it needs to:
|
||||||
|
|
||||||
|
* be able to map a name to a field
|
||||||
|
* understand embedded structs
|
||||||
|
* understand mapping names to fields by a particular tag
|
||||||
|
* user specified name -> field mapping functions
|
||||||
|
|
||||||
|
These behaviors mimic the behaviors by the standard library marshallers and also the
|
||||||
|
behavior of standard Go accessors.
|
||||||
|
|
||||||
|
The first two are amply taken care of by `Reflect.Value.FieldByName`, and the third is
|
||||||
|
addressed by `Reflect.Value.FieldByNameFunc`, but these don't quite understand struct
|
||||||
|
tags in the ways that are vital to most marshallers, and they are slow.
|
||||||
|
|
||||||
|
This reflectx package extends reflect to achieve these goals.
|
444
vendor/github.com/jmoiron/sqlx/reflectx/reflect.go
generated
vendored
Normal file
444
vendor/github.com/jmoiron/sqlx/reflectx/reflect.go
generated
vendored
Normal file
@ -0,0 +1,444 @@
|
|||||||
|
// Package reflectx implements extensions to the standard reflect lib suitable
|
||||||
|
// for implementing marshalling and unmarshalling packages. The main Mapper type
|
||||||
|
// allows for Go-compatible named attribute access, including accessing embedded
|
||||||
|
// struct attributes and the ability to use functions and struct tags to
|
||||||
|
// customize field names.
|
||||||
|
//
|
||||||
|
package reflectx
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"runtime"
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
// A FieldInfo is metadata for a struct field.
|
||||||
|
type FieldInfo struct {
|
||||||
|
Index []int
|
||||||
|
Path string
|
||||||
|
Field reflect.StructField
|
||||||
|
Zero reflect.Value
|
||||||
|
Name string
|
||||||
|
Options map[string]string
|
||||||
|
Embedded bool
|
||||||
|
Children []*FieldInfo
|
||||||
|
Parent *FieldInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// A StructMap is an index of field metadata for a struct.
|
||||||
|
type StructMap struct {
|
||||||
|
Tree *FieldInfo
|
||||||
|
Index []*FieldInfo
|
||||||
|
Paths map[string]*FieldInfo
|
||||||
|
Names map[string]*FieldInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetByPath returns a *FieldInfo for a given string path.
|
||||||
|
func (f StructMap) GetByPath(path string) *FieldInfo {
|
||||||
|
return f.Paths[path]
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetByTraversal returns a *FieldInfo for a given integer path. It is
|
||||||
|
// analogous to reflect.FieldByIndex, but using the cached traversal
|
||||||
|
// rather than re-executing the reflect machinery each time.
|
||||||
|
func (f StructMap) GetByTraversal(index []int) *FieldInfo {
|
||||||
|
if len(index) == 0 {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
tree := f.Tree
|
||||||
|
for _, i := range index {
|
||||||
|
if i >= len(tree.Children) || tree.Children[i] == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
tree = tree.Children[i]
|
||||||
|
}
|
||||||
|
return tree
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mapper is a general purpose mapper of names to struct fields. A Mapper
|
||||||
|
// behaves like most marshallers in the standard library, obeying a field tag
|
||||||
|
// for name mapping but also providing a basic transform function.
|
||||||
|
type Mapper struct {
|
||||||
|
cache map[reflect.Type]*StructMap
|
||||||
|
tagName string
|
||||||
|
tagMapFunc func(string) string
|
||||||
|
mapFunc func(string) string
|
||||||
|
mutex sync.Mutex
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewMapper returns a new mapper using the tagName as its struct field tag.
|
||||||
|
// If tagName is the empty string, it is ignored.
|
||||||
|
func NewMapper(tagName string) *Mapper {
|
||||||
|
return &Mapper{
|
||||||
|
cache: make(map[reflect.Type]*StructMap),
|
||||||
|
tagName: tagName,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewMapperTagFunc returns a new mapper which contains a mapper for field names
|
||||||
|
// AND a mapper for tag values. This is useful for tags like json which can
|
||||||
|
// have values like "name,omitempty".
|
||||||
|
func NewMapperTagFunc(tagName string, mapFunc, tagMapFunc func(string) string) *Mapper {
|
||||||
|
return &Mapper{
|
||||||
|
cache: make(map[reflect.Type]*StructMap),
|
||||||
|
tagName: tagName,
|
||||||
|
mapFunc: mapFunc,
|
||||||
|
tagMapFunc: tagMapFunc,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewMapperFunc returns a new mapper which optionally obeys a field tag and
|
||||||
|
// a struct field name mapper func given by f. Tags will take precedence, but
|
||||||
|
// for any other field, the mapped name will be f(field.Name)
|
||||||
|
func NewMapperFunc(tagName string, f func(string) string) *Mapper {
|
||||||
|
return &Mapper{
|
||||||
|
cache: make(map[reflect.Type]*StructMap),
|
||||||
|
tagName: tagName,
|
||||||
|
mapFunc: f,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TypeMap returns a mapping of field strings to int slices representing
|
||||||
|
// the traversal down the struct to reach the field.
|
||||||
|
func (m *Mapper) TypeMap(t reflect.Type) *StructMap {
|
||||||
|
m.mutex.Lock()
|
||||||
|
mapping, ok := m.cache[t]
|
||||||
|
if !ok {
|
||||||
|
mapping = getMapping(t, m.tagName, m.mapFunc, m.tagMapFunc)
|
||||||
|
m.cache[t] = mapping
|
||||||
|
}
|
||||||
|
m.mutex.Unlock()
|
||||||
|
return mapping
|
||||||
|
}
|
||||||
|
|
||||||
|
// FieldMap returns the mapper's mapping of field names to reflect values. Panics
|
||||||
|
// if v's Kind is not Struct, or v is not Indirectable to a struct kind.
|
||||||
|
func (m *Mapper) FieldMap(v reflect.Value) map[string]reflect.Value {
|
||||||
|
v = reflect.Indirect(v)
|
||||||
|
mustBe(v, reflect.Struct)
|
||||||
|
|
||||||
|
r := map[string]reflect.Value{}
|
||||||
|
tm := m.TypeMap(v.Type())
|
||||||
|
for tagName, fi := range tm.Names {
|
||||||
|
r[tagName] = FieldByIndexes(v, fi.Index)
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
|
// FieldByName returns a field by its mapped name as a reflect.Value.
|
||||||
|
// Panics if v's Kind is not Struct or v is not Indirectable to a struct Kind.
|
||||||
|
// Returns zero Value if the name is not found.
|
||||||
|
func (m *Mapper) FieldByName(v reflect.Value, name string) reflect.Value {
|
||||||
|
v = reflect.Indirect(v)
|
||||||
|
mustBe(v, reflect.Struct)
|
||||||
|
|
||||||
|
tm := m.TypeMap(v.Type())
|
||||||
|
fi, ok := tm.Names[name]
|
||||||
|
if !ok {
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
return FieldByIndexes(v, fi.Index)
|
||||||
|
}
|
||||||
|
|
||||||
|
// FieldsByName returns a slice of values corresponding to the slice of names
|
||||||
|
// for the value. Panics if v's Kind is not Struct or v is not Indirectable
|
||||||
|
// to a struct Kind. Returns zero Value for each name not found.
|
||||||
|
func (m *Mapper) FieldsByName(v reflect.Value, names []string) []reflect.Value {
|
||||||
|
v = reflect.Indirect(v)
|
||||||
|
mustBe(v, reflect.Struct)
|
||||||
|
|
||||||
|
tm := m.TypeMap(v.Type())
|
||||||
|
vals := make([]reflect.Value, 0, len(names))
|
||||||
|
for _, name := range names {
|
||||||
|
fi, ok := tm.Names[name]
|
||||||
|
if !ok {
|
||||||
|
vals = append(vals, *new(reflect.Value))
|
||||||
|
} else {
|
||||||
|
vals = append(vals, FieldByIndexes(v, fi.Index))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return vals
|
||||||
|
}
|
||||||
|
|
||||||
|
// TraversalsByName returns a slice of int slices which represent the struct
|
||||||
|
// traversals for each mapped name. Panics if t is not a struct or Indirectable
|
||||||
|
// to a struct. Returns empty int slice for each name not found.
|
||||||
|
func (m *Mapper) TraversalsByName(t reflect.Type, names []string) [][]int {
|
||||||
|
r := make([][]int, 0, len(names))
|
||||||
|
m.TraversalsByNameFunc(t, names, func(_ int, i []int) error {
|
||||||
|
if i == nil {
|
||||||
|
r = append(r, []int{})
|
||||||
|
} else {
|
||||||
|
r = append(r, i)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
|
// TraversalsByNameFunc traverses the mapped names and calls fn with the index of
|
||||||
|
// each name and the struct traversal represented by that name. Panics if t is not
|
||||||
|
// a struct or Indirectable to a struct. Returns the first error returned by fn or nil.
|
||||||
|
func (m *Mapper) TraversalsByNameFunc(t reflect.Type, names []string, fn func(int, []int) error) error {
|
||||||
|
t = Deref(t)
|
||||||
|
mustBe(t, reflect.Struct)
|
||||||
|
tm := m.TypeMap(t)
|
||||||
|
for i, name := range names {
|
||||||
|
fi, ok := tm.Names[name]
|
||||||
|
if !ok {
|
||||||
|
if err := fn(i, nil); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if err := fn(i, fi.Index); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// FieldByIndexes returns a value for the field given by the struct traversal
|
||||||
|
// for the given value.
|
||||||
|
func FieldByIndexes(v reflect.Value, indexes []int) reflect.Value {
|
||||||
|
for _, i := range indexes {
|
||||||
|
v = reflect.Indirect(v).Field(i)
|
||||||
|
// if this is a pointer and it's nil, allocate a new value and set it
|
||||||
|
if v.Kind() == reflect.Ptr && v.IsNil() {
|
||||||
|
alloc := reflect.New(Deref(v.Type()))
|
||||||
|
v.Set(alloc)
|
||||||
|
}
|
||||||
|
if v.Kind() == reflect.Map && v.IsNil() {
|
||||||
|
v.Set(reflect.MakeMap(v.Type()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
// FieldByIndexesReadOnly returns a value for a particular struct traversal,
|
||||||
|
// but is not concerned with allocating nil pointers because the value is
|
||||||
|
// going to be used for reading and not setting.
|
||||||
|
func FieldByIndexesReadOnly(v reflect.Value, indexes []int) reflect.Value {
|
||||||
|
for _, i := range indexes {
|
||||||
|
v = reflect.Indirect(v).Field(i)
|
||||||
|
}
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deref is Indirect for reflect.Types
|
||||||
|
func Deref(t reflect.Type) reflect.Type {
|
||||||
|
if t.Kind() == reflect.Ptr {
|
||||||
|
t = t.Elem()
|
||||||
|
}
|
||||||
|
return t
|
||||||
|
}
|
||||||
|
|
||||||
|
// -- helpers & utilities --
|
||||||
|
|
||||||
|
type kinder interface {
|
||||||
|
Kind() reflect.Kind
|
||||||
|
}
|
||||||
|
|
||||||
|
// mustBe checks a value against a kind, panicing with a reflect.ValueError
|
||||||
|
// if the kind isn't that which is required.
|
||||||
|
func mustBe(v kinder, expected reflect.Kind) {
|
||||||
|
if k := v.Kind(); k != expected {
|
||||||
|
panic(&reflect.ValueError{Method: methodName(), Kind: k})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// methodName returns the caller of the function calling methodName
|
||||||
|
func methodName() string {
|
||||||
|
pc, _, _, _ := runtime.Caller(2)
|
||||||
|
f := runtime.FuncForPC(pc)
|
||||||
|
if f == nil {
|
||||||
|
return "unknown method"
|
||||||
|
}
|
||||||
|
return f.Name()
|
||||||
|
}
|
||||||
|
|
||||||
|
type typeQueue struct {
|
||||||
|
t reflect.Type
|
||||||
|
fi *FieldInfo
|
||||||
|
pp string // Parent path
|
||||||
|
}
|
||||||
|
|
||||||
|
// A copying append that creates a new slice each time.
|
||||||
|
func apnd(is []int, i int) []int {
|
||||||
|
x := make([]int, len(is)+1)
|
||||||
|
copy(x, is)
|
||||||
|
x[len(x)-1] = i
|
||||||
|
return x
|
||||||
|
}
|
||||||
|
|
||||||
|
type mapf func(string) string
|
||||||
|
|
||||||
|
// parseName parses the tag and the target name for the given field using
|
||||||
|
// the tagName (eg 'json' for `json:"foo"` tags), mapFunc for mapping the
|
||||||
|
// field's name to a target name, and tagMapFunc for mapping the tag to
|
||||||
|
// a target name.
|
||||||
|
func parseName(field reflect.StructField, tagName string, mapFunc, tagMapFunc mapf) (tag, fieldName string) {
|
||||||
|
// first, set the fieldName to the field's name
|
||||||
|
fieldName = field.Name
|
||||||
|
// if a mapFunc is set, use that to override the fieldName
|
||||||
|
if mapFunc != nil {
|
||||||
|
fieldName = mapFunc(fieldName)
|
||||||
|
}
|
||||||
|
|
||||||
|
// if there's no tag to look for, return the field name
|
||||||
|
if tagName == "" {
|
||||||
|
return "", fieldName
|
||||||
|
}
|
||||||
|
|
||||||
|
// if this tag is not set using the normal convention in the tag,
|
||||||
|
// then return the fieldname.. this check is done because according
|
||||||
|
// to the reflect documentation:
|
||||||
|
// If the tag does not have the conventional format,
|
||||||
|
// the value returned by Get is unspecified.
|
||||||
|
// which doesn't sound great.
|
||||||
|
if !strings.Contains(string(field.Tag), tagName+":") {
|
||||||
|
return "", fieldName
|
||||||
|
}
|
||||||
|
|
||||||
|
// at this point we're fairly sure that we have a tag, so lets pull it out
|
||||||
|
tag = field.Tag.Get(tagName)
|
||||||
|
|
||||||
|
// if we have a mapper function, call it on the whole tag
|
||||||
|
// XXX: this is a change from the old version, which pulled out the name
|
||||||
|
// before the tagMapFunc could be run, but I think this is the right way
|
||||||
|
if tagMapFunc != nil {
|
||||||
|
tag = tagMapFunc(tag)
|
||||||
|
}
|
||||||
|
|
||||||
|
// finally, split the options from the name
|
||||||
|
parts := strings.Split(tag, ",")
|
||||||
|
fieldName = parts[0]
|
||||||
|
|
||||||
|
return tag, fieldName
|
||||||
|
}
|
||||||
|
|
||||||
|
// parseOptions parses options out of a tag string, skipping the name
|
||||||
|
func parseOptions(tag string) map[string]string {
|
||||||
|
parts := strings.Split(tag, ",")
|
||||||
|
options := make(map[string]string, len(parts))
|
||||||
|
if len(parts) > 1 {
|
||||||
|
for _, opt := range parts[1:] {
|
||||||
|
// short circuit potentially expensive split op
|
||||||
|
if strings.Contains(opt, "=") {
|
||||||
|
kv := strings.Split(opt, "=")
|
||||||
|
options[kv[0]] = kv[1]
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
options[opt] = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return options
|
||||||
|
}
|
||||||
|
|
||||||
|
// getMapping returns a mapping for the t type, using the tagName, mapFunc and
|
||||||
|
// tagMapFunc to determine the canonical names of fields.
|
||||||
|
func getMapping(t reflect.Type, tagName string, mapFunc, tagMapFunc mapf) *StructMap {
|
||||||
|
m := []*FieldInfo{}
|
||||||
|
|
||||||
|
root := &FieldInfo{}
|
||||||
|
queue := []typeQueue{}
|
||||||
|
queue = append(queue, typeQueue{Deref(t), root, ""})
|
||||||
|
|
||||||
|
QueueLoop:
|
||||||
|
for len(queue) != 0 {
|
||||||
|
// pop the first item off of the queue
|
||||||
|
tq := queue[0]
|
||||||
|
queue = queue[1:]
|
||||||
|
|
||||||
|
// ignore recursive field
|
||||||
|
for p := tq.fi.Parent; p != nil; p = p.Parent {
|
||||||
|
if tq.fi.Field.Type == p.Field.Type {
|
||||||
|
continue QueueLoop
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
nChildren := 0
|
||||||
|
if tq.t.Kind() == reflect.Struct {
|
||||||
|
nChildren = tq.t.NumField()
|
||||||
|
}
|
||||||
|
tq.fi.Children = make([]*FieldInfo, nChildren)
|
||||||
|
|
||||||
|
// iterate through all of its fields
|
||||||
|
for fieldPos := 0; fieldPos < nChildren; fieldPos++ {
|
||||||
|
|
||||||
|
f := tq.t.Field(fieldPos)
|
||||||
|
|
||||||
|
// parse the tag and the target name using the mapping options for this field
|
||||||
|
tag, name := parseName(f, tagName, mapFunc, tagMapFunc)
|
||||||
|
|
||||||
|
// if the name is "-", disabled via a tag, skip it
|
||||||
|
if name == "-" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
fi := FieldInfo{
|
||||||
|
Field: f,
|
||||||
|
Name: name,
|
||||||
|
Zero: reflect.New(f.Type).Elem(),
|
||||||
|
Options: parseOptions(tag),
|
||||||
|
}
|
||||||
|
|
||||||
|
// if the path is empty this path is just the name
|
||||||
|
if tq.pp == "" {
|
||||||
|
fi.Path = fi.Name
|
||||||
|
} else {
|
||||||
|
fi.Path = tq.pp + "." + fi.Name
|
||||||
|
}
|
||||||
|
|
||||||
|
// skip unexported fields
|
||||||
|
if len(f.PkgPath) != 0 && !f.Anonymous {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// bfs search of anonymous embedded structs
|
||||||
|
if f.Anonymous {
|
||||||
|
pp := tq.pp
|
||||||
|
if tag != "" {
|
||||||
|
pp = fi.Path
|
||||||
|
}
|
||||||
|
|
||||||
|
fi.Embedded = true
|
||||||
|
fi.Index = apnd(tq.fi.Index, fieldPos)
|
||||||
|
nChildren := 0
|
||||||
|
ft := Deref(f.Type)
|
||||||
|
if ft.Kind() == reflect.Struct {
|
||||||
|
nChildren = ft.NumField()
|
||||||
|
}
|
||||||
|
fi.Children = make([]*FieldInfo, nChildren)
|
||||||
|
queue = append(queue, typeQueue{Deref(f.Type), &fi, pp})
|
||||||
|
} else if fi.Zero.Kind() == reflect.Struct || (fi.Zero.Kind() == reflect.Ptr && fi.Zero.Type().Elem().Kind() == reflect.Struct) {
|
||||||
|
fi.Index = apnd(tq.fi.Index, fieldPos)
|
||||||
|
fi.Children = make([]*FieldInfo, Deref(f.Type).NumField())
|
||||||
|
queue = append(queue, typeQueue{Deref(f.Type), &fi, fi.Path})
|
||||||
|
}
|
||||||
|
|
||||||
|
fi.Index = apnd(tq.fi.Index, fieldPos)
|
||||||
|
fi.Parent = tq.fi
|
||||||
|
tq.fi.Children[fieldPos] = &fi
|
||||||
|
m = append(m, &fi)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
flds := &StructMap{Index: m, Tree: root, Paths: map[string]*FieldInfo{}, Names: map[string]*FieldInfo{}}
|
||||||
|
for _, fi := range flds.Index {
|
||||||
|
// check if nothing has already been pushed with the same path
|
||||||
|
// sometimes you can choose to override a type using embedded struct
|
||||||
|
fld, ok := flds.Paths[fi.Path]
|
||||||
|
if !ok || fld.Embedded {
|
||||||
|
flds.Paths[fi.Path] = fi
|
||||||
|
if fi.Name != "" && !fi.Embedded {
|
||||||
|
flds.Names[fi.Path] = fi
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return flds
|
||||||
|
}
|
1051
vendor/github.com/jmoiron/sqlx/sqlx.go
generated
vendored
Normal file
1051
vendor/github.com/jmoiron/sqlx/sqlx.go
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
414
vendor/github.com/jmoiron/sqlx/sqlx_context.go
generated
vendored
Normal file
414
vendor/github.com/jmoiron/sqlx/sqlx_context.go
generated
vendored
Normal file
@ -0,0 +1,414 @@
|
|||||||
|
// +build go1.8
|
||||||
|
|
||||||
|
package sqlx
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"database/sql"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"path/filepath"
|
||||||
|
"reflect"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ConnectContext to a database and verify with a ping.
|
||||||
|
func ConnectContext(ctx context.Context, driverName, dataSourceName string) (*DB, error) {
|
||||||
|
db, err := Open(driverName, dataSourceName)
|
||||||
|
if err != nil {
|
||||||
|
return db, err
|
||||||
|
}
|
||||||
|
err = db.PingContext(ctx)
|
||||||
|
return db, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryerContext is an interface used by GetContext and SelectContext
|
||||||
|
type QueryerContext interface {
|
||||||
|
QueryContext(ctx context.Context, query string, args ...interface{}) (*sql.Rows, error)
|
||||||
|
QueryxContext(ctx context.Context, query string, args ...interface{}) (*Rows, error)
|
||||||
|
QueryRowxContext(ctx context.Context, query string, args ...interface{}) *Row
|
||||||
|
}
|
||||||
|
|
||||||
|
// PreparerContext is an interface used by PreparexContext.
|
||||||
|
type PreparerContext interface {
|
||||||
|
PrepareContext(ctx context.Context, query string) (*sql.Stmt, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ExecerContext is an interface used by MustExecContext and LoadFileContext
|
||||||
|
type ExecerContext interface {
|
||||||
|
ExecContext(ctx context.Context, query string, args ...interface{}) (sql.Result, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ExtContext is a union interface which can bind, query, and exec, with Context
|
||||||
|
// used by NamedQueryContext and NamedExecContext.
|
||||||
|
type ExtContext interface {
|
||||||
|
binder
|
||||||
|
QueryerContext
|
||||||
|
ExecerContext
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext executes a query using the provided Queryer, and StructScans
|
||||||
|
// each row into dest, which must be a slice. If the slice elements are
|
||||||
|
// scannable, then the result set must have only one column. Otherwise,
|
||||||
|
// StructScan is used. The *sql.Rows are closed automatically.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func SelectContext(ctx context.Context, q QueryerContext, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
rows, err := q.QueryxContext(ctx, query, args...)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// if something happens here, we want to make sure the rows are Closed
|
||||||
|
defer rows.Close()
|
||||||
|
return scanAll(rows, dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// PreparexContext prepares a statement.
|
||||||
|
//
|
||||||
|
// The provided context is used for the preparation of the statement, not for
|
||||||
|
// the execution of the statement.
|
||||||
|
func PreparexContext(ctx context.Context, p PreparerContext, query string) (*Stmt, error) {
|
||||||
|
s, err := p.PrepareContext(ctx, query)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Stmt{Stmt: s, unsafe: isUnsafe(p), Mapper: mapperFor(p)}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext does a QueryRow using the provided Queryer, and scans the
|
||||||
|
// resulting row to dest. If dest is scannable, the result must only have one
|
||||||
|
// column. Otherwise, StructScan is used. Get will return sql.ErrNoRows like
|
||||||
|
// row.Scan would. Any placeholder parameters are replaced with supplied args.
|
||||||
|
// An error is returned if the result set is empty.
|
||||||
|
func GetContext(ctx context.Context, q QueryerContext, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
r := q.QueryRowxContext(ctx, query, args...)
|
||||||
|
return r.scanAny(dest, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// LoadFileContext exec's every statement in a file (as a single call to Exec).
|
||||||
|
// LoadFileContext may return a nil *sql.Result if errors are encountered
|
||||||
|
// locating or reading the file at path. LoadFile reads the entire file into
|
||||||
|
// memory, so it is not suitable for loading large data dumps, but can be useful
|
||||||
|
// for initializing schemas or loading indexes.
|
||||||
|
//
|
||||||
|
// FIXME: this does not really work with multi-statement files for mattn/go-sqlite3
|
||||||
|
// or the go-mysql-driver/mysql drivers; pq seems to be an exception here. Detecting
|
||||||
|
// this by requiring something with DriverName() and then attempting to split the
|
||||||
|
// queries will be difficult to get right, and its current driver-specific behavior
|
||||||
|
// is deemed at least not complex in its incorrectness.
|
||||||
|
func LoadFileContext(ctx context.Context, e ExecerContext, path string) (*sql.Result, error) {
|
||||||
|
realpath, err := filepath.Abs(path)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
contents, err := ioutil.ReadFile(realpath)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
res, err := e.ExecContext(ctx, string(contents))
|
||||||
|
return &res, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExecContext execs the query using e and panics if there was an error.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func MustExecContext(ctx context.Context, e ExecerContext, query string, args ...interface{}) sql.Result {
|
||||||
|
res, err := e.ExecContext(ctx, query, args...)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
|
// PrepareNamedContext returns an sqlx.NamedStmt
|
||||||
|
func (db *DB) PrepareNamedContext(ctx context.Context, query string) (*NamedStmt, error) {
|
||||||
|
return prepareNamedContext(ctx, db, query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedQueryContext using this DB.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (db *DB) NamedQueryContext(ctx context.Context, query string, arg interface{}) (*Rows, error) {
|
||||||
|
return NamedQueryContext(ctx, db, query, arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedExecContext using this DB.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (db *DB) NamedExecContext(ctx context.Context, query string, arg interface{}) (sql.Result, error) {
|
||||||
|
return NamedExecContext(ctx, db, query, arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext using this DB.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (db *DB) SelectContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return SelectContext(ctx, db, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext using this DB.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
// An error is returned if the result set is empty.
|
||||||
|
func (db *DB) GetContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return GetContext(ctx, db, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// PreparexContext returns an sqlx.Stmt instead of a sql.Stmt.
|
||||||
|
//
|
||||||
|
// The provided context is used for the preparation of the statement, not for
|
||||||
|
// the execution of the statement.
|
||||||
|
func (db *DB) PreparexContext(ctx context.Context, query string) (*Stmt, error) {
|
||||||
|
return PreparexContext(ctx, db, query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryxContext queries the database and returns an *sqlx.Rows.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (db *DB) QueryxContext(ctx context.Context, query string, args ...interface{}) (*Rows, error) {
|
||||||
|
r, err := db.DB.QueryContext(ctx, query, args...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, unsafe: db.unsafe, Mapper: db.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowxContext queries the database and returns an *sqlx.Row.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (db *DB) QueryRowxContext(ctx context.Context, query string, args ...interface{}) *Row {
|
||||||
|
rows, err := db.DB.QueryContext(ctx, query, args...)
|
||||||
|
return &Row{rows: rows, err: err, unsafe: db.unsafe, Mapper: db.Mapper}
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustBeginTx starts a transaction, and panics on error. Returns an *sqlx.Tx instead
|
||||||
|
// of an *sql.Tx.
|
||||||
|
//
|
||||||
|
// The provided context is used until the transaction is committed or rolled
|
||||||
|
// back. If the context is canceled, the sql package will roll back the
|
||||||
|
// transaction. Tx.Commit will return an error if the context provided to
|
||||||
|
// MustBeginContext is canceled.
|
||||||
|
func (db *DB) MustBeginTx(ctx context.Context, opts *sql.TxOptions) *Tx {
|
||||||
|
tx, err := db.BeginTxx(ctx, opts)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return tx
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExecContext (panic) runs MustExec using this database.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (db *DB) MustExecContext(ctx context.Context, query string, args ...interface{}) sql.Result {
|
||||||
|
return MustExecContext(ctx, db, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// BeginTxx begins a transaction and returns an *sqlx.Tx instead of an
|
||||||
|
// *sql.Tx.
|
||||||
|
//
|
||||||
|
// The provided context is used until the transaction is committed or rolled
|
||||||
|
// back. If the context is canceled, the sql package will roll back the
|
||||||
|
// transaction. Tx.Commit will return an error if the context provided to
|
||||||
|
// BeginxContext is canceled.
|
||||||
|
func (db *DB) BeginTxx(ctx context.Context, opts *sql.TxOptions) (*Tx, error) {
|
||||||
|
tx, err := db.DB.BeginTx(ctx, opts)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Tx{Tx: tx, driverName: db.driverName, unsafe: db.unsafe, Mapper: db.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Connx returns an *sqlx.Conn instead of an *sql.Conn.
|
||||||
|
func (db *DB) Connx(ctx context.Context) (*Conn, error) {
|
||||||
|
conn, err := db.DB.Conn(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &Conn{Conn: conn, driverName: db.driverName, unsafe: db.unsafe, Mapper: db.Mapper}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// BeginTxx begins a transaction and returns an *sqlx.Tx instead of an
|
||||||
|
// *sql.Tx.
|
||||||
|
//
|
||||||
|
// The provided context is used until the transaction is committed or rolled
|
||||||
|
// back. If the context is canceled, the sql package will roll back the
|
||||||
|
// transaction. Tx.Commit will return an error if the context provided to
|
||||||
|
// BeginxContext is canceled.
|
||||||
|
func (c *Conn) BeginTxx(ctx context.Context, opts *sql.TxOptions) (*Tx, error) {
|
||||||
|
tx, err := c.Conn.BeginTx(ctx, opts)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Tx{Tx: tx, driverName: c.driverName, unsafe: c.unsafe, Mapper: c.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext using this Conn.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (c *Conn) SelectContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return SelectContext(ctx, c, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext using this Conn.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
// An error is returned if the result set is empty.
|
||||||
|
func (c *Conn) GetContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return GetContext(ctx, c, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// PreparexContext returns an sqlx.Stmt instead of a sql.Stmt.
|
||||||
|
//
|
||||||
|
// The provided context is used for the preparation of the statement, not for
|
||||||
|
// the execution of the statement.
|
||||||
|
func (c *Conn) PreparexContext(ctx context.Context, query string) (*Stmt, error) {
|
||||||
|
return PreparexContext(ctx, c, query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryxContext queries the database and returns an *sqlx.Rows.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (c *Conn) QueryxContext(ctx context.Context, query string, args ...interface{}) (*Rows, error) {
|
||||||
|
r, err := c.Conn.QueryContext(ctx, query, args...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, unsafe: c.unsafe, Mapper: c.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowxContext queries the database and returns an *sqlx.Row.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (c *Conn) QueryRowxContext(ctx context.Context, query string, args ...interface{}) *Row {
|
||||||
|
rows, err := c.Conn.QueryContext(ctx, query, args...)
|
||||||
|
return &Row{rows: rows, err: err, unsafe: c.unsafe, Mapper: c.Mapper}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rebind a query within a Conn's bindvar type.
|
||||||
|
func (c *Conn) Rebind(query string) string {
|
||||||
|
return Rebind(BindType(c.driverName), query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// StmtxContext returns a version of the prepared statement which runs within a
|
||||||
|
// transaction. Provided stmt can be either *sql.Stmt or *sqlx.Stmt.
|
||||||
|
func (tx *Tx) StmtxContext(ctx context.Context, stmt interface{}) *Stmt {
|
||||||
|
var s *sql.Stmt
|
||||||
|
switch v := stmt.(type) {
|
||||||
|
case Stmt:
|
||||||
|
s = v.Stmt
|
||||||
|
case *Stmt:
|
||||||
|
s = v.Stmt
|
||||||
|
case *sql.Stmt:
|
||||||
|
s = v
|
||||||
|
default:
|
||||||
|
panic(fmt.Sprintf("non-statement type %v passed to Stmtx", reflect.ValueOf(stmt).Type()))
|
||||||
|
}
|
||||||
|
return &Stmt{Stmt: tx.StmtContext(ctx, s), Mapper: tx.Mapper}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedStmtContext returns a version of the prepared statement which runs
|
||||||
|
// within a transaction.
|
||||||
|
func (tx *Tx) NamedStmtContext(ctx context.Context, stmt *NamedStmt) *NamedStmt {
|
||||||
|
return &NamedStmt{
|
||||||
|
QueryString: stmt.QueryString,
|
||||||
|
Params: stmt.Params,
|
||||||
|
Stmt: tx.StmtxContext(ctx, stmt.Stmt),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// PreparexContext returns an sqlx.Stmt instead of a sql.Stmt.
|
||||||
|
//
|
||||||
|
// The provided context is used for the preparation of the statement, not for
|
||||||
|
// the execution of the statement.
|
||||||
|
func (tx *Tx) PreparexContext(ctx context.Context, query string) (*Stmt, error) {
|
||||||
|
return PreparexContext(ctx, tx, query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// PrepareNamedContext returns an sqlx.NamedStmt
|
||||||
|
func (tx *Tx) PrepareNamedContext(ctx context.Context, query string) (*NamedStmt, error) {
|
||||||
|
return prepareNamedContext(ctx, tx, query)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExecContext runs MustExecContext within a transaction.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (tx *Tx) MustExecContext(ctx context.Context, query string, args ...interface{}) sql.Result {
|
||||||
|
return MustExecContext(ctx, tx, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryxContext within a transaction and context.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (tx *Tx) QueryxContext(ctx context.Context, query string, args ...interface{}) (*Rows, error) {
|
||||||
|
r, err := tx.Tx.QueryContext(ctx, query, args...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, unsafe: tx.unsafe, Mapper: tx.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext within a transaction and context.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (tx *Tx) SelectContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return SelectContext(ctx, tx, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext within a transaction and context.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
// An error is returned if the result set is empty.
|
||||||
|
func (tx *Tx) GetContext(ctx context.Context, dest interface{}, query string, args ...interface{}) error {
|
||||||
|
return GetContext(ctx, tx, dest, query, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowxContext within a transaction and context.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (tx *Tx) QueryRowxContext(ctx context.Context, query string, args ...interface{}) *Row {
|
||||||
|
rows, err := tx.Tx.QueryContext(ctx, query, args...)
|
||||||
|
return &Row{rows: rows, err: err, unsafe: tx.unsafe, Mapper: tx.Mapper}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NamedExecContext using this Tx.
|
||||||
|
// Any named placeholder parameters are replaced with fields from arg.
|
||||||
|
func (tx *Tx) NamedExecContext(ctx context.Context, query string, arg interface{}) (sql.Result, error) {
|
||||||
|
return NamedExecContext(ctx, tx, query, arg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SelectContext using the prepared statement.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (s *Stmt) SelectContext(ctx context.Context, dest interface{}, args ...interface{}) error {
|
||||||
|
return SelectContext(ctx, &qStmt{s}, dest, "", args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetContext using the prepared statement.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
// An error is returned if the result set is empty.
|
||||||
|
func (s *Stmt) GetContext(ctx context.Context, dest interface{}, args ...interface{}) error {
|
||||||
|
return GetContext(ctx, &qStmt{s}, dest, "", args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MustExecContext (panic) using this statement. Note that the query portion of
|
||||||
|
// the error output will be blank, as Stmt does not expose its query.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (s *Stmt) MustExecContext(ctx context.Context, args ...interface{}) sql.Result {
|
||||||
|
return MustExecContext(ctx, &qStmt{s}, "", args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryRowxContext using this statement.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (s *Stmt) QueryRowxContext(ctx context.Context, args ...interface{}) *Row {
|
||||||
|
qs := &qStmt{s}
|
||||||
|
return qs.QueryRowxContext(ctx, "", args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// QueryxContext using this statement.
|
||||||
|
// Any placeholder parameters are replaced with supplied args.
|
||||||
|
func (s *Stmt) QueryxContext(ctx context.Context, args ...interface{}) (*Rows, error) {
|
||||||
|
qs := &qStmt{s}
|
||||||
|
return qs.QueryxContext(ctx, "", args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (q *qStmt) QueryContext(ctx context.Context, query string, args ...interface{}) (*sql.Rows, error) {
|
||||||
|
return q.Stmt.QueryContext(ctx, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (q *qStmt) QueryxContext(ctx context.Context, query string, args ...interface{}) (*Rows, error) {
|
||||||
|
r, err := q.Stmt.QueryContext(ctx, args...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &Rows{Rows: r, unsafe: q.Stmt.unsafe, Mapper: q.Stmt.Mapper}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (q *qStmt) QueryRowxContext(ctx context.Context, query string, args ...interface{}) *Row {
|
||||||
|
rows, err := q.Stmt.QueryContext(ctx, args...)
|
||||||
|
return &Row{rows: rows, err: err, unsafe: q.Stmt.unsafe, Mapper: q.Stmt.Mapper}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (q *qStmt) ExecContext(ctx context.Context, query string, args ...interface{}) (sql.Result, error) {
|
||||||
|
return q.Stmt.ExecContext(ctx, args...)
|
||||||
|
}
|
35
vendor/github.com/mutecomm/go-sqlcipher/v4/_example/mod_regexp/sqlite3_mod_regexp.c
generated
vendored
35
vendor/github.com/mutecomm/go-sqlcipher/v4/_example/mod_regexp/sqlite3_mod_regexp.c
generated
vendored
@ -1,35 +0,0 @@
|
|||||||
#include <pcre.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <sqlite3ext.h>
|
|
||||||
|
|
||||||
SQLITE_EXTENSION_INIT1
|
|
||||||
static void regexp_func(sqlite3_context *context, int argc, sqlite3_value **argv) {
|
|
||||||
if (argc >= 2) {
|
|
||||||
const char *target = (const char *)sqlite3_value_text(argv[1]);
|
|
||||||
const char *pattern = (const char *)sqlite3_value_text(argv[0]);
|
|
||||||
const char* errstr = NULL;
|
|
||||||
int erroff = 0;
|
|
||||||
int vec[500];
|
|
||||||
int n, rc;
|
|
||||||
pcre* re = pcre_compile(pattern, 0, &errstr, &erroff, NULL);
|
|
||||||
if (!re) {
|
|
||||||
sqlite3_result_error(context, errstr, 0);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
rc = pcre_exec(re, NULL, target, strlen(target), 0, 0, vec, 500);
|
|
||||||
if (rc <= 0) {
|
|
||||||
sqlite3_result_int(context, 0);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
sqlite3_result_int(context, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
__declspec(dllexport)
|
|
||||||
#endif
|
|
||||||
int sqlite3_extension_init(sqlite3 *db, char **errmsg, const sqlite3_api_routines *api) {
|
|
||||||
SQLITE_EXTENSION_INIT2(api);
|
|
||||||
return sqlite3_create_function(db, "regexp", 2, SQLITE_UTF8, (void*)db, regexp_func, NULL, NULL);
|
|
||||||
}
|
|
1040
vendor/github.com/mutecomm/go-sqlcipher/v4/_example/mod_vtable/picojson.h
generated
vendored
1040
vendor/github.com/mutecomm/go-sqlcipher/v4/_example/mod_vtable/picojson.h
generated
vendored
File diff suppressed because it is too large
Load Diff
122
vendor/modernc.org/libc/freebsd/mblocal.h
generated
vendored
122
vendor/modernc.org/libc/freebsd/mblocal.h
generated
vendored
@ -1,122 +0,0 @@
|
|||||||
// +build ingore
|
|
||||||
|
|
||||||
/*-
|
|
||||||
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
|
|
||||||
*
|
|
||||||
* Copyright 2013 Garrett D'Amore <garrett@damore.org>
|
|
||||||
* Copyright 2011 Nexenta Systems, Inc. All rights reserved.
|
|
||||||
* Copyright (c) 2004 Tim J. Robbins.
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011 The FreeBSD Foundation
|
|
||||||
* All rights reserved.
|
|
||||||
* Portions of this software were developed by David Chisnall
|
|
||||||
* under sponsorship from the FreeBSD Foundation.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* $FreeBSD$
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _MBLOCAL_H_
|
|
||||||
#define _MBLOCAL_H_
|
|
||||||
|
|
||||||
#include <runetype.h>
|
|
||||||
#include "xlocale_private.h"
|
|
||||||
|
|
||||||
#define SS2 0x008e
|
|
||||||
#define SS3 0x008f
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Conversion function pointers for current encoding.
|
|
||||||
*/
|
|
||||||
struct xlocale_ctype {
|
|
||||||
struct xlocale_component header;
|
|
||||||
_RuneLocale *runes;
|
|
||||||
size_t (*__mbrtowc)(wchar_t * __restrict, const char * __restrict,
|
|
||||||
size_t, mbstate_t * __restrict);
|
|
||||||
int (*__mbsinit)(const mbstate_t *);
|
|
||||||
size_t (*__mbsnrtowcs)(wchar_t * __restrict, const char ** __restrict,
|
|
||||||
size_t, size_t, mbstate_t * __restrict);
|
|
||||||
size_t (*__wcrtomb)(char * __restrict, wchar_t, mbstate_t * __restrict);
|
|
||||||
size_t (*__wcsnrtombs)(char * __restrict, const wchar_t ** __restrict,
|
|
||||||
size_t, size_t, mbstate_t * __restrict);
|
|
||||||
int __mb_cur_max;
|
|
||||||
int __mb_sb_limit;
|
|
||||||
/** Persistent state used by mblen() calls. */
|
|
||||||
__mbstate_t mblen;
|
|
||||||
/** Persistent state used by mbrlen() calls. */
|
|
||||||
__mbstate_t mbrlen;
|
|
||||||
/** Persistent state used by mbrtoc16() calls. */
|
|
||||||
__mbstate_t mbrtoc16;
|
|
||||||
/** Persistent state used by mbrtoc32() calls. */
|
|
||||||
__mbstate_t mbrtoc32;
|
|
||||||
/** Persistent state used by mbrtowc() calls. */
|
|
||||||
__mbstate_t mbrtowc;
|
|
||||||
/** Persistent state used by mbsnrtowcs() calls. */
|
|
||||||
__mbstate_t mbsnrtowcs;
|
|
||||||
/** Persistent state used by mbsrtowcs() calls. */
|
|
||||||
__mbstate_t mbsrtowcs;
|
|
||||||
/** Persistent state used by mbtowc() calls. */
|
|
||||||
__mbstate_t mbtowc;
|
|
||||||
/** Persistent state used by c16rtomb() calls. */
|
|
||||||
__mbstate_t c16rtomb;
|
|
||||||
/** Persistent state used by c32rtomb() calls. */
|
|
||||||
__mbstate_t c32rtomb;
|
|
||||||
/** Persistent state used by wcrtomb() calls. */
|
|
||||||
__mbstate_t wcrtomb;
|
|
||||||
/** Persistent state used by wcsnrtombs() calls. */
|
|
||||||
__mbstate_t wcsnrtombs;
|
|
||||||
/** Persistent state used by wcsrtombs() calls. */
|
|
||||||
__mbstate_t wcsrtombs;
|
|
||||||
/** Persistent state used by wctomb() calls. */
|
|
||||||
__mbstate_t wctomb;
|
|
||||||
};
|
|
||||||
#define XLOCALE_CTYPE(x) ((struct xlocale_ctype*)(x)->components[XLC_CTYPE])
|
|
||||||
extern struct xlocale_ctype __xlocale_global_ctype;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Rune initialization function prototypes.
|
|
||||||
*/
|
|
||||||
int _none_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _UTF8_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _EUC_CN_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _EUC_JP_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _EUC_KR_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _EUC_TW_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _GB18030_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _GB2312_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _GBK_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _BIG5_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _MSKanji_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
int _ascii_init(struct xlocale_ctype *, _RuneLocale *) __hidden;
|
|
||||||
|
|
||||||
typedef size_t (*mbrtowc_pfn_t)(wchar_t * __restrict,
|
|
||||||
const char * __restrict, size_t, mbstate_t * __restrict);
|
|
||||||
typedef size_t (*wcrtomb_pfn_t)(char * __restrict, wchar_t,
|
|
||||||
mbstate_t * __restrict);
|
|
||||||
size_t __mbsnrtowcs_std(wchar_t * __restrict, const char ** __restrict,
|
|
||||||
size_t, size_t, mbstate_t * __restrict, mbrtowc_pfn_t);
|
|
||||||
size_t __wcsnrtombs_std(char * __restrict, const wchar_t ** __restrict,
|
|
||||||
size_t, size_t, mbstate_t * __restrict, wcrtomb_pfn_t);
|
|
||||||
|
|
||||||
#endif /* _MBLOCAL_H_ */
|
|
13
vendor/modernc.org/libc/freebsd/setlocale.h
generated
vendored
13
vendor/modernc.org/libc/freebsd/setlocale.h
generated
vendored
@ -1,13 +0,0 @@
|
|||||||
|
|
||||||
#ifndef _SETLOCALE_H_
|
|
||||||
#define _SETLOCALE_H_
|
|
||||||
|
|
||||||
#define ENCODING_LEN 31
|
|
||||||
#define CATEGORY_LEN 11
|
|
||||||
|
|
||||||
extern char *_PathLocale;
|
|
||||||
|
|
||||||
int __detect_path_locale(void);
|
|
||||||
int __wrap_setrunelocale(const char *);
|
|
||||||
|
|
||||||
#endif /* !_SETLOCALE_H_ */
|
|
267
vendor/modernc.org/libc/freebsd/table.c
generated
vendored
267
vendor/modernc.org/libc/freebsd/table.c
generated
vendored
@ -1,267 +0,0 @@
|
|||||||
// +build ingore
|
|
||||||
|
|
||||||
/*-
|
|
||||||
* SPDX-License-Identifier: BSD-3-Clause
|
|
||||||
*
|
|
||||||
* Copyright (c) 1993
|
|
||||||
* The Regents of the University of California. All rights reserved.
|
|
||||||
*
|
|
||||||
* This code is derived from software contributed to Berkeley by
|
|
||||||
* Paul Borman at Krystal Technologies.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011 The FreeBSD Foundation
|
|
||||||
* All rights reserved.
|
|
||||||
* Portions of this software were developed by David Chisnall
|
|
||||||
* under sponsorship from the FreeBSD Foundation.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. Neither the name of the University nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(LIBC_SCCS) && !defined(lint)
|
|
||||||
static char sccsid[] = "@(#)table.c 8.1 (Berkeley) 6/27/93";
|
|
||||||
#endif /* LIBC_SCCS and not lint */
|
|
||||||
#include <sys/cdefs.h>
|
|
||||||
__FBSDID("$FreeBSD$");
|
|
||||||
|
|
||||||
#include <ctype.h>
|
|
||||||
#include <runetype.h>
|
|
||||||
#include <wchar.h>
|
|
||||||
#include "mblocal.h"
|
|
||||||
|
|
||||||
const _RuneLocale _DefaultRuneLocale = {
|
|
||||||
_RUNE_MAGIC_1,
|
|
||||||
"NONE",
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
0xFFFD,
|
|
||||||
|
|
||||||
{ /*00*/ _CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
/*08*/ _CTYPE_C,
|
|
||||||
_CTYPE_C|_CTYPE_S|_CTYPE_B,
|
|
||||||
_CTYPE_C|_CTYPE_S,
|
|
||||||
_CTYPE_C|_CTYPE_S,
|
|
||||||
_CTYPE_C|_CTYPE_S,
|
|
||||||
_CTYPE_C|_CTYPE_S,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
/*10*/ _CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
/*18*/ _CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
_CTYPE_C,
|
|
||||||
/*20*/ _CTYPE_S|_CTYPE_B|_CTYPE_R,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
/*28*/ _CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
/*30*/ _CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|0,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|1,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|2,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|3,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|4,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|5,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|6,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|7,
|
|
||||||
/*38*/ _CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|8,
|
|
||||||
_CTYPE_D|_CTYPE_R|_CTYPE_G|_CTYPE_X|_CTYPE_N|9,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
/*40*/ _CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|10,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|11,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|12,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|13,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|14,
|
|
||||||
_CTYPE_U|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|15,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*48*/ _CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*50*/ _CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*58*/ _CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_U|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
/*60*/ _CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|10,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|11,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|12,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|13,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|14,
|
|
||||||
_CTYPE_L|_CTYPE_X|_CTYPE_R|_CTYPE_G|_CTYPE_A|15,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*68*/ _CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*70*/ _CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
/*78*/ _CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_L|_CTYPE_R|_CTYPE_G|_CTYPE_A,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_P|_CTYPE_R|_CTYPE_G,
|
|
||||||
_CTYPE_C,
|
|
||||||
},
|
|
||||||
{ 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
|
|
||||||
0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
|
|
||||||
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
|
|
||||||
0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f,
|
|
||||||
0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27,
|
|
||||||
0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f,
|
|
||||||
0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37,
|
|
||||||
0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
|
|
||||||
0x40, 'a', 'b', 'c', 'd', 'e', 'f', 'g',
|
|
||||||
'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
|
|
||||||
'p', 'q', 'r', 's', 't', 'u', 'v', 'w',
|
|
||||||
'x', 'y', 'z', 0x5b, 0x5c, 0x5d, 0x5e, 0x5f,
|
|
||||||
0x60, 'a', 'b', 'c', 'd', 'e', 'f', 'g',
|
|
||||||
'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
|
|
||||||
'p', 'q', 'r', 's', 't', 'u', 'v', 'w',
|
|
||||||
'x', 'y', 'z', 0x7b, 0x7c, 0x7d, 0x7e, 0x7f,
|
|
||||||
0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
|
|
||||||
0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f,
|
|
||||||
0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97,
|
|
||||||
0x98, 0x99, 0x9a, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f,
|
|
||||||
0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
|
|
||||||
0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xaf,
|
|
||||||
0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7,
|
|
||||||
0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf,
|
|
||||||
0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,
|
|
||||||
0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,
|
|
||||||
0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7,
|
|
||||||
0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xdd, 0xde, 0xdf,
|
|
||||||
0xe0, 0xe1, 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7,
|
|
||||||
0xe8, 0xe9, 0xea, 0xeb, 0xec, 0xed, 0xee, 0xef,
|
|
||||||
0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7,
|
|
||||||
0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff,
|
|
||||||
},
|
|
||||||
{ 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
|
|
||||||
0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
|
|
||||||
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
|
|
||||||
0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f,
|
|
||||||
0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27,
|
|
||||||
0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f,
|
|
||||||
0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37,
|
|
||||||
0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
|
|
||||||
0x40, 'A', 'B', 'C', 'D', 'E', 'F', 'G',
|
|
||||||
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O',
|
|
||||||
'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
|
|
||||||
'X', 'Y', 'Z', 0x5b, 0x5c, 0x5d, 0x5e, 0x5f,
|
|
||||||
0x60, 'A', 'B', 'C', 'D', 'E', 'F', 'G',
|
|
||||||
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O',
|
|
||||||
'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
|
|
||||||
'X', 'Y', 'Z', 0x7b, 0x7c, 0x7d, 0x7e, 0x7f,
|
|
||||||
0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
|
|
||||||
0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f,
|
|
||||||
0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97,
|
|
||||||
0x98, 0x99, 0x9a, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f,
|
|
||||||
0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
|
|
||||||
0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xaf,
|
|
||||||
0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7,
|
|
||||||
0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf,
|
|
||||||
0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,
|
|
||||||
0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,
|
|
||||||
0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7,
|
|
||||||
0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xdd, 0xde, 0xdf,
|
|
||||||
0xe0, 0xe1, 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7,
|
|
||||||
0xe8, 0xe9, 0xea, 0xeb, 0xec, 0xed, 0xee, 0xef,
|
|
||||||
0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7,
|
|
||||||
0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
#undef _CurrentRuneLocale
|
|
||||||
const _RuneLocale *_CurrentRuneLocale = &_DefaultRuneLocale;
|
|
||||||
|
|
||||||
_RuneLocale *
|
|
||||||
__runes_for_locale(locale_t locale, int *mb_sb_limit)
|
|
||||||
{
|
|
||||||
FIX_LOCALE(locale);
|
|
||||||
struct xlocale_ctype *c = XLOCALE_CTYPE(locale);
|
|
||||||
*mb_sb_limit = c->__mb_sb_limit;
|
|
||||||
return c->runes;
|
|
||||||
}
|
|
4101
vendor/modernc.org/libc/freebsd/table.cpp.c
generated
vendored
4101
vendor/modernc.org/libc/freebsd/table.cpp.c
generated
vendored
File diff suppressed because it is too large
Load Diff
228
vendor/modernc.org/libc/freebsd/xlocale_private.h
generated
vendored
228
vendor/modernc.org/libc/freebsd/xlocale_private.h
generated
vendored
@ -1,228 +0,0 @@
|
|||||||
/*-
|
|
||||||
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011 The FreeBSD Foundation
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* This software was developed by David Chisnall under sponsorship from
|
|
||||||
* the FreeBSD Foundation.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* $FreeBSD$
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _XLOCALE_PRIVATE__H_
|
|
||||||
#define _XLOCALE_PRIVATE__H_
|
|
||||||
|
|
||||||
#include <xlocale.h>
|
|
||||||
#include <locale.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <machine/atomic.h>
|
|
||||||
#include "setlocale.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The XLC_ values are indexes into the components array. They are defined in
|
|
||||||
* the same order as the LC_ values in locale.h, but without the LC_ALL zero
|
|
||||||
* value. Translating from LC_X to XLC_X is done by subtracting one.
|
|
||||||
*
|
|
||||||
* Any reordering of this enum should ensure that these invariants are not
|
|
||||||
* violated.
|
|
||||||
*/
|
|
||||||
enum {
|
|
||||||
XLC_COLLATE = 0,
|
|
||||||
XLC_CTYPE,
|
|
||||||
XLC_MONETARY,
|
|
||||||
XLC_NUMERIC,
|
|
||||||
XLC_TIME,
|
|
||||||
XLC_MESSAGES,
|
|
||||||
XLC_LAST
|
|
||||||
};
|
|
||||||
|
|
||||||
_Static_assert(XLC_LAST - XLC_COLLATE == 6, "XLC values should be contiguous");
|
|
||||||
_Static_assert(XLC_COLLATE == LC_COLLATE - 1,
|
|
||||||
"XLC_COLLATE doesn't match the LC_COLLATE value.");
|
|
||||||
_Static_assert(XLC_CTYPE == LC_CTYPE - 1,
|
|
||||||
"XLC_CTYPE doesn't match the LC_CTYPE value.");
|
|
||||||
_Static_assert(XLC_MONETARY == LC_MONETARY - 1,
|
|
||||||
"XLC_MONETARY doesn't match the LC_MONETARY value.");
|
|
||||||
_Static_assert(XLC_NUMERIC == LC_NUMERIC - 1,
|
|
||||||
"XLC_NUMERIC doesn't match the LC_NUMERIC value.");
|
|
||||||
_Static_assert(XLC_TIME == LC_TIME - 1,
|
|
||||||
"XLC_TIME doesn't match the LC_TIME value.");
|
|
||||||
_Static_assert(XLC_MESSAGES == LC_MESSAGES - 1,
|
|
||||||
"XLC_MESSAGES doesn't match the LC_MESSAGES value.");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Header used for objects that are reference counted. Objects may optionally
|
|
||||||
* have a destructor associated, which is responsible for destroying the
|
|
||||||
* structure. Global / static versions of the structure should have no
|
|
||||||
* destructor set - they can then have their reference counts manipulated as
|
|
||||||
* normal, but will not do anything with them.
|
|
||||||
*
|
|
||||||
* The header stores a retain count - objects are assumed to have a reference
|
|
||||||
* count of 1 when they are created, but the retain count is 0. When the
|
|
||||||
* retain count is less than 0, they are freed.
|
|
||||||
*/
|
|
||||||
struct xlocale_refcounted {
|
|
||||||
/** Number of references to this component. */
|
|
||||||
long retain_count;
|
|
||||||
/** Function used to destroy this component, if one is required*/
|
|
||||||
void(*destructor)(void*);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define XLOCALE_DEF_VERSION_LEN 12
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Header for a locale component. All locale components must begin with this
|
|
||||||
* header.
|
|
||||||
*/
|
|
||||||
struct xlocale_component {
|
|
||||||
struct xlocale_refcounted header;
|
|
||||||
/** Name of the locale used for this component. */
|
|
||||||
char locale[ENCODING_LEN+1];
|
|
||||||
/** Version of the definition for this component. */
|
|
||||||
char version[XLOCALE_DEF_VERSION_LEN];
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* xlocale structure, stores per-thread locale information.
|
|
||||||
*/
|
|
||||||
struct _xlocale {
|
|
||||||
struct xlocale_refcounted header;
|
|
||||||
/** Components for the locale. */
|
|
||||||
struct xlocale_component *components[XLC_LAST];
|
|
||||||
/** Flag indicating if components[XLC_MONETARY] has changed since the
|
|
||||||
* last call to localeconv_l() with this locale. */
|
|
||||||
int monetary_locale_changed;
|
|
||||||
/** Flag indicating whether this locale is actually using a locale for
|
|
||||||
* LC_MONETARY (1), or if it should use the C default instead (0). */
|
|
||||||
int using_monetary_locale;
|
|
||||||
/** Flag indicating if components[XLC_NUMERIC] has changed since the
|
|
||||||
* last call to localeconv_l() with this locale. */
|
|
||||||
int numeric_locale_changed;
|
|
||||||
/** Flag indicating whether this locale is actually using a locale for
|
|
||||||
* LC_NUMERIC (1), or if it should use the C default instead (0). */
|
|
||||||
int using_numeric_locale;
|
|
||||||
/** Flag indicating whether this locale is actually using a locale for
|
|
||||||
* LC_TIME (1), or if it should use the C default instead (0). */
|
|
||||||
int using_time_locale;
|
|
||||||
/** Flag indicating whether this locale is actually using a locale for
|
|
||||||
* LC_MESSAGES (1), or if it should use the C default instead (0). */
|
|
||||||
int using_messages_locale;
|
|
||||||
/** The structure to be returned from localeconv_l() for this locale. */
|
|
||||||
struct lconv lconv;
|
|
||||||
/** Buffer used by nl_langinfo_l() */
|
|
||||||
char *csym;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Increments the reference count of a reference-counted structure.
|
|
||||||
*/
|
|
||||||
__attribute__((unused)) static void*
|
|
||||||
xlocale_retain(void *val)
|
|
||||||
{
|
|
||||||
struct xlocale_refcounted *obj = val;
|
|
||||||
atomic_add_long(&(obj->retain_count), 1);
|
|
||||||
return (val);
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Decrements the reference count of a reference-counted structure, freeing it
|
|
||||||
* if this is the last reference, calling its destructor if it has one.
|
|
||||||
*/
|
|
||||||
__attribute__((unused)) static void
|
|
||||||
xlocale_release(void *val)
|
|
||||||
{
|
|
||||||
struct xlocale_refcounted *obj = val;
|
|
||||||
long count;
|
|
||||||
|
|
||||||
count = atomic_fetchadd_long(&(obj->retain_count), -1) - 1;
|
|
||||||
if (count < 0 && obj->destructor != NULL)
|
|
||||||
obj->destructor(obj);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load functions. Each takes the name of a locale and a pointer to the data
|
|
||||||
* to be initialised as arguments. Two special values are allowed for the
|
|
||||||
*/
|
|
||||||
extern void* __collate_load(const char*, locale_t);
|
|
||||||
extern void* __ctype_load(const char*, locale_t);
|
|
||||||
extern void* __messages_load(const char*, locale_t);
|
|
||||||
extern void* __monetary_load(const char*, locale_t);
|
|
||||||
extern void* __numeric_load(const char*, locale_t);
|
|
||||||
extern void* __time_load(const char*, locale_t);
|
|
||||||
|
|
||||||
extern struct _xlocale __xlocale_global_locale;
|
|
||||||
extern struct _xlocale __xlocale_C_locale;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Caches the rune table in TLS for fast access.
|
|
||||||
*/
|
|
||||||
void __set_thread_rune_locale(locale_t loc);
|
|
||||||
/**
|
|
||||||
* Flag indicating whether a per-thread locale has been set. If no per-thread
|
|
||||||
* locale has ever been set, then we always use the global locale.
|
|
||||||
*/
|
|
||||||
extern int __has_thread_locale;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The per-thread locale. Avoids the need to use pthread lookup functions when
|
|
||||||
* getting the per-thread locale.
|
|
||||||
*/
|
|
||||||
extern _Thread_local locale_t __thread_locale;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the current locale for this thread, or the global locale if none is
|
|
||||||
* set. The caller does not have to free the locale. The return value from
|
|
||||||
* this call is not guaranteed to remain valid after the locale changes. As
|
|
||||||
* such, this should only be called within libc functions.
|
|
||||||
*/
|
|
||||||
static inline locale_t __get_locale(void)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (!__has_thread_locale) {
|
|
||||||
return (&__xlocale_global_locale);
|
|
||||||
}
|
|
||||||
return (__thread_locale ? __thread_locale : &__xlocale_global_locale);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Two magic values are allowed for locale_t objects. NULL and -1. This
|
|
||||||
* function maps those to the real locales that they represent.
|
|
||||||
*/
|
|
||||||
static inline locale_t get_real_locale(locale_t locale)
|
|
||||||
{
|
|
||||||
switch ((intptr_t)locale) {
|
|
||||||
case 0: return (&__xlocale_C_locale);
|
|
||||||
case -1: return (&__xlocale_global_locale);
|
|
||||||
default: return (locale);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Replace a placeholder locale with the real global or thread-local locale_t.
|
|
||||||
*/
|
|
||||||
#define FIX_LOCALE(l) (l = get_real_locale(l))
|
|
||||||
|
|
||||||
#endif
|
|
82
vendor/modernc.org/libc/musl/arch/aarch64/atomic_arch.h
generated
vendored
82
vendor/modernc.org/libc/musl/arch/aarch64/atomic_arch.h
generated
vendored
@ -1,82 +0,0 @@
|
|||||||
#define a_ll a_ll
|
|
||||||
static inline int a_ll(volatile int *p)
|
|
||||||
{
|
|
||||||
int v;
|
|
||||||
__asm__ __volatile__ ("ldaxr %w0,%1" : "=r"(v) : "Q"(*p));
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_sc a_sc
|
|
||||||
static inline int a_sc(volatile int *p, int v)
|
|
||||||
{
|
|
||||||
int r;
|
|
||||||
__asm__ __volatile__ ("stlxr %w0,%w2,%1" : "=&r"(r), "=Q"(*p) : "r"(v) : "memory");
|
|
||||||
return !r;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_barrier a_barrier
|
|
||||||
static inline void a_barrier()
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("dmb ish" : : : "memory");
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_cas a_cas
|
|
||||||
static inline int a_cas(volatile int *p, int t, int s)
|
|
||||||
{
|
|
||||||
int old;
|
|
||||||
do {
|
|
||||||
old = a_ll(p);
|
|
||||||
if (old != t) {
|
|
||||||
a_barrier();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} while (!a_sc(p, s));
|
|
||||||
return old;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_ll_p a_ll_p
|
|
||||||
static inline void *a_ll_p(volatile void *p)
|
|
||||||
{
|
|
||||||
void *v;
|
|
||||||
__asm__ __volatile__ ("ldaxr %0, %1" : "=r"(v) : "Q"(*(void *volatile *)p));
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_sc_p a_sc_p
|
|
||||||
static inline int a_sc_p(volatile int *p, void *v)
|
|
||||||
{
|
|
||||||
int r;
|
|
||||||
__asm__ __volatile__ ("stlxr %w0,%2,%1" : "=&r"(r), "=Q"(*(void *volatile *)p) : "r"(v) : "memory");
|
|
||||||
return !r;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_cas_p a_cas_p
|
|
||||||
static inline void *a_cas_p(volatile void *p, void *t, void *s)
|
|
||||||
{
|
|
||||||
void *old;
|
|
||||||
do {
|
|
||||||
old = a_ll_p(p);
|
|
||||||
if (old != t) {
|
|
||||||
a_barrier();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} while (!a_sc_p(p, s));
|
|
||||||
return old;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_ctz_64 a_ctz_64
|
|
||||||
static inline int a_ctz_64(uint64_t x)
|
|
||||||
{
|
|
||||||
__asm__(
|
|
||||||
" rbit %0, %1\n"
|
|
||||||
" clz %0, %0\n"
|
|
||||||
: "=r"(x) : "r"(x));
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_clz_64 a_clz_64
|
|
||||||
static inline int a_clz_64(uint64_t x)
|
|
||||||
{
|
|
||||||
__asm__("clz %0, %1" : "=r"(x) : "r"(x));
|
|
||||||
return x;
|
|
||||||
}
|
|
38
vendor/modernc.org/libc/musl/arch/aarch64/bits/fcntl.h
generated
vendored
38
vendor/modernc.org/libc/musl/arch/aarch64/bits/fcntl.h
generated
vendored
@ -1,38 +0,0 @@
|
|||||||
#define O_CREAT 0100
|
|
||||||
#define O_EXCL 0200
|
|
||||||
#define O_NOCTTY 0400
|
|
||||||
#define O_TRUNC 01000
|
|
||||||
#define O_APPEND 02000
|
|
||||||
#define O_NONBLOCK 04000
|
|
||||||
#define O_DSYNC 010000
|
|
||||||
#define O_SYNC 04010000
|
|
||||||
#define O_RSYNC 04010000
|
|
||||||
#define O_DIRECTORY 040000
|
|
||||||
#define O_NOFOLLOW 0100000
|
|
||||||
#define O_CLOEXEC 02000000
|
|
||||||
|
|
||||||
#define O_ASYNC 020000
|
|
||||||
#define O_DIRECT 0200000
|
|
||||||
#define O_LARGEFILE 0400000
|
|
||||||
#define O_NOATIME 01000000
|
|
||||||
#define O_PATH 010000000
|
|
||||||
#define O_TMPFILE 020040000
|
|
||||||
#define O_NDELAY O_NONBLOCK
|
|
||||||
|
|
||||||
#define F_DUPFD 0
|
|
||||||
#define F_GETFD 1
|
|
||||||
#define F_SETFD 2
|
|
||||||
#define F_GETFL 3
|
|
||||||
#define F_SETFL 4
|
|
||||||
#define F_GETLK 5
|
|
||||||
#define F_SETLK 6
|
|
||||||
#define F_SETLKW 7
|
|
||||||
#define F_SETOWN 8
|
|
||||||
#define F_GETOWN 9
|
|
||||||
#define F_SETSIG 10
|
|
||||||
#define F_GETSIG 11
|
|
||||||
|
|
||||||
#define F_SETOWN_EX 15
|
|
||||||
#define F_GETOWN_EX 16
|
|
||||||
|
|
||||||
#define F_GETOWNER_UIDS 17
|
|
19
vendor/modernc.org/libc/musl/arch/aarch64/bits/fenv.h
generated
vendored
19
vendor/modernc.org/libc/musl/arch/aarch64/bits/fenv.h
generated
vendored
@ -1,19 +0,0 @@
|
|||||||
#define FE_INVALID 1
|
|
||||||
#define FE_DIVBYZERO 2
|
|
||||||
#define FE_OVERFLOW 4
|
|
||||||
#define FE_UNDERFLOW 8
|
|
||||||
#define FE_INEXACT 16
|
|
||||||
#define FE_ALL_EXCEPT 31
|
|
||||||
#define FE_TONEAREST 0
|
|
||||||
#define FE_DOWNWARD 0x800000
|
|
||||||
#define FE_UPWARD 0x400000
|
|
||||||
#define FE_TOWARDZERO 0xc00000
|
|
||||||
|
|
||||||
typedef unsigned int fexcept_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
unsigned int __fpcr;
|
|
||||||
unsigned int __fpsr;
|
|
||||||
} fenv_t;
|
|
||||||
|
|
||||||
#define FE_DFL_ENV ((const fenv_t *) -1)
|
|
31
vendor/modernc.org/libc/musl/arch/aarch64/bits/float.h
generated
vendored
31
vendor/modernc.org/libc/musl/arch/aarch64/bits/float.h
generated
vendored
@ -1,31 +0,0 @@
|
|||||||
#define FLT_EVAL_METHOD 0
|
|
||||||
|
|
||||||
// #define LDBL_TRUE_MIN 6.47517511943802511092443895822764655e-4966L
|
|
||||||
// #define LDBL_MIN 3.36210314311209350626267781732175260e-4932L
|
|
||||||
// #define LDBL_MAX 1.18973149535723176508575932662800702e+4932L
|
|
||||||
// #define LDBL_EPSILON 1.92592994438723585305597794258492732e-34L
|
|
||||||
//
|
|
||||||
// #define LDBL_MANT_DIG 113
|
|
||||||
// #define LDBL_MIN_EXP (-16381)
|
|
||||||
// #define LDBL_MAX_EXP 16384
|
|
||||||
//
|
|
||||||
// #define LDBL_DIG 33
|
|
||||||
// #define LDBL_MIN_10_EXP (-4931)
|
|
||||||
// #define LDBL_MAX_10_EXP 4932
|
|
||||||
//
|
|
||||||
// #define DECIMAL_DIG 36
|
|
||||||
|
|
||||||
#define LDBL_TRUE_MIN 4.94065645841246544177e-324L
|
|
||||||
#define LDBL_MIN 2.22507385850720138309e-308L
|
|
||||||
#define LDBL_MAX 1.79769313486231570815e+308L
|
|
||||||
#define LDBL_EPSILON 2.22044604925031308085e-16L
|
|
||||||
|
|
||||||
#define LDBL_MANT_DIG 53
|
|
||||||
#define LDBL_MIN_EXP (-1021)
|
|
||||||
#define LDBL_MAX_EXP 1024
|
|
||||||
|
|
||||||
#define LDBL_DIG 15
|
|
||||||
#define LDBL_MIN_10_EXP (-307)
|
|
||||||
#define LDBL_MAX_10_EXP 308
|
|
||||||
|
|
||||||
#define DECIMAL_DIG 17
|
|
40
vendor/modernc.org/libc/musl/arch/aarch64/bits/hwcap.h
generated
vendored
40
vendor/modernc.org/libc/musl/arch/aarch64/bits/hwcap.h
generated
vendored
@ -1,40 +0,0 @@
|
|||||||
#define HWCAP_FP (1 << 0)
|
|
||||||
#define HWCAP_ASIMD (1 << 1)
|
|
||||||
#define HWCAP_EVTSTRM (1 << 2)
|
|
||||||
#define HWCAP_AES (1 << 3)
|
|
||||||
#define HWCAP_PMULL (1 << 4)
|
|
||||||
#define HWCAP_SHA1 (1 << 5)
|
|
||||||
#define HWCAP_SHA2 (1 << 6)
|
|
||||||
#define HWCAP_CRC32 (1 << 7)
|
|
||||||
#define HWCAP_ATOMICS (1 << 8)
|
|
||||||
#define HWCAP_FPHP (1 << 9)
|
|
||||||
#define HWCAP_ASIMDHP (1 << 10)
|
|
||||||
#define HWCAP_CPUID (1 << 11)
|
|
||||||
#define HWCAP_ASIMDRDM (1 << 12)
|
|
||||||
#define HWCAP_JSCVT (1 << 13)
|
|
||||||
#define HWCAP_FCMA (1 << 14)
|
|
||||||
#define HWCAP_LRCPC (1 << 15)
|
|
||||||
#define HWCAP_DCPOP (1 << 16)
|
|
||||||
#define HWCAP_SHA3 (1 << 17)
|
|
||||||
#define HWCAP_SM3 (1 << 18)
|
|
||||||
#define HWCAP_SM4 (1 << 19)
|
|
||||||
#define HWCAP_ASIMDDP (1 << 20)
|
|
||||||
#define HWCAP_SHA512 (1 << 21)
|
|
||||||
#define HWCAP_SVE (1 << 22)
|
|
||||||
#define HWCAP_ASIMDFHM (1 << 23)
|
|
||||||
#define HWCAP_DIT (1 << 24)
|
|
||||||
#define HWCAP_USCAT (1 << 25)
|
|
||||||
#define HWCAP_ILRCPC (1 << 26)
|
|
||||||
#define HWCAP_FLAGM (1 << 27)
|
|
||||||
#define HWCAP_SSBS (1 << 28)
|
|
||||||
#define HWCAP_SB (1 << 29)
|
|
||||||
#define HWCAP_PACA (1 << 30)
|
|
||||||
#define HWCAP_PACG (1UL << 31)
|
|
||||||
|
|
||||||
#define HWCAP2_DCPODP (1 << 0)
|
|
||||||
#define HWCAP2_SVE2 (1 << 1)
|
|
||||||
#define HWCAP2_SVEAES (1 << 2)
|
|
||||||
#define HWCAP2_SVEPMULL (1 << 3)
|
|
||||||
#define HWCAP2_SVEBITPERM (1 << 4)
|
|
||||||
#define HWCAP2_SVESHA3 (1 << 5)
|
|
||||||
#define HWCAP2_SVESM4 (1 << 6)
|
|
2
vendor/modernc.org/libc/musl/arch/aarch64/bits/posix.h
generated
vendored
2
vendor/modernc.org/libc/musl/arch/aarch64/bits/posix.h
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
#define _POSIX_V6_LP64_OFF64 1
|
|
||||||
#define _POSIX_V7_LP64_OFF64 1
|
|
2
vendor/modernc.org/libc/musl/arch/aarch64/bits/reg.h
generated
vendored
2
vendor/modernc.org/libc/musl/arch/aarch64/bits/reg.h
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
#undef __WORDSIZE
|
|
||||||
#define __WORDSIZE 64
|
|
1
vendor/modernc.org/libc/musl/arch/aarch64/bits/setjmp.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/aarch64/bits/setjmp.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
typedef unsigned long __jmp_buf[22];
|
|
153
vendor/modernc.org/libc/musl/arch/aarch64/bits/signal.h
generated
vendored
153
vendor/modernc.org/libc/musl/arch/aarch64/bits/signal.h
generated
vendored
@ -1,153 +0,0 @@
|
|||||||
#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|
|
||||||
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
|
|
||||||
#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
#define MINSIGSTKSZ 6144
|
|
||||||
#define SIGSTKSZ 12288
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
typedef unsigned long greg_t;
|
|
||||||
typedef unsigned long gregset_t[34];
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
long double vregs[32];
|
|
||||||
unsigned int fpsr;
|
|
||||||
unsigned int fpcr;
|
|
||||||
} fpregset_t;
|
|
||||||
typedef struct sigcontext {
|
|
||||||
unsigned long fault_address;
|
|
||||||
unsigned long regs[31];
|
|
||||||
unsigned long sp, pc, pstate;
|
|
||||||
long double __reserved[256];
|
|
||||||
} mcontext_t;
|
|
||||||
|
|
||||||
#define FPSIMD_MAGIC 0x46508001
|
|
||||||
#define ESR_MAGIC 0x45535201
|
|
||||||
#define EXTRA_MAGIC 0x45585401
|
|
||||||
#define SVE_MAGIC 0x53564501
|
|
||||||
struct _aarch64_ctx {
|
|
||||||
unsigned int magic;
|
|
||||||
unsigned int size;
|
|
||||||
};
|
|
||||||
struct fpsimd_context {
|
|
||||||
struct _aarch64_ctx head;
|
|
||||||
unsigned int fpsr;
|
|
||||||
unsigned int fpcr;
|
|
||||||
long double vregs[32];
|
|
||||||
};
|
|
||||||
struct esr_context {
|
|
||||||
struct _aarch64_ctx head;
|
|
||||||
unsigned long esr;
|
|
||||||
};
|
|
||||||
struct extra_context {
|
|
||||||
struct _aarch64_ctx head;
|
|
||||||
unsigned long datap;
|
|
||||||
unsigned int size;
|
|
||||||
unsigned int __reserved[3];
|
|
||||||
};
|
|
||||||
struct sve_context {
|
|
||||||
struct _aarch64_ctx head;
|
|
||||||
unsigned short vl;
|
|
||||||
unsigned short __reserved[3];
|
|
||||||
};
|
|
||||||
#define SVE_VQ_BYTES 16
|
|
||||||
#define SVE_VQ_MIN 1
|
|
||||||
#define SVE_VQ_MAX 512
|
|
||||||
#define SVE_VL_MIN (SVE_VQ_MIN * SVE_VQ_BYTES)
|
|
||||||
#define SVE_VL_MAX (SVE_VQ_MAX * SVE_VQ_BYTES)
|
|
||||||
#define SVE_NUM_ZREGS 32
|
|
||||||
#define SVE_NUM_PREGS 16
|
|
||||||
#define sve_vl_valid(vl) \
|
|
||||||
((vl) % SVE_VQ_BYTES == 0 && (vl) >= SVE_VL_MIN && (vl) <= SVE_VL_MAX)
|
|
||||||
#define sve_vq_from_vl(vl) ((vl) / SVE_VQ_BYTES)
|
|
||||||
#define sve_vl_from_vq(vq) ((vq) * SVE_VQ_BYTES)
|
|
||||||
#define SVE_SIG_ZREG_SIZE(vq) ((unsigned)(vq) * SVE_VQ_BYTES)
|
|
||||||
#define SVE_SIG_PREG_SIZE(vq) ((unsigned)(vq) * (SVE_VQ_BYTES / 8))
|
|
||||||
#define SVE_SIG_FFR_SIZE(vq) SVE_SIG_PREG_SIZE(vq)
|
|
||||||
#define SVE_SIG_REGS_OFFSET \
|
|
||||||
((sizeof(struct sve_context) + (SVE_VQ_BYTES - 1)) \
|
|
||||||
/ SVE_VQ_BYTES * SVE_VQ_BYTES)
|
|
||||||
#define SVE_SIG_ZREGS_OFFSET SVE_SIG_REGS_OFFSET
|
|
||||||
#define SVE_SIG_ZREG_OFFSET(vq, n) \
|
|
||||||
(SVE_SIG_ZREGS_OFFSET + SVE_SIG_ZREG_SIZE(vq) * (n))
|
|
||||||
#define SVE_SIG_ZREGS_SIZE(vq) \
|
|
||||||
(SVE_SIG_ZREG_OFFSET(vq, SVE_NUM_ZREGS) - SVE_SIG_ZREGS_OFFSET)
|
|
||||||
#define SVE_SIG_PREGS_OFFSET(vq) \
|
|
||||||
(SVE_SIG_ZREGS_OFFSET + SVE_SIG_ZREGS_SIZE(vq))
|
|
||||||
#define SVE_SIG_PREG_OFFSET(vq, n) \
|
|
||||||
(SVE_SIG_PREGS_OFFSET(vq) + SVE_SIG_PREG_SIZE(vq) * (n))
|
|
||||||
#define SVE_SIG_PREGS_SIZE(vq) \
|
|
||||||
(SVE_SIG_PREG_OFFSET(vq, SVE_NUM_PREGS) - SVE_SIG_PREGS_OFFSET(vq))
|
|
||||||
#define SVE_SIG_FFR_OFFSET(vq) \
|
|
||||||
(SVE_SIG_PREGS_OFFSET(vq) + SVE_SIG_PREGS_SIZE(vq))
|
|
||||||
#define SVE_SIG_REGS_SIZE(vq) \
|
|
||||||
(SVE_SIG_FFR_OFFSET(vq) + SVE_SIG_FFR_SIZE(vq) - SVE_SIG_REGS_OFFSET)
|
|
||||||
#define SVE_SIG_CONTEXT_SIZE(vq) (SVE_SIG_REGS_OFFSET + SVE_SIG_REGS_SIZE(vq))
|
|
||||||
#else
|
|
||||||
typedef struct {
|
|
||||||
long double __regs[18+256];
|
|
||||||
} mcontext_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct sigaltstack {
|
|
||||||
void *ss_sp;
|
|
||||||
int ss_flags;
|
|
||||||
size_t ss_size;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct __ucontext {
|
|
||||||
unsigned long uc_flags;
|
|
||||||
struct __ucontext *uc_link;
|
|
||||||
stack_t uc_stack;
|
|
||||||
sigset_t uc_sigmask;
|
|
||||||
mcontext_t uc_mcontext;
|
|
||||||
} ucontext_t;
|
|
||||||
|
|
||||||
#define SA_NOCLDSTOP 1
|
|
||||||
#define SA_NOCLDWAIT 2
|
|
||||||
#define SA_SIGINFO 4
|
|
||||||
#define SA_ONSTACK 0x08000000
|
|
||||||
#define SA_RESTART 0x10000000
|
|
||||||
#define SA_NODEFER 0x40000000
|
|
||||||
#define SA_RESETHAND 0x80000000
|
|
||||||
#define SA_RESTORER 0x04000000
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SIGHUP 1
|
|
||||||
#define SIGINT 2
|
|
||||||
#define SIGQUIT 3
|
|
||||||
#define SIGILL 4
|
|
||||||
#define SIGTRAP 5
|
|
||||||
#define SIGABRT 6
|
|
||||||
#define SIGIOT SIGABRT
|
|
||||||
#define SIGBUS 7
|
|
||||||
#define SIGFPE 8
|
|
||||||
#define SIGKILL 9
|
|
||||||
#define SIGUSR1 10
|
|
||||||
#define SIGSEGV 11
|
|
||||||
#define SIGUSR2 12
|
|
||||||
#define SIGPIPE 13
|
|
||||||
#define SIGALRM 14
|
|
||||||
#define SIGTERM 15
|
|
||||||
#define SIGSTKFLT 16
|
|
||||||
#define SIGCHLD 17
|
|
||||||
#define SIGCONT 18
|
|
||||||
#define SIGSTOP 19
|
|
||||||
#define SIGTSTP 20
|
|
||||||
#define SIGTTIN 21
|
|
||||||
#define SIGTTOU 22
|
|
||||||
#define SIGURG 23
|
|
||||||
#define SIGXCPU 24
|
|
||||||
#define SIGXFSZ 25
|
|
||||||
#define SIGVTALRM 26
|
|
||||||
#define SIGPROF 27
|
|
||||||
#define SIGWINCH 28
|
|
||||||
#define SIGIO 29
|
|
||||||
#define SIGPOLL 29
|
|
||||||
#define SIGPWR 30
|
|
||||||
#define SIGSYS 31
|
|
||||||
#define SIGUNUSED SIGSYS
|
|
||||||
|
|
||||||
#define _NSIG 65
|
|
18
vendor/modernc.org/libc/musl/arch/aarch64/bits/stat.h
generated
vendored
18
vendor/modernc.org/libc/musl/arch/aarch64/bits/stat.h
generated
vendored
@ -1,18 +0,0 @@
|
|||||||
struct stat {
|
|
||||||
dev_t st_dev;
|
|
||||||
ino_t st_ino;
|
|
||||||
mode_t st_mode;
|
|
||||||
nlink_t st_nlink;
|
|
||||||
uid_t st_uid;
|
|
||||||
gid_t st_gid;
|
|
||||||
dev_t st_rdev;
|
|
||||||
unsigned long __pad;
|
|
||||||
off_t st_size;
|
|
||||||
blksize_t st_blksize;
|
|
||||||
int __pad2;
|
|
||||||
blkcnt_t st_blocks;
|
|
||||||
struct timespec st_atim;
|
|
||||||
struct timespec st_mtim;
|
|
||||||
struct timespec st_ctim;
|
|
||||||
unsigned __unused[2];
|
|
||||||
};
|
|
20
vendor/modernc.org/libc/musl/arch/aarch64/bits/stdint.h
generated
vendored
20
vendor/modernc.org/libc/musl/arch/aarch64/bits/stdint.h
generated
vendored
@ -1,20 +0,0 @@
|
|||||||
typedef int32_t int_fast16_t;
|
|
||||||
typedef int32_t int_fast32_t;
|
|
||||||
typedef uint32_t uint_fast16_t;
|
|
||||||
typedef uint32_t uint_fast32_t;
|
|
||||||
|
|
||||||
#define INT_FAST16_MIN INT32_MIN
|
|
||||||
#define INT_FAST32_MIN INT32_MIN
|
|
||||||
|
|
||||||
#define INT_FAST16_MAX INT32_MAX
|
|
||||||
#define INT_FAST32_MAX INT32_MAX
|
|
||||||
|
|
||||||
#define UINT_FAST16_MAX UINT32_MAX
|
|
||||||
#define UINT_FAST32_MAX UINT32_MAX
|
|
||||||
|
|
||||||
#define INTPTR_MIN INT64_MIN
|
|
||||||
#define INTPTR_MAX INT64_MAX
|
|
||||||
#define UINTPTR_MAX UINT64_MAX
|
|
||||||
#define PTRDIFF_MIN INT64_MIN
|
|
||||||
#define PTRDIFF_MAX INT64_MAX
|
|
||||||
#define SIZE_MAX UINT64_MAX
|
|
16
vendor/modernc.org/libc/musl/arch/aarch64/bits/user.h
generated
vendored
16
vendor/modernc.org/libc/musl/arch/aarch64/bits/user.h
generated
vendored
@ -1,16 +0,0 @@
|
|||||||
struct user_regs_struct {
|
|
||||||
unsigned long long regs[31];
|
|
||||||
unsigned long long sp;
|
|
||||||
unsigned long long pc;
|
|
||||||
unsigned long long pstate;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct user_fpsimd_struct {
|
|
||||||
long double vregs[32];
|
|
||||||
unsigned int fpsr;
|
|
||||||
unsigned int fpcr;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ELF_NREG 34
|
|
||||||
typedef unsigned long elf_greg_t, elf_gregset_t[ELF_NREG];
|
|
||||||
typedef struct user_fpsimd_struct elf_fpregset_t;
|
|
15
vendor/modernc.org/libc/musl/arch/aarch64/crt_arch.h
generated
vendored
15
vendor/modernc.org/libc/musl/arch/aarch64/crt_arch.h
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
__asm__(
|
|
||||||
".text \n"
|
|
||||||
".global " START "\n"
|
|
||||||
".type " START ",%function\n"
|
|
||||||
START ":\n"
|
|
||||||
" mov x29, #0\n"
|
|
||||||
" mov x30, #0\n"
|
|
||||||
" mov x0, sp\n"
|
|
||||||
".weak _DYNAMIC\n"
|
|
||||||
".hidden _DYNAMIC\n"
|
|
||||||
" adrp x1, _DYNAMIC\n"
|
|
||||||
" add x1, x1, #:lo12:_DYNAMIC\n"
|
|
||||||
" and sp, x0, #-16\n"
|
|
||||||
" b " START "_c\n"
|
|
||||||
);
|
|
25
vendor/modernc.org/libc/musl/arch/aarch64/fp_arch.h
generated
vendored
25
vendor/modernc.org/libc/musl/arch/aarch64/fp_arch.h
generated
vendored
@ -1,25 +0,0 @@
|
|||||||
#define fp_barrierf fp_barrierf
|
|
||||||
static inline float fp_barrierf(float x)
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("" : "+w"(x));
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define fp_barrier fp_barrier
|
|
||||||
static inline double fp_barrier(double x)
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("" : "+w"(x));
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define fp_force_evalf fp_force_evalf
|
|
||||||
static inline void fp_force_evalf(float x)
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("" : "+w"(x));
|
|
||||||
}
|
|
||||||
|
|
||||||
#define fp_force_eval fp_force_eval
|
|
||||||
static inline void fp_force_eval(double x)
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("" : "+w"(x));
|
|
||||||
}
|
|
21
vendor/modernc.org/libc/musl/arch/aarch64/kstat.h
generated
vendored
21
vendor/modernc.org/libc/musl/arch/aarch64/kstat.h
generated
vendored
@ -1,21 +0,0 @@
|
|||||||
struct kstat {
|
|
||||||
dev_t st_dev;
|
|
||||||
ino_t st_ino;
|
|
||||||
mode_t st_mode;
|
|
||||||
nlink_t st_nlink;
|
|
||||||
uid_t st_uid;
|
|
||||||
gid_t st_gid;
|
|
||||||
dev_t st_rdev;
|
|
||||||
unsigned long __pad;
|
|
||||||
off_t st_size;
|
|
||||||
blksize_t st_blksize;
|
|
||||||
int __pad2;
|
|
||||||
blkcnt_t st_blocks;
|
|
||||||
long st_atime_sec;
|
|
||||||
long st_atime_nsec;
|
|
||||||
long st_mtime_sec;
|
|
||||||
long st_mtime_nsec;
|
|
||||||
long st_ctime_sec;
|
|
||||||
long st_ctime_nsec;
|
|
||||||
unsigned __unused[2];
|
|
||||||
};
|
|
12
vendor/modernc.org/libc/musl/arch/aarch64/pthread_arch.h
generated
vendored
12
vendor/modernc.org/libc/musl/arch/aarch64/pthread_arch.h
generated
vendored
@ -1,12 +0,0 @@
|
|||||||
static inline struct pthread *__pthread_self()
|
|
||||||
{
|
|
||||||
char *self;
|
|
||||||
__asm__ ("mrs %0,tpidr_el0" : "=r"(self));
|
|
||||||
return (void*)(self - sizeof(struct pthread));
|
|
||||||
}
|
|
||||||
|
|
||||||
#define TLS_ABOVE_TP
|
|
||||||
#define GAP_ABOVE_TP 16
|
|
||||||
#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread))
|
|
||||||
|
|
||||||
#define MC_PC pc
|
|
24
vendor/modernc.org/libc/musl/arch/aarch64/reloc.h
generated
vendored
24
vendor/modernc.org/libc/musl/arch/aarch64/reloc.h
generated
vendored
@ -1,24 +0,0 @@
|
|||||||
#if __BYTE_ORDER == __BIG_ENDIAN
|
|
||||||
#define ENDIAN_SUFFIX "_be"
|
|
||||||
#else
|
|
||||||
#define ENDIAN_SUFFIX ""
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define LDSO_ARCH "aarch64" ENDIAN_SUFFIX
|
|
||||||
|
|
||||||
#define NO_LEGACY_INITFINI
|
|
||||||
|
|
||||||
#define TPOFF_K 0
|
|
||||||
|
|
||||||
#define REL_SYMBOLIC R_AARCH64_ABS64
|
|
||||||
#define REL_GOT R_AARCH64_GLOB_DAT
|
|
||||||
#define REL_PLT R_AARCH64_JUMP_SLOT
|
|
||||||
#define REL_RELATIVE R_AARCH64_RELATIVE
|
|
||||||
#define REL_COPY R_AARCH64_COPY
|
|
||||||
#define REL_DTPMOD R_AARCH64_TLS_DTPMOD64
|
|
||||||
#define REL_DTPOFF R_AARCH64_TLS_DTPREL64
|
|
||||||
#define REL_TPOFF R_AARCH64_TLS_TPREL64
|
|
||||||
#define REL_TLSDESC R_AARCH64_TLSDESC
|
|
||||||
|
|
||||||
#define CRTJMP(pc,sp) __asm__ __volatile__( \
|
|
||||||
"mov sp,%1 ; br %0" : : "r"(pc), "r"(sp) : "memory" )
|
|
78
vendor/modernc.org/libc/musl/arch/aarch64/syscall_arch.h
generated
vendored
78
vendor/modernc.org/libc/musl/arch/aarch64/syscall_arch.h
generated
vendored
@ -1,78 +0,0 @@
|
|||||||
#define __SYSCALL_LL_E(x) (x)
|
|
||||||
#define __SYSCALL_LL_O(x) (x)
|
|
||||||
|
|
||||||
#define __asm_syscall(...) do { \
|
|
||||||
__asm__ __volatile__ ( "svc 0" \
|
|
||||||
: "=r"(x0) : __VA_ARGS__ : "memory", "cc"); \
|
|
||||||
return x0; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
inline long __syscall0(long n)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0");
|
|
||||||
__asm_syscall("r"(x8));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall1(long n, long a)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall2(long n, long a, long b)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
register long x1 __asm__("x1") = b;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0), "r"(x1));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall3(long n, long a, long b, long c)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
register long x1 __asm__("x1") = b;
|
|
||||||
register long x2 __asm__("x2") = c;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0), "r"(x1), "r"(x2));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall4(long n, long a, long b, long c, long d)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
register long x1 __asm__("x1") = b;
|
|
||||||
register long x2 __asm__("x2") = c;
|
|
||||||
register long x3 __asm__("x3") = d;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0), "r"(x1), "r"(x2), "r"(x3));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall5(long n, long a, long b, long c, long d, long e)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
register long x1 __asm__("x1") = b;
|
|
||||||
register long x2 __asm__("x2") = c;
|
|
||||||
register long x3 __asm__("x3") = d;
|
|
||||||
register long x4 __asm__("x4") = e;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0), "r"(x1), "r"(x2), "r"(x3), "r"(x4));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
|
|
||||||
{
|
|
||||||
register long x8 __asm__("x8") = n;
|
|
||||||
register long x0 __asm__("x0") = a;
|
|
||||||
register long x1 __asm__("x1") = b;
|
|
||||||
register long x2 __asm__("x2") = c;
|
|
||||||
register long x3 __asm__("x3") = d;
|
|
||||||
register long x4 __asm__("x4") = e;
|
|
||||||
register long x5 __asm__("x5") = f;
|
|
||||||
__asm_syscall("r"(x8), "0"(x0), "r"(x1), "r"(x2), "r"(x3), "r"(x4), "r"(x5));
|
|
||||||
}
|
|
||||||
|
|
||||||
#define VDSO_USEFUL
|
|
||||||
#define VDSO_CGT_SYM "__kernel_clock_gettime"
|
|
||||||
#define VDSO_CGT_VER "LINUX_2.6.39"
|
|
||||||
|
|
||||||
#define IPC_64 0
|
|
109
vendor/modernc.org/libc/musl/arch/arm/atomic_arch.h
generated
vendored
109
vendor/modernc.org/libc/musl/arch/arm/atomic_arch.h
generated
vendored
@ -1,109 +0,0 @@
|
|||||||
#include "libc.h"
|
|
||||||
|
|
||||||
#if __ARM_ARCH_4__ || __ARM_ARCH_4T__ || __ARM_ARCH == 4
|
|
||||||
#define BLX "mov lr,pc\n\tbx"
|
|
||||||
#else
|
|
||||||
#define BLX "blx"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern hidden uintptr_t __a_cas_ptr, __a_barrier_ptr;
|
|
||||||
|
|
||||||
#if ((__ARM_ARCH_6__ || __ARM_ARCH_6K__ || __ARM_ARCH_6KZ__ || __ARM_ARCH_6ZK__) && !__thumb__) \
|
|
||||||
|| __ARM_ARCH_6T2__ || __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7
|
|
||||||
|
|
||||||
#define a_ll a_ll
|
|
||||||
static inline int a_ll(volatile int *p)
|
|
||||||
{
|
|
||||||
int v;
|
|
||||||
__asm__ __volatile__ ("ldrex %0, %1" : "=r"(v) : "Q"(*p));
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define a_sc a_sc
|
|
||||||
static inline int a_sc(volatile int *p, int v)
|
|
||||||
{
|
|
||||||
int r;
|
|
||||||
__asm__ __volatile__ ("strex %0,%2,%1" : "=&r"(r), "=Q"(*p) : "r"(v) : "memory");
|
|
||||||
return !r;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7
|
|
||||||
|
|
||||||
#define a_barrier a_barrier
|
|
||||||
static inline void a_barrier()
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("dmb ish" : : : "memory");
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define a_pre_llsc a_barrier
|
|
||||||
#define a_post_llsc a_barrier
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define a_cas a_cas
|
|
||||||
static inline int a_cas(volatile int *p, int t, int s)
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("TODO");
|
|
||||||
//TODO for (;;) {
|
|
||||||
//TODO register int r0 __asm__("r0") = t;
|
|
||||||
//TODO register int r1 __asm__("r1") = s;
|
|
||||||
//TODO register volatile int *r2 __asm__("r2") = p;
|
|
||||||
//TODO register uintptr_t r3 __asm__("r3") = __a_cas_ptr;
|
|
||||||
//TODO int old;
|
|
||||||
//TODO __asm__ __volatile__ (
|
|
||||||
//TODO BLX " r3"
|
|
||||||
//TODO : "+r"(r0), "+r"(r3) : "r"(r1), "r"(r2)
|
|
||||||
//TODO : "memory", "lr", "ip", "cc" );
|
|
||||||
//TODO if (!r0) return t;
|
|
||||||
//TODO if ((old=*p)!=t) return old;
|
|
||||||
//TODO }
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef a_barrier
|
|
||||||
#define a_barrier a_barrier
|
|
||||||
static inline void a_barrier()
|
|
||||||
{
|
|
||||||
__asm__ __volatile__ ("TODO");
|
|
||||||
//TODO register uintptr_t ip __asm__("ip") = __a_barrier_ptr;
|
|
||||||
//TODO __asm__ __volatile__( BLX " ip" : "+r"(ip) : : "memory", "cc", "lr" );
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define a_crash a_crash
|
|
||||||
static inline void a_crash()
|
|
||||||
{
|
|
||||||
__asm__ __volatile__(
|
|
||||||
#ifndef __thumb__
|
|
||||||
".word 0xe7f000f0"
|
|
||||||
#else
|
|
||||||
".short 0xdeff"
|
|
||||||
#endif
|
|
||||||
: : : "memory");
|
|
||||||
}
|
|
||||||
|
|
||||||
#if __ARM_ARCH >= 5 && (!__thumb__ || __thumb2__)
|
|
||||||
|
|
||||||
#define a_clz_32 a_clz_32
|
|
||||||
static inline int a_clz_32(uint32_t x)
|
|
||||||
{
|
|
||||||
__asm__ ("clz %0, %1" : "=r"(x) : "r"(x));
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if __ARM_ARCH_6T2__ || __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7
|
|
||||||
|
|
||||||
#define a_ctz_32 a_ctz_32
|
|
||||||
static inline int a_ctz_32(uint32_t x)
|
|
||||||
{
|
|
||||||
uint32_t xr;
|
|
||||||
__asm__ ("rbit %0, %1" : "=r"(xr) : "r"(x));
|
|
||||||
return a_clz_32(xr);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
40
vendor/modernc.org/libc/musl/arch/arm/bits/fcntl.h
generated
vendored
40
vendor/modernc.org/libc/musl/arch/arm/bits/fcntl.h
generated
vendored
@ -1,40 +0,0 @@
|
|||||||
#define O_CREAT 0100
|
|
||||||
#define O_EXCL 0200
|
|
||||||
#define O_NOCTTY 0400
|
|
||||||
#define O_TRUNC 01000
|
|
||||||
#define O_APPEND 02000
|
|
||||||
#define O_NONBLOCK 04000
|
|
||||||
#define O_DSYNC 010000
|
|
||||||
#define O_SYNC 04010000
|
|
||||||
#define O_RSYNC 04010000
|
|
||||||
#define O_DIRECTORY 040000
|
|
||||||
#define O_NOFOLLOW 0100000
|
|
||||||
#define O_CLOEXEC 02000000
|
|
||||||
|
|
||||||
#define O_ASYNC 020000
|
|
||||||
#define O_DIRECT 0200000
|
|
||||||
#define O_LARGEFILE 0400000
|
|
||||||
#define O_NOATIME 01000000
|
|
||||||
#define O_PATH 010000000
|
|
||||||
#define O_TMPFILE 020040000
|
|
||||||
#define O_NDELAY O_NONBLOCK
|
|
||||||
|
|
||||||
#define F_DUPFD 0
|
|
||||||
#define F_GETFD 1
|
|
||||||
#define F_SETFD 2
|
|
||||||
#define F_GETFL 3
|
|
||||||
#define F_SETFL 4
|
|
||||||
|
|
||||||
#define F_SETOWN 8
|
|
||||||
#define F_GETOWN 9
|
|
||||||
#define F_SETSIG 10
|
|
||||||
#define F_GETSIG 11
|
|
||||||
|
|
||||||
#define F_GETLK 12
|
|
||||||
#define F_SETLK 13
|
|
||||||
#define F_SETLKW 14
|
|
||||||
|
|
||||||
#define F_SETOWN_EX 15
|
|
||||||
#define F_GETOWN_EX 16
|
|
||||||
|
|
||||||
#define F_GETOWNER_UIDS 17
|
|
23
vendor/modernc.org/libc/musl/arch/arm/bits/fenv.h
generated
vendored
23
vendor/modernc.org/libc/musl/arch/arm/bits/fenv.h
generated
vendored
@ -1,23 +0,0 @@
|
|||||||
#ifndef __ARM_PCS_VFP
|
|
||||||
#define FE_ALL_EXCEPT 0
|
|
||||||
#define FE_TONEAREST 0
|
|
||||||
#else
|
|
||||||
#define FE_INVALID 1
|
|
||||||
#define FE_DIVBYZERO 2
|
|
||||||
#define FE_OVERFLOW 4
|
|
||||||
#define FE_UNDERFLOW 8
|
|
||||||
#define FE_INEXACT 16
|
|
||||||
#define FE_ALL_EXCEPT 31
|
|
||||||
#define FE_TONEAREST 0
|
|
||||||
#define FE_DOWNWARD 0x800000
|
|
||||||
#define FE_UPWARD 0x400000
|
|
||||||
#define FE_TOWARDZERO 0xc00000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef unsigned long fexcept_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
unsigned long __cw;
|
|
||||||
} fenv_t;
|
|
||||||
|
|
||||||
#define FE_DFL_ENV ((const fenv_t *) -1)
|
|
16
vendor/modernc.org/libc/musl/arch/arm/bits/float.h
generated
vendored
16
vendor/modernc.org/libc/musl/arch/arm/bits/float.h
generated
vendored
@ -1,16 +0,0 @@
|
|||||||
#define FLT_EVAL_METHOD 0
|
|
||||||
|
|
||||||
#define LDBL_TRUE_MIN 4.94065645841246544177e-324L
|
|
||||||
#define LDBL_MIN 2.22507385850720138309e-308L
|
|
||||||
#define LDBL_MAX 1.79769313486231570815e+308L
|
|
||||||
#define LDBL_EPSILON 2.22044604925031308085e-16L
|
|
||||||
|
|
||||||
#define LDBL_MANT_DIG 53
|
|
||||||
#define LDBL_MIN_EXP (-1021)
|
|
||||||
#define LDBL_MAX_EXP 1024
|
|
||||||
|
|
||||||
#define LDBL_DIG 15
|
|
||||||
#define LDBL_MIN_10_EXP (-307)
|
|
||||||
#define LDBL_MAX_10_EXP 308
|
|
||||||
|
|
||||||
#define DECIMAL_DIG 17
|
|
53
vendor/modernc.org/libc/musl/arch/arm/bits/hwcap.h
generated
vendored
53
vendor/modernc.org/libc/musl/arch/arm/bits/hwcap.h
generated
vendored
@ -1,53 +0,0 @@
|
|||||||
#define HWCAP_SWP (1 << 0)
|
|
||||||
#define HWCAP_HALF (1 << 1)
|
|
||||||
#define HWCAP_THUMB (1 << 2)
|
|
||||||
#define HWCAP_26BIT (1 << 3)
|
|
||||||
#define HWCAP_FAST_MULT (1 << 4)
|
|
||||||
#define HWCAP_FPA (1 << 5)
|
|
||||||
#define HWCAP_VFP (1 << 6)
|
|
||||||
#define HWCAP_EDSP (1 << 7)
|
|
||||||
#define HWCAP_JAVA (1 << 8)
|
|
||||||
#define HWCAP_IWMMXT (1 << 9)
|
|
||||||
#define HWCAP_CRUNCH (1 << 10)
|
|
||||||
#define HWCAP_THUMBEE (1 << 11)
|
|
||||||
#define HWCAP_NEON (1 << 12)
|
|
||||||
#define HWCAP_VFPv3 (1 << 13)
|
|
||||||
#define HWCAP_VFPv3D16 (1 << 14)
|
|
||||||
#define HWCAP_TLS (1 << 15)
|
|
||||||
#define HWCAP_VFPv4 (1 << 16)
|
|
||||||
#define HWCAP_IDIVA (1 << 17)
|
|
||||||
#define HWCAP_IDIVT (1 << 18)
|
|
||||||
#define HWCAP_VFPD32 (1 << 19)
|
|
||||||
#define HWCAP_IDIV (HWCAP_IDIVA | HWCAP_IDIVT)
|
|
||||||
#define HWCAP_LPAE (1 << 20)
|
|
||||||
#define HWCAP_EVTSTRM (1 << 21)
|
|
||||||
|
|
||||||
#define HWCAP2_AES (1 << 0)
|
|
||||||
#define HWCAP2_PMULL (1 << 1)
|
|
||||||
#define HWCAP2_SHA1 (1 << 2)
|
|
||||||
#define HWCAP2_SHA2 (1 << 3)
|
|
||||||
#define HWCAP2_CRC32 (1 << 4)
|
|
||||||
|
|
||||||
#define HWCAP_ARM_SWP (1 << 0)
|
|
||||||
#define HWCAP_ARM_HALF (1 << 1)
|
|
||||||
#define HWCAP_ARM_THUMB (1 << 2)
|
|
||||||
#define HWCAP_ARM_26BIT (1 << 3)
|
|
||||||
#define HWCAP_ARM_FAST_MULT (1 << 4)
|
|
||||||
#define HWCAP_ARM_FPA (1 << 5)
|
|
||||||
#define HWCAP_ARM_VFP (1 << 6)
|
|
||||||
#define HWCAP_ARM_EDSP (1 << 7)
|
|
||||||
#define HWCAP_ARM_JAVA (1 << 8)
|
|
||||||
#define HWCAP_ARM_IWMMXT (1 << 9)
|
|
||||||
#define HWCAP_ARM_CRUNCH (1 << 10)
|
|
||||||
#define HWCAP_ARM_THUMBEE (1 << 11)
|
|
||||||
#define HWCAP_ARM_NEON (1 << 12)
|
|
||||||
#define HWCAP_ARM_VFPv3 (1 << 13)
|
|
||||||
#define HWCAP_ARM_VFPv3D16 (1 << 14)
|
|
||||||
#define HWCAP_ARM_TLS (1 << 15)
|
|
||||||
#define HWCAP_ARM_VFPv4 (1 << 16)
|
|
||||||
#define HWCAP_ARM_IDIVA (1 << 17)
|
|
||||||
#define HWCAP_ARM_IDIVT (1 << 18)
|
|
||||||
#define HWCAP_ARM_VFPD32 (1 << 19)
|
|
||||||
#define HWCAP_ARM_IDIV (HWCAP_ARM_IDIVA | HWCAP_ARM_IDIVT)
|
|
||||||
#define HWCAP_ARM_LPAE (1 << 20)
|
|
||||||
#define HWCAP_ARM_EVTSTRM (1 << 21)
|
|
2
vendor/modernc.org/libc/musl/arch/arm/bits/ioctl_fix.h
generated
vendored
2
vendor/modernc.org/libc/musl/arch/arm/bits/ioctl_fix.h
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
#undef FIOQSIZE
|
|
||||||
#define FIOQSIZE 0x545e
|
|
1
vendor/modernc.org/libc/musl/arch/arm/bits/ipcstat.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/arm/bits/ipcstat.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
#define IPC_STAT 0x102
|
|
18
vendor/modernc.org/libc/musl/arch/arm/bits/msg.h
generated
vendored
18
vendor/modernc.org/libc/musl/arch/arm/bits/msg.h
generated
vendored
@ -1,18 +0,0 @@
|
|||||||
struct msqid_ds {
|
|
||||||
struct ipc_perm msg_perm;
|
|
||||||
unsigned long __msg_stime_lo;
|
|
||||||
unsigned long __msg_stime_hi;
|
|
||||||
unsigned long __msg_rtime_lo;
|
|
||||||
unsigned long __msg_rtime_hi;
|
|
||||||
unsigned long __msg_ctime_lo;
|
|
||||||
unsigned long __msg_ctime_hi;
|
|
||||||
unsigned long msg_cbytes;
|
|
||||||
msgqnum_t msg_qnum;
|
|
||||||
msglen_t msg_qbytes;
|
|
||||||
pid_t msg_lspid;
|
|
||||||
pid_t msg_lrpid;
|
|
||||||
unsigned long __unused[2];
|
|
||||||
time_t msg_stime;
|
|
||||||
time_t msg_rtime;
|
|
||||||
time_t msg_ctime;
|
|
||||||
};
|
|
2
vendor/modernc.org/libc/musl/arch/arm/bits/posix.h
generated
vendored
2
vendor/modernc.org/libc/musl/arch/arm/bits/posix.h
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
#define _POSIX_V6_ILP32_OFFBIG 1
|
|
||||||
#define _POSIX_V7_ILP32_OFFBIG 1
|
|
25
vendor/modernc.org/libc/musl/arch/arm/bits/ptrace.h
generated
vendored
25
vendor/modernc.org/libc/musl/arch/arm/bits/ptrace.h
generated
vendored
@ -1,25 +0,0 @@
|
|||||||
#define PTRACE_GETWMMXREGS 18
|
|
||||||
#define PTRACE_SETWMMXREGS 19
|
|
||||||
#define PTRACE_GET_THREAD_AREA 22
|
|
||||||
#define PTRACE_SET_SYSCALL 23
|
|
||||||
#define PTRACE_GETCRUNCHREGS 25
|
|
||||||
#define PTRACE_SETCRUNCHREGS 26
|
|
||||||
#define PTRACE_GETVFPREGS 27
|
|
||||||
#define PTRACE_SETVFPREGS 28
|
|
||||||
#define PTRACE_GETHBPREGS 29
|
|
||||||
#define PTRACE_SETHBPREGS 30
|
|
||||||
#define PTRACE_GETFDPIC 31
|
|
||||||
#define PTRACE_GETFDPIC_EXEC 0
|
|
||||||
#define PTRACE_GETFDPIC_INTERP 1
|
|
||||||
|
|
||||||
#define PT_GETWMMXREGS PTRACE_GETWMMXREGS
|
|
||||||
#define PT_SETWMMXREGS PTRACE_SETWMMXREGS
|
|
||||||
#define PT_GET_THREAD_AREA PTRACE_GET_THREAD_AREA
|
|
||||||
#define PT_SET_SYSCALL PTRACE_SET_SYSCALL
|
|
||||||
#define PT_GETCRUNCHREGS PTRACE_GETCRUNCHREGS
|
|
||||||
#define PT_SETCRUNCHREGS PTRACE_SETCRUNCHREGS
|
|
||||||
#define PT_GETVFPREGS PTRACE_GETVFPREGS
|
|
||||||
#define PT_SETVFPREGS PTRACE_SETVFPREGS
|
|
||||||
#define PT_GETHBPREGS PTRACE_GETHBPREGS
|
|
||||||
#define PT_SETHBPREGS PTRACE_SETHBPREGS
|
|
||||||
#define PT_GETFDPIC PTRACE_GETFDPIC
|
|
3
vendor/modernc.org/libc/musl/arch/arm/bits/reg.h
generated
vendored
3
vendor/modernc.org/libc/musl/arch/arm/bits/reg.h
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
#undef __WORDSIZE
|
|
||||||
#define __WORDSIZE 32
|
|
||||||
/* FIXME */
|
|
18
vendor/modernc.org/libc/musl/arch/arm/bits/sem.h
generated
vendored
18
vendor/modernc.org/libc/musl/arch/arm/bits/sem.h
generated
vendored
@ -1,18 +0,0 @@
|
|||||||
struct semid_ds {
|
|
||||||
struct ipc_perm sem_perm;
|
|
||||||
unsigned long __sem_otime_lo;
|
|
||||||
unsigned long __sem_otime_hi;
|
|
||||||
unsigned long __sem_ctime_lo;
|
|
||||||
unsigned long __sem_ctime_hi;
|
|
||||||
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
|
||||||
unsigned short sem_nsems;
|
|
||||||
char __sem_nsems_pad[sizeof(long)-sizeof(short)];
|
|
||||||
#else
|
|
||||||
char __sem_nsems_pad[sizeof(long)-sizeof(short)];
|
|
||||||
unsigned short sem_nsems;
|
|
||||||
#endif
|
|
||||||
long __unused3;
|
|
||||||
long __unused4;
|
|
||||||
time_t sem_otime;
|
|
||||||
time_t sem_ctime;
|
|
||||||
};
|
|
1
vendor/modernc.org/libc/musl/arch/arm/bits/setjmp.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/arm/bits/setjmp.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
typedef unsigned long long __jmp_buf[32];
|
|
31
vendor/modernc.org/libc/musl/arch/arm/bits/shm.h
generated
vendored
31
vendor/modernc.org/libc/musl/arch/arm/bits/shm.h
generated
vendored
@ -1,31 +0,0 @@
|
|||||||
#define SHMLBA 4096
|
|
||||||
|
|
||||||
struct shmid_ds {
|
|
||||||
struct ipc_perm shm_perm;
|
|
||||||
size_t shm_segsz;
|
|
||||||
unsigned long __shm_atime_lo;
|
|
||||||
unsigned long __shm_atime_hi;
|
|
||||||
unsigned long __shm_dtime_lo;
|
|
||||||
unsigned long __shm_dtime_hi;
|
|
||||||
unsigned long __shm_ctime_lo;
|
|
||||||
unsigned long __shm_ctime_hi;
|
|
||||||
pid_t shm_cpid;
|
|
||||||
pid_t shm_lpid;
|
|
||||||
unsigned long shm_nattch;
|
|
||||||
unsigned long __pad1;
|
|
||||||
unsigned long __pad2;
|
|
||||||
unsigned long __pad3;
|
|
||||||
time_t shm_atime;
|
|
||||||
time_t shm_dtime;
|
|
||||||
time_t shm_ctime;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct shminfo {
|
|
||||||
unsigned long shmmax, shmmin, shmmni, shmseg, shmall, __unused[4];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct shm_info {
|
|
||||||
int __used_ids;
|
|
||||||
unsigned long shm_tot, shm_rss, shm_swp;
|
|
||||||
unsigned long __swap_attempts, __swap_successes;
|
|
||||||
};
|
|
86
vendor/modernc.org/libc/musl/arch/arm/bits/signal.h
generated
vendored
86
vendor/modernc.org/libc/musl/arch/arm/bits/signal.h
generated
vendored
@ -1,86 +0,0 @@
|
|||||||
#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|
|
||||||
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
|
|
||||||
#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
#define MINSIGSTKSZ 2048
|
|
||||||
#define SIGSTKSZ 8192
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
|
|
||||||
typedef int greg_t, gregset_t[18];
|
|
||||||
typedef struct sigcontext {
|
|
||||||
unsigned long trap_no, error_code, oldmask;
|
|
||||||
unsigned long arm_r0, arm_r1, arm_r2, arm_r3;
|
|
||||||
unsigned long arm_r4, arm_r5, arm_r6, arm_r7;
|
|
||||||
unsigned long arm_r8, arm_r9, arm_r10, arm_fp;
|
|
||||||
unsigned long arm_ip, arm_sp, arm_lr, arm_pc;
|
|
||||||
unsigned long arm_cpsr, fault_address;
|
|
||||||
} mcontext_t;
|
|
||||||
#else
|
|
||||||
typedef struct {
|
|
||||||
unsigned long __regs[21];
|
|
||||||
} mcontext_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct sigaltstack {
|
|
||||||
void *ss_sp;
|
|
||||||
int ss_flags;
|
|
||||||
size_t ss_size;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct __ucontext {
|
|
||||||
unsigned long uc_flags;
|
|
||||||
struct __ucontext *uc_link;
|
|
||||||
stack_t uc_stack;
|
|
||||||
mcontext_t uc_mcontext;
|
|
||||||
sigset_t uc_sigmask;
|
|
||||||
unsigned long long uc_regspace[64];
|
|
||||||
} ucontext_t;
|
|
||||||
|
|
||||||
#define SA_NOCLDSTOP 1
|
|
||||||
#define SA_NOCLDWAIT 2
|
|
||||||
#define SA_SIGINFO 4
|
|
||||||
#define SA_ONSTACK 0x08000000
|
|
||||||
#define SA_RESTART 0x10000000
|
|
||||||
#define SA_NODEFER 0x40000000
|
|
||||||
#define SA_RESETHAND 0x80000000
|
|
||||||
#define SA_RESTORER 0x04000000
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SIGHUP 1
|
|
||||||
#define SIGINT 2
|
|
||||||
#define SIGQUIT 3
|
|
||||||
#define SIGILL 4
|
|
||||||
#define SIGTRAP 5
|
|
||||||
#define SIGABRT 6
|
|
||||||
#define SIGIOT SIGABRT
|
|
||||||
#define SIGBUS 7
|
|
||||||
#define SIGFPE 8
|
|
||||||
#define SIGKILL 9
|
|
||||||
#define SIGUSR1 10
|
|
||||||
#define SIGSEGV 11
|
|
||||||
#define SIGUSR2 12
|
|
||||||
#define SIGPIPE 13
|
|
||||||
#define SIGALRM 14
|
|
||||||
#define SIGTERM 15
|
|
||||||
#define SIGSTKFLT 16
|
|
||||||
#define SIGCHLD 17
|
|
||||||
#define SIGCONT 18
|
|
||||||
#define SIGSTOP 19
|
|
||||||
#define SIGTSTP 20
|
|
||||||
#define SIGTTIN 21
|
|
||||||
#define SIGTTOU 22
|
|
||||||
#define SIGURG 23
|
|
||||||
#define SIGXCPU 24
|
|
||||||
#define SIGXFSZ 25
|
|
||||||
#define SIGVTALRM 26
|
|
||||||
#define SIGPROF 27
|
|
||||||
#define SIGWINCH 28
|
|
||||||
#define SIGIO 29
|
|
||||||
#define SIGPOLL 29
|
|
||||||
#define SIGPWR 30
|
|
||||||
#define SIGSYS 31
|
|
||||||
#define SIGUNUSED SIGSYS
|
|
||||||
|
|
||||||
#define _NSIG 65
|
|
25
vendor/modernc.org/libc/musl/arch/arm/bits/stat.h
generated
vendored
25
vendor/modernc.org/libc/musl/arch/arm/bits/stat.h
generated
vendored
@ -1,25 +0,0 @@
|
|||||||
/* copied from kernel definition, but with padding replaced
|
|
||||||
* by the corresponding correctly-sized userspace types. */
|
|
||||||
|
|
||||||
struct stat {
|
|
||||||
dev_t st_dev;
|
|
||||||
int __st_dev_padding;
|
|
||||||
long __st_ino_truncated;
|
|
||||||
mode_t st_mode;
|
|
||||||
nlink_t st_nlink;
|
|
||||||
uid_t st_uid;
|
|
||||||
gid_t st_gid;
|
|
||||||
dev_t st_rdev;
|
|
||||||
int __st_rdev_padding;
|
|
||||||
off_t st_size;
|
|
||||||
blksize_t st_blksize;
|
|
||||||
blkcnt_t st_blocks;
|
|
||||||
struct {
|
|
||||||
long tv_sec;
|
|
||||||
long tv_nsec;
|
|
||||||
} __st_atim32, __st_mtim32, __st_ctim32;
|
|
||||||
ino_t st_ino;
|
|
||||||
struct timespec st_atim;
|
|
||||||
struct timespec st_mtim;
|
|
||||||
struct timespec st_ctim;
|
|
||||||
};
|
|
20
vendor/modernc.org/libc/musl/arch/arm/bits/stdint.h
generated
vendored
20
vendor/modernc.org/libc/musl/arch/arm/bits/stdint.h
generated
vendored
@ -1,20 +0,0 @@
|
|||||||
typedef int32_t int_fast16_t;
|
|
||||||
typedef int32_t int_fast32_t;
|
|
||||||
typedef uint32_t uint_fast16_t;
|
|
||||||
typedef uint32_t uint_fast32_t;
|
|
||||||
|
|
||||||
#define INT_FAST16_MIN INT32_MIN
|
|
||||||
#define INT_FAST32_MIN INT32_MIN
|
|
||||||
|
|
||||||
#define INT_FAST16_MAX INT32_MAX
|
|
||||||
#define INT_FAST32_MAX INT32_MAX
|
|
||||||
|
|
||||||
#define UINT_FAST16_MAX UINT32_MAX
|
|
||||||
#define UINT_FAST32_MAX UINT32_MAX
|
|
||||||
|
|
||||||
#define INTPTR_MIN INT32_MIN
|
|
||||||
#define INTPTR_MAX INT32_MAX
|
|
||||||
#define UINTPTR_MAX UINT32_MAX
|
|
||||||
#define PTRDIFF_MIN INT32_MIN
|
|
||||||
#define PTRDIFF_MAX INT32_MAX
|
|
||||||
#define SIZE_MAX UINT32_MAX
|
|
36
vendor/modernc.org/libc/musl/arch/arm/bits/user.h
generated
vendored
36
vendor/modernc.org/libc/musl/arch/arm/bits/user.h
generated
vendored
@ -1,36 +0,0 @@
|
|||||||
typedef struct user_fpregs {
|
|
||||||
struct fp_reg {
|
|
||||||
unsigned sign1:1;
|
|
||||||
unsigned unused:15;
|
|
||||||
unsigned sign2:1;
|
|
||||||
unsigned exponent:14;
|
|
||||||
unsigned j:1;
|
|
||||||
unsigned mantissa1:31;
|
|
||||||
unsigned mantissa0:32;
|
|
||||||
} fpregs[8];
|
|
||||||
unsigned fpsr:32;
|
|
||||||
unsigned fpcr:32;
|
|
||||||
unsigned char ftype[8];
|
|
||||||
unsigned int init_flag;
|
|
||||||
} elf_fpregset_t;
|
|
||||||
|
|
||||||
struct user_regs {
|
|
||||||
unsigned long uregs[18];
|
|
||||||
};
|
|
||||||
#define ELF_NGREG 18
|
|
||||||
typedef unsigned long elf_greg_t, elf_gregset_t[ELF_NGREG];
|
|
||||||
|
|
||||||
struct user {
|
|
||||||
struct user_regs regs;
|
|
||||||
int u_fpvalid;
|
|
||||||
unsigned long u_tsize, u_dsize, u_ssize;
|
|
||||||
unsigned long start_code, start_stack;
|
|
||||||
long signal;
|
|
||||||
int reserved;
|
|
||||||
struct user_regs *u_ar0;
|
|
||||||
unsigned long magic;
|
|
||||||
char u_comm[32];
|
|
||||||
int u_debugreg[8];
|
|
||||||
struct user_fpregs u_fp;
|
|
||||||
struct user_fpregs *u_fp0;
|
|
||||||
};
|
|
18
vendor/modernc.org/libc/musl/arch/arm/crt_arch.h
generated
vendored
18
vendor/modernc.org/libc/musl/arch/arm/crt_arch.h
generated
vendored
@ -1,18 +0,0 @@
|
|||||||
__asm__(
|
|
||||||
".text \n"
|
|
||||||
".global " START " \n"
|
|
||||||
".type " START ",%function \n"
|
|
||||||
START ": \n"
|
|
||||||
" mov fp, #0 \n"
|
|
||||||
" mov lr, #0 \n"
|
|
||||||
" ldr a2, 1f \n"
|
|
||||||
" add a2, pc, a2 \n"
|
|
||||||
" mov a1, sp \n"
|
|
||||||
"2: and ip, a1, #-16 \n"
|
|
||||||
" mov sp, ip \n"
|
|
||||||
" bl " START "_c \n"
|
|
||||||
".weak _DYNAMIC \n"
|
|
||||||
".hidden _DYNAMIC \n"
|
|
||||||
".align 2 \n"
|
|
||||||
"1: .word _DYNAMIC-2b \n"
|
|
||||||
);
|
|
21
vendor/modernc.org/libc/musl/arch/arm/kstat.h
generated
vendored
21
vendor/modernc.org/libc/musl/arch/arm/kstat.h
generated
vendored
@ -1,21 +0,0 @@
|
|||||||
struct kstat {
|
|
||||||
dev_t st_dev;
|
|
||||||
int __st_dev_padding;
|
|
||||||
long __st_ino_truncated;
|
|
||||||
mode_t st_mode;
|
|
||||||
nlink_t st_nlink;
|
|
||||||
uid_t st_uid;
|
|
||||||
gid_t st_gid;
|
|
||||||
dev_t st_rdev;
|
|
||||||
int __st_rdev_padding;
|
|
||||||
off_t st_size;
|
|
||||||
blksize_t st_blksize;
|
|
||||||
blkcnt_t st_blocks;
|
|
||||||
long st_atime_sec;
|
|
||||||
long st_atime_nsec;
|
|
||||||
long st_mtime_sec;
|
|
||||||
long st_mtime_nsec;
|
|
||||||
long st_ctime_sec;
|
|
||||||
long st_ctime_nsec;
|
|
||||||
ino_t st_ino;
|
|
||||||
};
|
|
33
vendor/modernc.org/libc/musl/arch/arm/pthread_arch.h
generated
vendored
33
vendor/modernc.org/libc/musl/arch/arm/pthread_arch.h
generated
vendored
@ -1,33 +0,0 @@
|
|||||||
#if ((__ARM_ARCH_6K__ || __ARM_ARCH_6KZ__ || __ARM_ARCH_6ZK__) && !__thumb__) \
|
|
||||||
|| __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7
|
|
||||||
|
|
||||||
static inline pthread_t __pthread_self()
|
|
||||||
{
|
|
||||||
char *p;
|
|
||||||
__asm__ ( "mrc p15,0,%0,c13,c0,3" : "=r"(p) );
|
|
||||||
return (void *)(p-sizeof(struct pthread));
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#if __ARM_ARCH_4__ || __ARM_ARCH_4T__ || __ARM_ARCH == 4
|
|
||||||
#define BLX "mov lr,pc\n\tbx"
|
|
||||||
#else
|
|
||||||
#define BLX "blx"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static inline pthread_t __pthread_self()
|
|
||||||
{
|
|
||||||
extern hidden uintptr_t __a_gettp_ptr;
|
|
||||||
register uintptr_t p __asm__("r0");
|
|
||||||
__asm__ ( BLX " %1" : "=r"(p) : "r"(__a_gettp_ptr) : "cc", "lr" );
|
|
||||||
return (void *)(p-sizeof(struct pthread));
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define TLS_ABOVE_TP
|
|
||||||
#define GAP_ABOVE_TP 8
|
|
||||||
#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread))
|
|
||||||
|
|
||||||
#define MC_PC arm_pc
|
|
32
vendor/modernc.org/libc/musl/arch/arm/reloc.h
generated
vendored
32
vendor/modernc.org/libc/musl/arch/arm/reloc.h
generated
vendored
@ -1,32 +0,0 @@
|
|||||||
#if __BYTE_ORDER == __BIG_ENDIAN
|
|
||||||
#define ENDIAN_SUFFIX "eb"
|
|
||||||
#else
|
|
||||||
#define ENDIAN_SUFFIX ""
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if __ARM_PCS_VFP
|
|
||||||
#define FP_SUFFIX "hf"
|
|
||||||
#else
|
|
||||||
#define FP_SUFFIX ""
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define LDSO_ARCH "arm" ENDIAN_SUFFIX FP_SUFFIX
|
|
||||||
|
|
||||||
#define NO_LEGACY_INITFINI
|
|
||||||
|
|
||||||
#define TPOFF_K 0
|
|
||||||
|
|
||||||
#define REL_SYMBOLIC R_ARM_ABS32
|
|
||||||
#define REL_GOT R_ARM_GLOB_DAT
|
|
||||||
#define REL_PLT R_ARM_JUMP_SLOT
|
|
||||||
#define REL_RELATIVE R_ARM_RELATIVE
|
|
||||||
#define REL_COPY R_ARM_COPY
|
|
||||||
#define REL_DTPMOD R_ARM_TLS_DTPMOD32
|
|
||||||
#define REL_DTPOFF R_ARM_TLS_DTPOFF32
|
|
||||||
#define REL_TPOFF R_ARM_TLS_TPOFF32
|
|
||||||
#define REL_TLSDESC R_ARM_TLS_DESC
|
|
||||||
|
|
||||||
#define TLSDESC_BACKWARDS
|
|
||||||
|
|
||||||
#define CRTJMP(pc,sp) __asm__ __volatile__( \
|
|
||||||
"mov sp,%1 ; bx %0" : : "r"(pc), "r"(sp) : "memory" )
|
|
103
vendor/modernc.org/libc/musl/arch/arm/syscall_arch.h
generated
vendored
103
vendor/modernc.org/libc/musl/arch/arm/syscall_arch.h
generated
vendored
@ -1,103 +0,0 @@
|
|||||||
#define __SYSCALL_LL_E(x) \
|
|
||||||
((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
|
|
||||||
((union { long long ll; long l[2]; }){ .ll = x }).l[1]
|
|
||||||
#define __SYSCALL_LL_O(x) 0, __SYSCALL_LL_E((x))
|
|
||||||
|
|
||||||
#ifdef __thumb__
|
|
||||||
|
|
||||||
/* Avoid use of r7 in asm constraints when producing thumb code,
|
|
||||||
* since it's reserved as frame pointer and might not be supported. */
|
|
||||||
#define __ASM____R7__
|
|
||||||
#define __asm_syscall(...) do { \
|
|
||||||
__asm__ __volatile__ ( "mov %1,r7 ; mov r7,%2 ; svc 0 ; mov r7,%1" \
|
|
||||||
: "=r"(r0), "=&r"((int){0}) : __VA_ARGS__ : "memory"); \
|
|
||||||
return r0; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define __ASM____R7__ __asm__("r7")
|
|
||||||
#define __asm_syscall(...) do { \
|
|
||||||
__asm__ __volatile__ ( "svc 0" \
|
|
||||||
: "=r"(r0) : __VA_ARGS__ : "memory"); \
|
|
||||||
return r0; \
|
|
||||||
} while (0)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* For thumb2, we can allow 8-bit immediate syscall numbers, saving a
|
|
||||||
* register in the above dance around r7. Does not work for thumb1 where
|
|
||||||
* only movs, not mov, supports immediates, and we can't use movs because
|
|
||||||
* it doesn't support high regs. */
|
|
||||||
#ifdef __thumb2__
|
|
||||||
#define R7_OPERAND "rI"(r7)
|
|
||||||
#else
|
|
||||||
#define R7_OPERAND "r"(r7)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
inline long __syscall0(long n)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0");
|
|
||||||
__asm_syscall(R7_OPERAND);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall1(long n, long a)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall2(long n, long a, long b)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
register long r1 __asm__("r1") = b;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall3(long n, long a, long b, long c)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
register long r1 __asm__("r1") = b;
|
|
||||||
register long r2 __asm__("r2") = c;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall4(long n, long a, long b, long c, long d)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
register long r1 __asm__("r1") = b;
|
|
||||||
register long r2 __asm__("r2") = c;
|
|
||||||
register long r3 __asm__("r3") = d;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall5(long n, long a, long b, long c, long d, long e)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
register long r1 __asm__("r1") = b;
|
|
||||||
register long r2 __asm__("r2") = c;
|
|
||||||
register long r3 __asm__("r3") = d;
|
|
||||||
register long r4 __asm__("r4") = e;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3), "r"(r4));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
|
|
||||||
{
|
|
||||||
register long r7 __ASM____R7__ = n;
|
|
||||||
register long r0 __asm__("r0") = a;
|
|
||||||
register long r1 __asm__("r1") = b;
|
|
||||||
register long r2 __asm__("r2") = c;
|
|
||||||
register long r3 __asm__("r3") = d;
|
|
||||||
register long r4 __asm__("r4") = e;
|
|
||||||
register long r5 __asm__("r5") = f;
|
|
||||||
__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3), "r"(r4), "r"(r5));
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SYSCALL_FADVISE_6_ARG
|
|
||||||
|
|
||||||
#define SYSCALL_IPC_BROKEN_MODE
|
|
11
vendor/modernc.org/libc/musl/arch/generic/bits/dirent.h
generated
vendored
11
vendor/modernc.org/libc/musl/arch/generic/bits/dirent.h
generated
vendored
@ -1,11 +0,0 @@
|
|||||||
#define _DIRENT_HAVE_D_RECLEN
|
|
||||||
#define _DIRENT_HAVE_D_OFF
|
|
||||||
#define _DIRENT_HAVE_D_TYPE
|
|
||||||
|
|
||||||
struct dirent {
|
|
||||||
ino_t d_ino;
|
|
||||||
off_t d_off;
|
|
||||||
unsigned short d_reclen;
|
|
||||||
unsigned char d_type;
|
|
||||||
char d_name[256];
|
|
||||||
};
|
|
134
vendor/modernc.org/libc/musl/arch/generic/bits/errno.h
generated
vendored
134
vendor/modernc.org/libc/musl/arch/generic/bits/errno.h
generated
vendored
@ -1,134 +0,0 @@
|
|||||||
#define EPERM 1
|
|
||||||
#define ENOENT 2
|
|
||||||
#define ESRCH 3
|
|
||||||
#define EINTR 4
|
|
||||||
#define EIO 5
|
|
||||||
#define ENXIO 6
|
|
||||||
#define E2BIG 7
|
|
||||||
#define ENOEXEC 8
|
|
||||||
#define EBADF 9
|
|
||||||
#define ECHILD 10
|
|
||||||
#define EAGAIN 11
|
|
||||||
#define ENOMEM 12
|
|
||||||
#define EACCES 13
|
|
||||||
#define EFAULT 14
|
|
||||||
#define ENOTBLK 15
|
|
||||||
#define EBUSY 16
|
|
||||||
#define EEXIST 17
|
|
||||||
#define EXDEV 18
|
|
||||||
#define ENODEV 19
|
|
||||||
#define ENOTDIR 20
|
|
||||||
#define EISDIR 21
|
|
||||||
#define EINVAL 22
|
|
||||||
#define ENFILE 23
|
|
||||||
#define EMFILE 24
|
|
||||||
#define ENOTTY 25
|
|
||||||
#define ETXTBSY 26
|
|
||||||
#define EFBIG 27
|
|
||||||
#define ENOSPC 28
|
|
||||||
#define ESPIPE 29
|
|
||||||
#define EROFS 30
|
|
||||||
#define EMLINK 31
|
|
||||||
#define EPIPE 32
|
|
||||||
#define EDOM 33
|
|
||||||
#define ERANGE 34
|
|
||||||
#define EDEADLK 35
|
|
||||||
#define ENAMETOOLONG 36
|
|
||||||
#define ENOLCK 37
|
|
||||||
#define ENOSYS 38
|
|
||||||
#define ENOTEMPTY 39
|
|
||||||
#define ELOOP 40
|
|
||||||
#define EWOULDBLOCK EAGAIN
|
|
||||||
#define ENOMSG 42
|
|
||||||
#define EIDRM 43
|
|
||||||
#define ECHRNG 44
|
|
||||||
#define EL2NSYNC 45
|
|
||||||
#define EL3HLT 46
|
|
||||||
#define EL3RST 47
|
|
||||||
#define ELNRNG 48
|
|
||||||
#define EUNATCH 49
|
|
||||||
#define ENOCSI 50
|
|
||||||
#define EL2HLT 51
|
|
||||||
#define EBADE 52
|
|
||||||
#define EBADR 53
|
|
||||||
#define EXFULL 54
|
|
||||||
#define ENOANO 55
|
|
||||||
#define EBADRQC 56
|
|
||||||
#define EBADSLT 57
|
|
||||||
#define EDEADLOCK EDEADLK
|
|
||||||
#define EBFONT 59
|
|
||||||
#define ENOSTR 60
|
|
||||||
#define ENODATA 61
|
|
||||||
#define ETIME 62
|
|
||||||
#define ENOSR 63
|
|
||||||
#define ENONET 64
|
|
||||||
#define ENOPKG 65
|
|
||||||
#define EREMOTE 66
|
|
||||||
#define ENOLINK 67
|
|
||||||
#define EADV 68
|
|
||||||
#define ESRMNT 69
|
|
||||||
#define ECOMM 70
|
|
||||||
#define EPROTO 71
|
|
||||||
#define EMULTIHOP 72
|
|
||||||
#define EDOTDOT 73
|
|
||||||
#define EBADMSG 74
|
|
||||||
#define EOVERFLOW 75
|
|
||||||
#define ENOTUNIQ 76
|
|
||||||
#define EBADFD 77
|
|
||||||
#define EREMCHG 78
|
|
||||||
#define ELIBACC 79
|
|
||||||
#define ELIBBAD 80
|
|
||||||
#define ELIBSCN 81
|
|
||||||
#define ELIBMAX 82
|
|
||||||
#define ELIBEXEC 83
|
|
||||||
#define EILSEQ 84
|
|
||||||
#define ERESTART 85
|
|
||||||
#define ESTRPIPE 86
|
|
||||||
#define EUSERS 87
|
|
||||||
#define ENOTSOCK 88
|
|
||||||
#define EDESTADDRREQ 89
|
|
||||||
#define EMSGSIZE 90
|
|
||||||
#define EPROTOTYPE 91
|
|
||||||
#define ENOPROTOOPT 92
|
|
||||||
#define EPROTONOSUPPORT 93
|
|
||||||
#define ESOCKTNOSUPPORT 94
|
|
||||||
#define EOPNOTSUPP 95
|
|
||||||
#define ENOTSUP EOPNOTSUPP
|
|
||||||
#define EPFNOSUPPORT 96
|
|
||||||
#define EAFNOSUPPORT 97
|
|
||||||
#define EADDRINUSE 98
|
|
||||||
#define EADDRNOTAVAIL 99
|
|
||||||
#define ENETDOWN 100
|
|
||||||
#define ENETUNREACH 101
|
|
||||||
#define ENETRESET 102
|
|
||||||
#define ECONNABORTED 103
|
|
||||||
#define ECONNRESET 104
|
|
||||||
#define ENOBUFS 105
|
|
||||||
#define EISCONN 106
|
|
||||||
#define ENOTCONN 107
|
|
||||||
#define ESHUTDOWN 108
|
|
||||||
#define ETOOMANYREFS 109
|
|
||||||
#define ETIMEDOUT 110
|
|
||||||
#define ECONNREFUSED 111
|
|
||||||
#define EHOSTDOWN 112
|
|
||||||
#define EHOSTUNREACH 113
|
|
||||||
#define EALREADY 114
|
|
||||||
#define EINPROGRESS 115
|
|
||||||
#define ESTALE 116
|
|
||||||
#define EUCLEAN 117
|
|
||||||
#define ENOTNAM 118
|
|
||||||
#define ENAVAIL 119
|
|
||||||
#define EISNAM 120
|
|
||||||
#define EREMOTEIO 121
|
|
||||||
#define EDQUOT 122
|
|
||||||
#define ENOMEDIUM 123
|
|
||||||
#define EMEDIUMTYPE 124
|
|
||||||
#define ECANCELED 125
|
|
||||||
#define ENOKEY 126
|
|
||||||
#define EKEYEXPIRED 127
|
|
||||||
#define EKEYREVOKED 128
|
|
||||||
#define EKEYREJECTED 129
|
|
||||||
#define EOWNERDEAD 130
|
|
||||||
#define ENOTRECOVERABLE 131
|
|
||||||
#define ERFKILL 132
|
|
||||||
#define EHWPOISON 133
|
|
40
vendor/modernc.org/libc/musl/arch/generic/bits/fcntl.h
generated
vendored
40
vendor/modernc.org/libc/musl/arch/generic/bits/fcntl.h
generated
vendored
@ -1,40 +0,0 @@
|
|||||||
#define O_CREAT 0100
|
|
||||||
#define O_EXCL 0200
|
|
||||||
#define O_NOCTTY 0400
|
|
||||||
#define O_TRUNC 01000
|
|
||||||
#define O_APPEND 02000
|
|
||||||
#define O_NONBLOCK 04000
|
|
||||||
#define O_DSYNC 010000
|
|
||||||
#define O_SYNC 04010000
|
|
||||||
#define O_RSYNC 04010000
|
|
||||||
#define O_DIRECTORY 0200000
|
|
||||||
#define O_NOFOLLOW 0400000
|
|
||||||
#define O_CLOEXEC 02000000
|
|
||||||
|
|
||||||
#define O_ASYNC 020000
|
|
||||||
#define O_DIRECT 040000
|
|
||||||
#define O_LARGEFILE 0100000
|
|
||||||
#define O_NOATIME 01000000
|
|
||||||
#define O_PATH 010000000
|
|
||||||
#define O_TMPFILE 020200000
|
|
||||||
#define O_NDELAY O_NONBLOCK
|
|
||||||
|
|
||||||
#define F_DUPFD 0
|
|
||||||
#define F_GETFD 1
|
|
||||||
#define F_SETFD 2
|
|
||||||
#define F_GETFL 3
|
|
||||||
#define F_SETFL 4
|
|
||||||
|
|
||||||
#define F_SETOWN 8
|
|
||||||
#define F_GETOWN 9
|
|
||||||
#define F_SETSIG 10
|
|
||||||
#define F_GETSIG 11
|
|
||||||
|
|
||||||
#define F_GETLK 12
|
|
||||||
#define F_SETLK 13
|
|
||||||
#define F_SETLKW 14
|
|
||||||
|
|
||||||
#define F_SETOWN_EX 15
|
|
||||||
#define F_GETOWN_EX 16
|
|
||||||
|
|
||||||
#define F_GETOWNER_UIDS 17
|
|
10
vendor/modernc.org/libc/musl/arch/generic/bits/fenv.h
generated
vendored
10
vendor/modernc.org/libc/musl/arch/generic/bits/fenv.h
generated
vendored
@ -1,10 +0,0 @@
|
|||||||
#define FE_ALL_EXCEPT 0
|
|
||||||
#define FE_TONEAREST 0
|
|
||||||
|
|
||||||
typedef unsigned long fexcept_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
unsigned long __cw;
|
|
||||||
} fenv_t;
|
|
||||||
|
|
||||||
#define FE_DFL_ENV ((const fenv_t *) -1)
|
|
0
vendor/modernc.org/libc/musl/arch/generic/bits/hwcap.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/hwcap.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/io.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/io.h
generated
vendored
115
vendor/modernc.org/libc/musl/arch/generic/bits/ioctl.h
generated
vendored
115
vendor/modernc.org/libc/musl/arch/generic/bits/ioctl.h
generated
vendored
@ -1,115 +0,0 @@
|
|||||||
#define _IOC(a,b,c,d) ( ((a)<<30) | ((b)<<8) | (c) | ((d)<<16) )
|
|
||||||
#define _IOC_NONE 0U
|
|
||||||
#define _IOC_WRITE 1U
|
|
||||||
#define _IOC_READ 2U
|
|
||||||
|
|
||||||
#define _IO(a,b) _IOC(_IOC_NONE,(a),(b),0)
|
|
||||||
#define _IOW(a,b,c) _IOC(_IOC_WRITE,(a),(b),sizeof(c))
|
|
||||||
#define _IOR(a,b,c) _IOC(_IOC_READ,(a),(b),sizeof(c))
|
|
||||||
#define _IOWR(a,b,c) _IOC(_IOC_READ|_IOC_WRITE,(a),(b),sizeof(c))
|
|
||||||
|
|
||||||
#define TCGETS 0x5401
|
|
||||||
#define TCSETS 0x5402
|
|
||||||
#define TCSETSW 0x5403
|
|
||||||
#define TCSETSF 0x5404
|
|
||||||
#define TCGETA 0x5405
|
|
||||||
#define TCSETA 0x5406
|
|
||||||
#define TCSETAW 0x5407
|
|
||||||
#define TCSETAF 0x5408
|
|
||||||
#define TCSBRK 0x5409
|
|
||||||
#define TCXONC 0x540A
|
|
||||||
#define TCFLSH 0x540B
|
|
||||||
#define TIOCEXCL 0x540C
|
|
||||||
#define TIOCNXCL 0x540D
|
|
||||||
#define TIOCSCTTY 0x540E
|
|
||||||
#define TIOCGPGRP 0x540F
|
|
||||||
#define TIOCSPGRP 0x5410
|
|
||||||
#define TIOCOUTQ 0x5411
|
|
||||||
#define TIOCSTI 0x5412
|
|
||||||
#define TIOCGWINSZ 0x5413
|
|
||||||
#define TIOCSWINSZ 0x5414
|
|
||||||
#define TIOCMGET 0x5415
|
|
||||||
#define TIOCMBIS 0x5416
|
|
||||||
#define TIOCMBIC 0x5417
|
|
||||||
#define TIOCMSET 0x5418
|
|
||||||
#define TIOCGSOFTCAR 0x5419
|
|
||||||
#define TIOCSSOFTCAR 0x541A
|
|
||||||
#define FIONREAD 0x541B
|
|
||||||
#define TIOCINQ FIONREAD
|
|
||||||
#define TIOCLINUX 0x541C
|
|
||||||
#define TIOCCONS 0x541D
|
|
||||||
#define TIOCGSERIAL 0x541E
|
|
||||||
#define TIOCSSERIAL 0x541F
|
|
||||||
#define TIOCPKT 0x5420
|
|
||||||
#define FIONBIO 0x5421
|
|
||||||
#define TIOCNOTTY 0x5422
|
|
||||||
#define TIOCSETD 0x5423
|
|
||||||
#define TIOCGETD 0x5424
|
|
||||||
#define TCSBRKP 0x5425
|
|
||||||
#define TIOCSBRK 0x5427
|
|
||||||
#define TIOCCBRK 0x5428
|
|
||||||
#define TIOCGSID 0x5429
|
|
||||||
#define TIOCGRS485 0x542E
|
|
||||||
#define TIOCSRS485 0x542F
|
|
||||||
#define TIOCGPTN 0x80045430
|
|
||||||
#define TIOCSPTLCK 0x40045431
|
|
||||||
#define TIOCGDEV 0x80045432
|
|
||||||
#define TCGETX 0x5432
|
|
||||||
#define TCSETX 0x5433
|
|
||||||
#define TCSETXF 0x5434
|
|
||||||
#define TCSETXW 0x5435
|
|
||||||
#define TIOCSIG 0x40045436
|
|
||||||
#define TIOCVHANGUP 0x5437
|
|
||||||
#define TIOCGPKT 0x80045438
|
|
||||||
#define TIOCGPTLCK 0x80045439
|
|
||||||
#define TIOCGEXCL 0x80045440
|
|
||||||
#define TIOCGPTPEER 0x5441
|
|
||||||
#define TIOCGISO7816 0x80285442
|
|
||||||
#define TIOCSISO7816 0xc0285443
|
|
||||||
|
|
||||||
#define FIONCLEX 0x5450
|
|
||||||
#define FIOCLEX 0x5451
|
|
||||||
#define FIOASYNC 0x5452
|
|
||||||
#define TIOCSERCONFIG 0x5453
|
|
||||||
#define TIOCSERGWILD 0x5454
|
|
||||||
#define TIOCSERSWILD 0x5455
|
|
||||||
#define TIOCGLCKTRMIOS 0x5456
|
|
||||||
#define TIOCSLCKTRMIOS 0x5457
|
|
||||||
#define TIOCSERGSTRUCT 0x5458
|
|
||||||
#define TIOCSERGETLSR 0x5459
|
|
||||||
#define TIOCSERGETMULTI 0x545A
|
|
||||||
#define TIOCSERSETMULTI 0x545B
|
|
||||||
|
|
||||||
#define TIOCMIWAIT 0x545C
|
|
||||||
#define TIOCGICOUNT 0x545D
|
|
||||||
#define FIOQSIZE 0x5460
|
|
||||||
|
|
||||||
#define TIOCM_LE 0x001
|
|
||||||
#define TIOCM_DTR 0x002
|
|
||||||
#define TIOCM_RTS 0x004
|
|
||||||
#define TIOCM_ST 0x008
|
|
||||||
#define TIOCM_SR 0x010
|
|
||||||
#define TIOCM_CTS 0x020
|
|
||||||
#define TIOCM_CAR 0x040
|
|
||||||
#define TIOCM_RNG 0x080
|
|
||||||
#define TIOCM_DSR 0x100
|
|
||||||
#define TIOCM_CD TIOCM_CAR
|
|
||||||
#define TIOCM_RI TIOCM_RNG
|
|
||||||
#define TIOCM_OUT1 0x2000
|
|
||||||
#define TIOCM_OUT2 0x4000
|
|
||||||
#define TIOCM_LOOP 0x8000
|
|
||||||
|
|
||||||
#define FIOSETOWN 0x8901
|
|
||||||
#define SIOCSPGRP 0x8902
|
|
||||||
#define FIOGETOWN 0x8903
|
|
||||||
#define SIOCGPGRP 0x8904
|
|
||||||
#define SIOCATMARK 0x8905
|
|
||||||
#if __LONG_MAX == 0x7fffffff
|
|
||||||
#define SIOCGSTAMP _IOR(0x89, 6, char[16])
|
|
||||||
#define SIOCGSTAMPNS _IOR(0x89, 7, char[16])
|
|
||||||
#else
|
|
||||||
#define SIOCGSTAMP 0x8906
|
|
||||||
#define SIOCGSTAMPNS 0x8907
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <bits/ioctl_fix.h>
|
|
0
vendor/modernc.org/libc/musl/arch/generic/bits/ioctl_fix.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/ioctl_fix.h
generated
vendored
11
vendor/modernc.org/libc/musl/arch/generic/bits/ipc.h
generated
vendored
11
vendor/modernc.org/libc/musl/arch/generic/bits/ipc.h
generated
vendored
@ -1,11 +0,0 @@
|
|||||||
struct ipc_perm {
|
|
||||||
key_t __ipc_perm_key;
|
|
||||||
uid_t uid;
|
|
||||||
gid_t gid;
|
|
||||||
uid_t cuid;
|
|
||||||
gid_t cgid;
|
|
||||||
mode_t mode;
|
|
||||||
int __ipc_perm_seq;
|
|
||||||
long __pad1;
|
|
||||||
long __pad2;
|
|
||||||
};
|
|
1
vendor/modernc.org/libc/musl/arch/generic/bits/ipcstat.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/generic/bits/ipcstat.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
#define IPC_STAT 2
|
|
1
vendor/modernc.org/libc/musl/arch/generic/bits/kd.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/generic/bits/kd.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
#include <linux/kd.h>
|
|
0
vendor/modernc.org/libc/musl/arch/generic/bits/limits.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/limits.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/generic/bits/link.h
generated
vendored
1
vendor/modernc.org/libc/musl/arch/generic/bits/link.h
generated
vendored
@ -1 +0,0 @@
|
|||||||
typedef uint32_t Elf_Symndx;
|
|
0
vendor/modernc.org/libc/musl/arch/generic/bits/mman.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/mman.h
generated
vendored
12
vendor/modernc.org/libc/musl/arch/generic/bits/msg.h
generated
vendored
12
vendor/modernc.org/libc/musl/arch/generic/bits/msg.h
generated
vendored
@ -1,12 +0,0 @@
|
|||||||
struct msqid_ds {
|
|
||||||
struct ipc_perm msg_perm;
|
|
||||||
time_t msg_stime;
|
|
||||||
time_t msg_rtime;
|
|
||||||
time_t msg_ctime;
|
|
||||||
unsigned long msg_cbytes;
|
|
||||||
msgqnum_t msg_qnum;
|
|
||||||
msglen_t msg_qbytes;
|
|
||||||
pid_t msg_lspid;
|
|
||||||
pid_t msg_lrpid;
|
|
||||||
unsigned long __unused[2];
|
|
||||||
};
|
|
0
vendor/modernc.org/libc/musl/arch/generic/bits/poll.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/poll.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/ptrace.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/ptrace.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/resource.h
generated
vendored
0
vendor/modernc.org/libc/musl/arch/generic/bits/resource.h
generated
vendored
14
vendor/modernc.org/libc/musl/arch/generic/bits/sem.h
generated
vendored
14
vendor/modernc.org/libc/musl/arch/generic/bits/sem.h
generated
vendored
@ -1,14 +0,0 @@
|
|||||||
struct semid_ds {
|
|
||||||
struct ipc_perm sem_perm;
|
|
||||||
time_t sem_otime;
|
|
||||||
time_t sem_ctime;
|
|
||||||
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
|
||||||
unsigned short sem_nsems;
|
|
||||||
char __sem_nsems_pad[sizeof(long)-sizeof(short)];
|
|
||||||
#else
|
|
||||||
char __sem_nsems_pad[sizeof(long)-sizeof(short)];
|
|
||||||
unsigned short sem_nsems;
|
|
||||||
#endif
|
|
||||||
long __unused3;
|
|
||||||
long __unused4;
|
|
||||||
};
|
|
24
vendor/modernc.org/libc/musl/arch/generic/bits/shm.h
generated
vendored
24
vendor/modernc.org/libc/musl/arch/generic/bits/shm.h
generated
vendored
@ -1,24 +0,0 @@
|
|||||||
#define SHMLBA 4096
|
|
||||||
|
|
||||||
struct shmid_ds {
|
|
||||||
struct ipc_perm shm_perm;
|
|
||||||
size_t shm_segsz;
|
|
||||||
time_t shm_atime;
|
|
||||||
time_t shm_dtime;
|
|
||||||
time_t shm_ctime;
|
|
||||||
pid_t shm_cpid;
|
|
||||||
pid_t shm_lpid;
|
|
||||||
unsigned long shm_nattch;
|
|
||||||
unsigned long __pad1;
|
|
||||||
unsigned long __pad2;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct shminfo {
|
|
||||||
unsigned long shmmax, shmmin, shmmni, shmseg, shmall, __unused[4];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct shm_info {
|
|
||||||
int __used_ids;
|
|
||||||
unsigned long shm_tot, shm_rss, shm_swp;
|
|
||||||
unsigned long __swap_attempts, __swap_successes;
|
|
||||||
};
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user