Ошибка с логами
Atom
27.09.2011


Вот код:
Код
        private void OnLogUpdate(ErrorTypes err, string message)
        {
            this.Log(new LogMessage(this, DateTime.Now, err, message));
        }
        
        public T400()
        {            
            plaza = new PlazaTrader(this.StrategyParameters.PlazaRouterPath.To<IPEndPoint>());
            this.candleManager = new CandleManager(plaza);
            logManager = new LogManager();
            logManager.Sources.Add(this);
        }

T400 это робот, по сути класс-инфраструктура для запуска стратегии, чтобы он тоже мог писать логи реализуется ILogSource.
На старте робота выполняется:
Код
guiLogListener = new GuiLogListener(_logWindow);
t400.AddLogListener(guiLogListener);

Потом, при выполнении OnLogUpdate ошибка: [System.ArgumentNullException] = {"Значение не может быть неопределенным.\r\nИмя параметра: obj"}
Вот стэктрэйс:
в Ecng.Xaml.XamlHelper.GuiSync(DispatcherObject obj, Action action)
в StockSharp.Xaml.GuiLogListener.OnWriteMessage(LogMessage message)
в StockSharp.Algo.Logging.LogListener.WriteMessage(LogMessage message)
в StockSharp.Algo.Logging.LogManager.#=qrUj$Ns0mMAxxqh0k0FFJLB8wrKr4pz7DsmdCpRVKh18=.#=q3S_X0XbExHKU68uzjbFQVxw4VT4yOdgZvBt8Dr1nZXc=(ILogListener #=qeUzjoy2OxlhpLB1gDjK5qQ==)
в Ecng.Collections.CollectionHelper.ForEach[T](IEnumerable`1 source, Action`1 action)
в StockSharp.Algo.Logging.LogManager.#=qm2awVrrxMn_7KT6KAHw0Wg==(LogMessage #=qJiXkieLb13i$V63GpKExqw==)
в Skynet.T400.OnLogUpdate(ErrorTypes err, String message)

Собственно вопрос: что передается в GuiSync в качестве DispatcherObject и почему все ломается.
Второй вопрос: как правильно в такой ситуации реализовать ILogSource, кто будет Parent, кто Childs, и зачем там Guid?

P.S. Ошибка появилась оч недавно, после последнего обновления референсов

Теги:


Спасибо:


< 1 2 
FiNick

Фотография
Дата: 28.09.2011
Ответить


Я вроде как понял:
Код
this.Trader.Disconnected += Trader_Disconnected;
void Trader_Disconnected()
{
     this.Log(new LogMessage(this, DateTime.Now, ErrorTypes.None, "Disconnected"));
}

Проблема в том, что Log вызывается не GuiAsync. Я впринципе не могу вызвать его GuiAsync, т.к. это функция для некоторого DispatcherObject, окна тоесть, а я обрабатываю внутри T400.

Я реализовывал ILogSource для MainWindow, та же проблема возникает. Но если написать так
Код
void Trader_Disconnected()
        {
            this.GuiAsync(() => this.Log(new LogMessage(this, DateTime.Now, ErrorTypes.None, "  ")));

            //this.Log(new LogMessage(this, DateTime.Now, ErrorTypes.None, "  "));    Так не работает
        }

то все норм.
Спасибо:

Mikhail Sukhov

Фотография
Дата: 28.09.2011
Ответить


ILogListener все тот же? Тогда это тянется отсюда же http://stocksharp.com/posts/m/11605/
Спасибо:

FiNick

Фотография
Дата: 28.09.2011
Ответить


Mikhail Sukhov Перейти
ILogListener все тот же? Тогда это тянется отсюда же http://stocksharp.com/posts/m/11605/

Да, то же самое, T400 реализует ILogListener. в качестве _logWindow используется MonitorWindow (потому что с LogWindow не работает пока).

В прикрепленном файле посмотрите, эта ошибка с зависанием реализована для MainWindow из примера SimpleGUI.
MainWindow.xaml.cs 10 KB (152)
Спасибо:

FiNick

Фотография
Дата: 30.09.2011
Ответить


После последнего обновления StockSharp.Algo первая ошибка с LogWindow решилась. Проблема с зависанием осталась.
Спасибо:

Mikhail Sukhov

Фотография
Дата: 30.09.2011
Ответить


FiNick Перейти
После последнего обновления StockSharp.Algo первая ошибка с LogWindow решилась. Проблема с зависанием осталась.


А зависание от чего происходит?
Спасибо:

FiNick

Фотография
Дата: 30.09.2011
Ответить


Mikhail Sukhov Перейти
FiNick Перейти
После последнего обновления StockSharp.Algo первая ошибка с LogWindow решилась. Проблема с зависанием осталась.


А зависание от чего происходит?


Зависание возникает при вызове лога в момент дисконнекта:
Код
        void Trader_Disconnected()
        {
            //this.GuiAsync(() => this.Log(new LogMessage(this, DateTime.Now, ErrorTypes.None, "  "))); //Так не зависает

            this.Log(new LogMessage(this, DateTime.Now, ErrorTypes.None, "  "));    //Так зависает
        }

Причем если обернуть GuiAsync, то не зависает. Это оочень странно, т.к. вроде как внутри GuiLogListener вызов лога оборачивается в GuiAsync автоматически.
Спасибо:
< 1 2 

Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy