mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-30 15:10:40 +00:00
currency: Adds matching lookup table built from available pairs (#1312)
* currency: Add pair matching update (cherry-pick) * exchange/currency: Add tests and update func * linter fix, also if using json unmarshal functionality stop usage of string conversion without delimiter * gemini: fix test * currency/manager: potential optimisation * exchanges: purge derive from wrapper cases and add warning comment * glorious: nits * glorious: nits * linter: fix * glorious: nits * whoops * whoops * glorious: nits continued * glorious: diff THANKS! * hitbtc: fix update tradable pairs strings splitting. continue if not enabled tickers update pair. * glorious: nits * linter: fix * Update exchanges/exmo/exmo_wrapper.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * bitstamp: fix test when 32 biterinos architecturinos * capture more strings for speed * swapsies because whos running 32bit \0/? --------- Co-authored-by: Ryan O'Hara-Reid <ryan.oharareid@thrasher.io> Co-authored-by: Scott <gloriousCode@users.noreply.github.com>
This commit is contained in:
@@ -4,6 +4,7 @@ import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"unicode"
|
||||
)
|
||||
|
||||
// EMPTYFORMAT defines an empty pair format
|
||||
@@ -45,8 +46,21 @@ func (p *Pair) UnmarshalJSON(d []byte) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
*p, err = NewPairFromString(pair)
|
||||
return err
|
||||
// Check if pair is in the format of BTC-USD
|
||||
for x := range pair {
|
||||
if unicode.IsPunct(rune(pair[x])) {
|
||||
p.Base = NewCode(pair[:x])
|
||||
p.Delimiter = string(pair[x])
|
||||
p.Quote = NewCode(pair[x+1:])
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE: Pair string could be in format DUSKUSDT (Kucoin) which will be
|
||||
// incorrectly converted to DUS-KUSDT, ELKRW (Bithumb) which will convert
|
||||
// converted to ELK-RW and HTUSDT (Lbank) which will be incorrectly
|
||||
// converted to HTU-SDT.
|
||||
return fmt.Errorf("%w from %s cannot ensure pair is in correct format, please use exchange method MatchSymbolWithAvailablePairs", errCannotCreatePair, pair)
|
||||
}
|
||||
|
||||
// MarshalJSON conforms type to the marshaler interface
|
||||
|
||||
Reference in New Issue
Block a user