New wren methods ticker_currency() and ticker_exchange()
This commit is contained in:
parent
6bd0dbb07e
commit
6cbe6ae47f
3 changed files with 57 additions and 8 deletions
34
src/main.cpp
34
src/main.cpp
|
@ -23,6 +23,9 @@
|
|||
#include <algorithm>
|
||||
|
||||
namespace {
|
||||
constexpr std::string_view g_dummy_currency {"EUR"};
|
||||
constexpr std::string_view g_dummy_exchange {"kraken"};
|
||||
|
||||
constexpr char g_script[] =
|
||||
R"script(
|
||||
import "bitcoinity" for Bitcoinity
|
||||
|
@ -37,6 +40,9 @@ class App {
|
|||
var price_quick = Bitcoinity.ticker_quick()
|
||||
System.print("Ticker (quick): %(price_quick.price) %(price_quick.currency) on %(price_quick.exchange)")
|
||||
|
||||
var price_currency = Bitcoinity.ticker_currency(_currency)
|
||||
System.print("Ticker (%(_currency)): %(price_currency.price) %(price_currency.currency) on %(price_currency.exchange)")
|
||||
|
||||
var price = Bitcoinity.ticker(_exchange, _currency)
|
||||
System.print("Ticker (%(_exchange), %(_currency)): %(price.price) %(price.currency) on %(price.exchange)")
|
||||
}
|
||||
|
@ -48,19 +54,37 @@ var the_app = App.new("kraken", "USD")
|
|||
void quick_ticker_price_bitcoinity_wren (wren::VM& vm) {
|
||||
using duck::TickerPrice;
|
||||
using duck::bitcoinity_ticker_price;
|
||||
using duck::BitcoinityMatchType;
|
||||
|
||||
TickerPrice* const tp = wren::make_foreign_object<TickerPrice>(vm, "ticker_price");
|
||||
constexpr bool exact_match = false;
|
||||
*tp = bitcoinity_ticker_price("kraken", "EUR", exact_match);
|
||||
*tp = bitcoinity_ticker_price(g_dummy_exchange, g_dummy_currency, BitcoinityMatchType::Any);
|
||||
}
|
||||
|
||||
void ticker_price_bitcoinity_wren (wren::VM& vm) {
|
||||
using duck::TickerPrice;
|
||||
using duck::bitcoinity_ticker_price;
|
||||
using duck::BitcoinityMatchType;
|
||||
|
||||
TickerPrice* const tp = wren::make_foreign_object<TickerPrice>(vm, "ticker_price");
|
||||
constexpr bool exact_match = true;
|
||||
*tp = bitcoinity_ticker_price(wren::get<const char*>(vm, 1), wren::get<const char*>(vm, 2), exact_match);
|
||||
*tp = bitcoinity_ticker_price(wren::get<const char*>(vm, 1), wren::get<const char*>(vm, 2), BitcoinityMatchType::Exact);
|
||||
}
|
||||
|
||||
void currency_ticker_price_bitcoinity_wren (wren::VM& vm) {
|
||||
using duck::TickerPrice;
|
||||
using duck::bitcoinity_ticker_price;
|
||||
using duck::BitcoinityMatchType;
|
||||
|
||||
TickerPrice* const tp = wren::make_foreign_object<TickerPrice>(vm, "ticker_price");
|
||||
*tp = bitcoinity_ticker_price(g_dummy_exchange, wren::get<const char*>(vm, 1), BitcoinityMatchType::CurrencyOnly);
|
||||
}
|
||||
|
||||
void exchange_ticker_price_bitcoinity_wren (wren::VM& vm) {
|
||||
using duck::TickerPrice;
|
||||
using duck::bitcoinity_ticker_price;
|
||||
using duck::BitcoinityMatchType;
|
||||
|
||||
TickerPrice* const tp = wren::make_foreign_object<TickerPrice>(vm, "ticker_price");
|
||||
*tp = bitcoinity_ticker_price(wren::get<const char*>(vm, 1), g_dummy_currency, BitcoinityMatchType::ExchangeOnly);
|
||||
}
|
||||
|
||||
class MyWrenConfiguration : public wren::DefConfiguration {
|
||||
|
@ -102,6 +126,8 @@ int main() {
|
|||
vm.callback_manager()
|
||||
.add_callback(true, "bitcoinity", "Bitcoinity", "ticker(_,_)", &ticker_price_bitcoinity_wren)
|
||||
.add_callback(true, "bitcoinity", "Bitcoinity", "ticker_quick()", &quick_ticker_price_bitcoinity_wren)
|
||||
.add_callback(true, "bitcoinity", "Bitcoinity", "ticker_currency(_)", ¤cy_ticker_price_bitcoinity_wren)
|
||||
.add_callback(true, "bitcoinity", "Bitcoinity", "ticker_exchange(_)", &exchange_ticker_price_bitcoinity_wren)
|
||||
.add_callback(false, "ticker_price", "TickerPrice", "price", wren::make_method_bindable<&TickerPrice::price>())
|
||||
.add_callback(false, "ticker_price", "TickerPrice", "currency", wren::make_method_bindable<&TickerPrice::currency>())
|
||||
.add_callback(false, "ticker_price", "TickerPrice", "is_valid", wren::make_method_bindable<&TickerPrice::is_valid>())
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue