Ошибки, баги, вопросы - страница 1973

 
Stanislav Korotky:
Подскажите, пожалуйста, алгоритм подсчета объемов для конкретного бара (может быть где-то уже описано?). Например, запрашиваем с помощью CopyTicksRange все тики за конкретный бар и нужно получить в результате вычислений тот же объем (и реальный, и тиковый), который отображается в Окне Данных. У меня расхождения по обоим объемам для биржевых инструментов на порядки (для конкретики - возьмем AFLT на MQ-Demo). Для форекса тиковые объемы совпадают, про реальные там речи нет.
Вы при суммировании объемов флаги проверяйте - TICK_FLAG. Иначе будете один и тот же объем несколько раз учитывать в сумме.
 
Dmitriy Skub:
Вы при суммировании объемов флаги проверяйте - TICK_FLAG. Иначе будете один и тот же объем несколько раз учитывать в сумме.

Конечно, смотрю флаги. Я про это и спрашивал - только нужна была конкретика. Уже ответили. Проще запрашивать тики _TRADE. Работает.

 
Stanislav Korotky:

Конечно, смотрю флаги. Я про это и спрашивал - только нужна была конкретика. Уже ответили. Проще запрашивать тики _TRADE. Работает.

Можно ещё флаг применять в зависимости от ENUM_SYMBOL_CALC_MODE

 
Alexey Viktorov:

Можно ещё флаг применять в зависимости от ENUM_SYMBOL_CALC_MODE

Разумеется так и делаю.

 
Комментарии, не относящиеся к этой теме, были перенесены в "Вопросы от начинающих MQL4 MT4 MetaTrader 4".
 
internal error #27
#import "Test.ex5"
        int f();
#import
static int i = Test::f();
 
Николай Никитюк:

Если мне нужно, чтобы в функциях "LongCondition" и "ShortCondition" использовались результаты вычислений из метода TrendTenkan, а у меня до сих пор не получается это сделать. Это значит, что LongCondition должна вызывать TrendTenkan ?

Я могу только подправить явные ошибки: 

for(i=idx+1;i<idx+21;i++)
     {if(DiffKijun(i)>0.0) {value_t=TYPE_TREND_UP; break; return(value_t);}
//здесь явно что-то не так
//return после break не имеет смысла

Откуда что должно вызываться - не знаю 

 

internal error #112

class A;
struct B {
        void f() { a.g(); }
        A *a;
};
void OnStart()
{
        B b;
        b.f();
}
 

В build 1653 ошибка при выполнении не исчезла, а лишь переместилась в другую часть кода:

Cannot find 'f1' in 'Test2.ex5'

//Test.mqh
class B {
        virtual void f() {}
};
class C {
        virtual void g( B& ) {}
};
class A : C {};
#import "Test2.ex5"
        A *f1();
        B *f2();
#import
//Test.mq5
#include "Test.mqh"
void OnStart()
{
        f1();
}
//Test2.mq5
#property library
#include "Test.mqh"
A *f1() export { return NULL; }
B *f2() export { return NULL; }
 

Ошибка при компиляции

#import "Test.ex5"
        void g();   //g(1)
#import
        void g() {} //g(2)
typedef void (*fn)();
void f( fn )       {}
void f( int, int ) {}
void OnStart()
{
        f( Test::g ); //нормально
        f(     ::g ); //error: 'f' - no one of the overloads can be applied to the function call
        f(       g ); //error: 'f' - no one of the overloads can be applied to the function call
//а как иначе указать что g - это g(2) ... и причем здесь overloads ???
        fn gg = g;    //нормально
        f( gg );
}
Причина обращения: