Не срабатывает колбек OnTrade

Страницы: 1
RSS
Не срабатывает колбек OnTrade
 
Исходный код:
Код
is_run = true

-- вызывается при нажатии кнопки "остановить" в диалоге
function OnStop(signal)
   stopped = true
end

-- крутится в отдельном потоке, ничего не делает
function main()
   while not stopped do
      sleep(100)
   end
end

-- выводим сообщение
function OnTrade(trade_data)
    message('da')
end


Нет сообщение при тике. Вот окно терминала:
 
Я ведь правильно понимаю, что OnTrade калбек срабатывает тогда, когда создается новый тик?
 
Дмитрий Косолапов,
OnTrade срабатывает тогда когда происходит Ваша сделка.
Если требуется смотреть тики, это OnAllTrade
 
И при использовании OnAllTrade то же сообщений нет, ошибок при работе скрипта то же нет. Функция message работает в калбеке OnAllTrade?
 
Дмитрий Косолапов,

Откройте таблицу обезличенных сделок и данные появятся.
 
Цитата
Дмитрий Косолапов написал:
Код
 -- выводим сообщение 
 function   OnTrade (trade_data)
     message ( 'da' )
 end 
  
Нет сообщение при тике.
message( 'da', 1 or 2 or 3 )
 
Тоже напоролся на некоторое непонимание работы OnTrade. Требуется совет) Не работает колбек.

В моём роботе в OnTrade в переменную записывается цена рыночной покупки из main.
В main идёт покупка по рынку и выставление стопа (цена совершенной сделки из переменной в онтрейд минус 0,5, к примеру), далее sleep пока текущая чистая позиция не = 0.

В итоге первый цикл получается как и задумано (покупка по рынку->срабатывает онтрейд и фиксирует цену сделки->выставляется стоп с учётом этой цены), а каждый следующий цикл main для выставления стопа берётся не текущая цена из онтрейд, а цена из предыдущего цикла. Будто ontrade перестаёт работать как колбек, а начинается работать последовательно после цикла main.
Хотя вставлял сообщение при вызове онтрейд и там в середине цикла в переменную записывается текущая цена, т.е. всё ОК. А вот в мейне почему-то отображается цена из предыдущего цикла.

Причем переменные, хранящие цену делал и локальными и глобальными, разницы нет.

Код
local ID_Order = 1001      --id ордера
local Status_Order         --id статуса ордера
local Num_Order            --номер ордера
local State_Order         --id проверки статуса заявки для OnOrder

Price_Stop = 0
Trade_Price = 0
   
local classcod = ".."
local seccod = ".."
local Depo = "..."

is_run = true

function OnStop()
  is_run = false
  return 500
end



function OnTransReply(order)
   if   order.trans_id == ID_Order then
      Status_Order = order.status
      Num_Order = order.order_num
   end
end



function OnOrder(order)
   if Num_Order == order.order_num then
      if bit.band(order.flags, 0x1) == 0 and bit.band(order.flags, 0x2) == 0 then
         State_Order = "Исполнена"
      end
   end
end



function OnTrade(trade)
   if   trade.order_num == Num_Order then
      Trade_Price = trade.price
   end
end



function main()
   while is_run do   

      if getItem("FUTURES_CLIENT_HOLDING",0).totalnet == 0   then      --покупка по рынку, если позиция пуста
         local MarketOrderBuy = {               
                        ["ACTION"] = "NEW_ORDER",
                        ["ACCOUNT"] = Depo,
                        ["OPERATION"] = "B",
                        ["CLASSCODE"] = classcod,
                        ["SECCODE"] = seccod,
                        ["PRICE"] = "0",
                        ["QUANTITY"] = "1",
                        ["TRANS_ID"] = tostring(ID_Order),
                        ["TYPE"] = "M",
                        }
         local Err_Order = sendTransaction(MarketOrderBuy)
         while Status_Order == nil and Err_Order == "" do
            sleep(100)
         end
         if Status_Order == 3 then
            while State_Order ~= "Исполнена" do
               sleep(100)
            end
            message("Покупка по рынку исполнена")
         end

         Price_Stop = Trade_Price - 0.5
            
         -- здесь высталвение стопа с учетом Price_Stop
               
         sleep(5000)
         ID_Order = ID_Order + 1            --смена id ордера для следующей сделки
      end   
      sleep(5000)
   end
   sleep(10)
end
 
Значения глобальных переменных, таких как, Status_Order, State_Order, Num_Order, удалять надо перед началом нового цикла.
Надо делать так, как надо. А как не надо - делать не надо.
 
Старатель, вроде заработало, спасибо)
Вначале думал обнулять абсолютно все переменные после выставления стопа и ухода в спячку, но набросал код и всё вроде работало как надо по алгоритму, возникла только эта проблема с запаздывающей на 1 цикл ценой сделки. Думал тут проблема сложнее... В общем мне ещё экспериментировать и экспериментировать))
Страницы: 1
Читают тему
Наверх