функции ResetLastError () производится для обнуления ошибки перед вызовом функции, после которой проверяется возникновение ошибки.
Функция OrderCalcMargin вычисляет размер средств, необходимых для открытия позиции.
И если размер свободных средств на счете (ACCOUNT_MARGIN_FREE) меньше, чем размер средств, необходимых для открытия позиции, денег на счете недостаточно и торговля невозможна.
Для функции AccountInfoString определены такие свойства как имя клиента ACCOUNT_NAME, имя торгового сервера ACCOUNT_SERVER, валюта депозита ACCOUNT_CURRENCY, имя компании, обслуживающей счет ACCOUNT_COMPANY.
С помощью свойства ACCOUNT_NAME, также как и с помощью свойства ACCOUNT_LOGIN, можно защитить советник.
Информацию о клиентском терминале можно получить с помощью функций TerminalInfoInteger и TerminalInfoString.
В качестве аргумента эти функции также принимают свойства.
Мы уже видели проверку подключения терминала к серверу с помощью свойства TERMINAL_CONNECTED.
Свойство TERMINAL_DLLS_ALLOWED позволяет выяснить, есть ли разрешение на использование DLL.
Файлы DLL это еще один способ создания повторно используемых библиотек — модулей кода для MQL5-программ.
DLL-библиотеки находятся в папке MQL5Libraries торгового терминала и включаются в код MQL5-программы с помощью команды #import.
При этом разрешение на использование DLL-библиотек устанавливается во вкладке Советники настроек клиентского терминала.
DLL-библиотеки могут также применяться для защиты эксперта с помощью переноса основного кода торговой стратегии в DLL-файл.
Свойство TERMINAL_TRADE_ALLOWED показывает, включена ли кнопка авто-торговли в клиентском терминале.
Для проверки этого свойства в функцию OnTick () можно включить код, использующий свойство TERMINAL_TRADE_ALLOWED.
Однако разрешение на торговлю с помощью эксперта может быть отключено в общих свойствах самого эксперта.
Для проверки этого условия можно использовать свойство MQL_TRADE_ALLOWED функции MQLInfoInteger.
С помощью свойства SYMBOL_SPREAD функции SymbolInfoInteger можно осуществить контроль над спредом брокера:
Здесь с помощью свойства SYMBOL_DIGITS выясняем, сколько знаков после запятой в цене и вычисляем спред в пунктах.
Затем сравниваем его с пороговым значением, и, если текущий спред больше порогового значения, торговлю не осуществляем.
С помощью свойства SYMBOL_TRADE_MODE функции SymbolInfoInteger можно проверить ограничения на торговые операции по символу, установленные брокером.
Здесь мы сравниваем значение свойства SYMBOL_TRADE_MODE с константой SYMBOL_TRADE_MODE_FULL.
Например, по какому-либо финансовому инструменту брокер может отключить торговлю.
Также в функции OnTick можно ограничить работу эксперта по времени.
Если вы хотите, чтобы эксперт работал каждый день в заданный интервал времени, определите начальные и конечные час и минуты временного интервала и сравните их с текущим временем.
Здесь берется локальное время, если вы хотите сравнивать с серверным временем, используйте функцию TimeCurrent, а не функцию TimeLocal.
Если вы хотите, чтобы эксперт просто отработал в заданный интервал времени, определите начальную и конечную даты временного интервала и сравните их с текущим временем.
В функции OnTick эксперта также было бы неплохо проверить, достаточно ли баров в истории для расчета советника.
Сделать это можно двумя способами — с помощью функции Bars и с помощью свойства SERIES_BARS_COUNT функции SeriesInfoInteger.
Ограничить вычисления советника в функции OnTick по появлению нового бара на графике также можно двумя способами, с помощью свойства SERIES_LASTBAR_DATE функции SeriesInfoInteger или с помощью функции CopyTime.
То есть здесь мы проводим вычисления в функции OnTick только при появлении нового бара на графике символа, пропуская все промежуточные тики.
Делаем мы это, получая время открытия последнего бара и используя статическую локальную переменную для сравнения.
Если вы, предположим, хотите, после того как поймали StopLoss, прекратить на сегодня торговлю советником, вам нужно правильно обработать это StopLoss событие.
Как известно, функция OnTrade вызывается при открытии или закрытии позиции, установке, модификации или удалении отложенного ордера, отмене отложенного ордера при нехватке средств либо по истечении срока действия, срабатывании отложенного ордера, модификации открытой позиции.
Поэтому в функции OnTrade нужно выделить только события совершения сделок, а затем из сделок выделить событие закрытия позиции по StopLoss:
Здесь функция HistorySelect запрашивает историю сделок и ордеров за все время, затем с помощью функции HistoryDealsTotal мы получаем индекс последней сделки и сравниваем его со статической переменной, хранящей индекс предыдущей сделки. Таким образом, мы выделяем только события совершения сделок.
С помощью функции HistoryDealGetTicket получаем тикет последней сделки и, используя свойство DEAL_COMMENT функции HistoryDealGetString, получаем комментарий к сделке.
Если комментарий содержит sl, тогда это была сделка закрытия позиции по StopLoss.
flagStopLoss это глобальная переменная, которую мы теперь можем использовать в функции OnTick.
Здесь эксперт прекращает вычисления, если получен StopLoss и не наступил новый дневной бар.
Это флаги flagStopLoss и IsNewBarD1 соответственно.
Так как для каждого финансового инструмента (символа) возможна только одна открытая позиция, в функции OnTick нужно организовать проверку наличия открытой позиции, чтобы не пытаться открыть ее заново, при ее фиксированном объеме.
Здесь функция PositionSelect копирует данные об открытой позиции символа в программное окружение. Затем, с помощью свойства POSITION_TYPE функции PositionGetInteger, выясняется, является ли открытая позиция позицией на продажу или покупку.
Позиции — это наличие купленных или проданных контрактов по финансовому инструменту.
Длинная позиция (Long) образуется в результате покупок в ожидании повышения цены, короткая позиция (Short) — результат продажи актива в расчете на снижение цены в будущем.
На одном счете по каждому финансовому инструменту может существовать только одна позиция.
По каждому символу в любой момент времени может быть только одна открытая позиция — длинная или короткая.
Объем позиции может увеличиваться в результате новой торговой операции в том же направлении.
То есть объем длинной позиции будет увеличен после новой покупки (операции Buy) и уменьшится после продажи (операции Sell).
Позиция считается закрытой, если в результате торговой операции объем обязательств стал равен нулю.
Такая операция называется закрытием позиции.
После выполнения различных проверок в функции OnTick следуют вычисления сигналов торговой системы эксперта.
Как правило, для вычисления сигналов торговой системы требуются исторические данные символа.
Сделать это можно с помощью функции CopyRates и структуры MqlRates, содержащей исторические цены бара символа.
Здесь в массив структуры MqlRates копируются данные последних трех баров, а затем меняется порядок доступа к массиву.
Наконец, после вычислений сигналов торговой системы