Browse Source

test

release/v0.1
jl777 9 years ago
parent
commit
78268c931a
  1. 1
      iguana/exchanges777.h
  2. 16
      iguana/swaps/iguana_BTCswap.c

1
iguana/exchanges777.h

@ -204,5 +204,6 @@ void tradebot_timeslices(struct exchange_info *exchange);
struct instantdex_stateinfo *BTC_initFSM(int32_t *n); struct instantdex_stateinfo *BTC_initFSM(int32_t *n);
struct bitcoin_statetx *instantdex_feetx(struct supernet_info *myinfo,struct instantdex_accept *A,struct bitcoin_swapinfo *swap,struct iguana_info *coin); struct bitcoin_statetx *instantdex_feetx(struct supernet_info *myinfo,struct instantdex_accept *A,struct bitcoin_swapinfo *swap,struct iguana_info *coin);
void instantdex_statemachine_iter(struct supernet_info *myinfo,struct exchange_info *exchange,struct bitcoin_swapinfo *swap); void instantdex_statemachine_iter(struct supernet_info *myinfo,struct exchange_info *exchange,struct bitcoin_swapinfo *swap);
void instantdex_historyadd(struct exchange_info *exchange,struct bitcoin_swapinfo *swap);
#endif #endif

16
iguana/swaps/iguana_BTCswap.c

@ -187,7 +187,7 @@ struct bitcoin_statetx *instantdex_feetx(struct supernet_info *myinfo,struct ins
r = swap->mine.orderid; r = swap->mine.orderid;
n = instantdex_outputinsurance(paymentscript,swap->insurance,r,r * (strcmp("BTC",coin->symbol) == 0)); n = instantdex_outputinsurance(paymentscript,swap->insurance,r,r * (strcmp("BTC",coin->symbol) == 0));
init_hexbytes_noT(scriptstr,paymentscript,n); init_hexbytes_noT(scriptstr,paymentscript,n);
printf("instantdex_feetx %.8f (%s)\n",dstr(swap->insurance),scriptstr); printf("instantdex_feetx %s %.8f (%s)\n",coin->symbol,dstr(swap->insurance),scriptstr);
ptr = instantdex_signtx(myinfo,coin,0,scriptstr,swap->insurance,coin->txfee,0,A->offer.myside); ptr = instantdex_signtx(myinfo,coin,0,scriptstr,swap->insurance,coin->txfee,0,A->offer.myside);
return(ptr); return(ptr);
} }
@ -725,7 +725,7 @@ cJSON *BTC_waitprivsfunc(struct supernet_info *myinfo,struct exchange_info *exch
else else
{ {
printf("error generating feetx\n"); printf("error generating feetx\n");
free_json(newjson); //free_json(newjson);
newjson = 0; newjson = 0;
} }
} }
@ -767,7 +767,7 @@ cJSON *ALICE_waitdepositfunc(struct supernet_info *myinfo,struct exchange_info *
} }
else else
{ {
free_json(newjson); //free_json(newjson);
newjson = 0; newjson = 0;
} }
} }
@ -817,6 +817,10 @@ cJSON *BTC_cleanupfunc(struct supernet_info *myinfo,struct exchange_info *exchan
swap->dead = (uint32_t)time(NULL); swap->dead = (uint32_t)time(NULL);
swap->mine.dead = (uint32_t)time(NULL); swap->mine.dead = (uint32_t)time(NULL);
swap->other.dead = (uint32_t)time(NULL); swap->other.dead = (uint32_t)time(NULL);
portable_mutex_lock(&exchange->mutexS);
DL_DELETE(exchange->statemachines,swap);
portable_mutex_unlock(&exchange->mutexS);
instantdex_historyadd(exchange,swap);
return(newjson); return(newjson);
} }
@ -1080,10 +1084,8 @@ void instantdex_statemachine_iter(struct supernet_info *myinfo,struct exchange_i
if ( swap->dead != 0 || swap->mine.dead != 0 || swap->other.dead != 0 ) if ( swap->dead != 0 || swap->mine.dead != 0 || swap->other.dead != 0 )
return; return;
coinbtc = iguana_coinfind("BTC"); coinbtc = iguana_coinfind("BTC");
if ( instantdex_isbob(swap) != 0 && swap->myfee == 0 ) if ( swap->myfee == 0 )
swap->myfee = instantdex_feetx(myinfo,&swap->mine,swap,coinbtc); swap->myfee = instantdex_feetx(myinfo,&swap->mine,swap,coinbtc);
else if ( instantdex_isbob(swap) == 0 && swap->otherfee == 0 )
swap->otherfee = instantdex_feetx(myinfo,&swap->mine,swap,coinbtc);
printf("state(%s) %llx/%llx\n",swap->state->name,(long long)swap->mine.orderid,(long long)swap->other.orderid); printf("state(%s) %llx/%llx\n",swap->state->name,(long long)swap->mine.orderid,(long long)swap->other.orderid);
while ( (ptr= queue_dequeue(&swap->eventsQ,0)) != 0 ) while ( (ptr= queue_dequeue(&swap->eventsQ,0)) != 0 )
{ {
@ -1093,7 +1095,7 @@ void instantdex_statemachine_iter(struct supernet_info *myinfo,struct exchange_i
instantdex_eventfree(ptr); instantdex_eventfree(ptr);
flag++; flag++;
} }
if ( flag == 0 && swap->pollevent != 0 ) if ( flag == 0 && swap->dead == 0 && swap->pollevent != 0 )
{ {
//printf("send poll event\n"); //printf("send poll event\n");
newjson = jduplicate(swap->pollevent->newjson); newjson = jduplicate(swap->pollevent->newjson);

Loading…
Cancel
Save