I am having problem with my EA not closing trade with magic number.
Can help me figure out what is wrong?
Here is the entire code below:
#define SIGNAL_NONE 0
#define SIGNAL_BUY 1
#define SIGNAL_SELL 2
#define SIGNAL_CLOSEBUY 3
#define SIGNAL_CLOSESELL 4
extern int MagicNumber = 1;
extern bool SignalMail = False;
extern bool EachTickMode = True;
extern double Lots = 0.3;
extern int Slippage = 1000;
extern bool UseStopLoss = False;
extern int StopLoss = 30;
extern bool UseTakeProfit = False;
extern int TakeProfit = 60;
extern bool UseTrailingStop = False;
extern int TrailingStop = 30;
int BarCount;
int Current;
bool TickCheck = False;
bool buyFlag = false, sellFlag = false;
datetime barStart = 0;
int pipsInProfit = 100;
bool TradingTime = false;
bool NoMoreTrades = false;
bool FailedOnce = false;
bool Uppercross = false;
bool Lowercross = false;
//+------------------------------------------------------------------+
//| expert initialization function |
//+------------------------------------------------------------------+
int init() {
BarCount = Bars;
if (EachTickMode) Current = 0; else Current = 1;
return(0);
}
//+------------------------------------------------------------------+
//| expert deinitialization function |
//+------------------------------------------------------------------+
int deinit() {
return(0);
}
//+------------------------------------------------------------------+
//| expert start function |
//+------------------------------------------------------------------+
int start() {
int Order = SIGNAL_NONE;
int Total, Ticket;
double StopLossLevel, TakeProfitLevel;
if (EachTickMode && Bars != BarCount) TickCheck = False;
Total = OrdersTotal();
Order = SIGNAL_NONE;
//+------------------------------------------------------------------+
//| Variable Begin |
//+------------------------------------------------------------------+
datetime StartTime = StrToTime("6:00");
datetime StopTime = StartTime;
datetime StartTime2 = StrToTime("12:00");
datetime StopTime2 = StartTime2;
double Upper1 = iBands(NULL, 0, 20, 2, 0, PRICE_CLOSE, MODE_UPPER, Current + 1);
double Lower1 = iBands(NULL, 0, 20, 2, 0, PRICE_CLOSE, MODE_LOWER, Current + 1);
double Middle1 = iMA(NULL, 0, 20, 0, MODE_SMA, PRICE_CLOSE, Current + 1);
double Open1 = iOpen(NULL, 0, Current + 1);
double Close1 = iClose(NULL, 0, Current + 1);
double High1 = iHigh(NULL, 0, Current + 1);
double Low1 = iLow(NULL, 0, Current + 1);
//Buy
//Close1 > Open1 && High1 > Upper1
//Sell
//Close1 < Open1 && Low1 < Lower1
//CloseBuy
//Close1 < Open1 && Close1 < Middle1
//CloseSell
//Close1 > Open1 && Close1 > Middle1
//+------------------------------------------------------------------+
//| Variable End |
//+------------------------------------------------------------------+
if (barStart < Time[0]) //start of new bar
{
barStart = Time[0];
buyFlag = false;
sellFlag = false;
if (TimeCurrent() == StartTime)
{
TradingTime = true;
NoMoreTrades = false;
FailedOnce = false;
}
if (TimeCurrent() == StartTime2)
{
TradingTime = true;
FailedOnce = false;
}
if (Close1 > Open1 && Close1 > Upper1)
{
Uppercross = true;
}
if (Close1 < Open1 && Close1 < Lower1)
{
Lowercross = true;
}
if (Close1 < Open1 && Close1 < Middle1)
{
Uppercross = false;
}
if (Close1 > Open1 && Close1 > Middle1)
{
Lowercross = false;
}
}
//Check position
bool IsTrade = False;
for (int i = 0; i < Total; i ++) {
OrderSelect(i, SELECT_BY_POS, MODE_TRADES);
if(OrderType() <= OP_SELL && OrderSymbol() == Symbol()) {
IsTrade = True;
if(OrderType() == OP_BUY) {
//Close
//+------------------------------------------------------------------+
//| Signal Begin(Exit Buy) |
//+------------------------------------------------------------------+
if (buyFlag == false && Close1 < Open1 && Close1 < Middle1)
{
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) >= pipsInProfit*Point)
{
NoMoreTrades = true;
}
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) < pipsInProfit*Point && FailedOnce == true)
{
TradingTime = false;
}
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) < pipsInProfit*Point && FailedOnce == false)
{
FailedOnce = true;
}
Order = SIGNAL_CLOSEBUY;
}
//+------------------------------------------------------------------+
//| Signal End(Exit Buy) |
//+------------------------------------------------------------------+
if (Order == SIGNAL_CLOSEBUY && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
OrderClose(OrderTicket(), OrderLots(), Bid, Slippage, MediumSeaGreen);
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Bid, Digits) + " Close Buy");
if (!EachTickMode) BarCount = Bars;
IsTrade = False;
continue;
}
//Trailing stop
if(UseTrailingStop && TrailingStop > 0) {
if(Bid - OrderOpenPrice() > Point * TrailingStop) {
if(OrderStopLoss() < Bid - Point * TrailingStop) {
OrderModify(OrderTicket(), OrderOpenPrice(), Bid - Point * TrailingStop, OrderTakeProfit(), 0, MediumSeaGreen);
if (!EachTickMode) BarCount = Bars;
continue;
}
}
}
} else {
//Close
//+------------------------------------------------------------------+
//| Signal Begin(Exit Sell) |
//+------------------------------------------------------------------+
if (sellFlag == false && Close1 > Open1 && Close1 > Middle1)
{
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) >= pipsInProfit*Point)
{
NoMoreTrades = true;
}
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) < pipsInProfit*Point && FailedOnce == true)
{
TradingTime = false;
}
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) < pipsInProfit*Point && FailedOnce == false)
{
FailedOnce = true;
}
Order = SIGNAL_CLOSESELL;
}
//+------------------------------------------------------------------+
//| Signal End(Exit Sell) |
//+------------------------------------------------------------------+
if (Order == SIGNAL_CLOSESELL && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
OrderClose(OrderTicket(), OrderLots(), Ask, Slippage, DarkOrange);
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Ask, Digits) + " Close Sell");
if (!EachTickMode) BarCount = Bars;
IsTrade = False;
continue;
}
//Trailing stop
if(UseTrailingStop && TrailingStop > 0) {
if((OrderOpenPrice() - Ask) > (Point * TrailingStop)) {
if((OrderStopLoss() > (Ask + Point * TrailingStop)) || (OrderStopLoss() == 0)) {
OrderModify(OrderTicket(), OrderOpenPrice(), Ask + Point * TrailingStop, OrderTakeProfit(), 0, DarkOrange);
if (!EachTickMode) BarCount = Bars;
continue;
}
}
}
}
}
}
//+------------------------------------------------------------------+
//| Signal Begin(Entry) |
//+------------------------------------------------------------------+
if (TradingTime == true && NoMoreTrades == false && Close1 > Open1 && Close1 > Upper1)
{
Order = SIGNAL_BUY;
buyFlag = true;
}
if (TradingTime == true && NoMoreTrades == false && Close1 < Open1 && Close1 < Lower1)
{
Order = SIGNAL_SELL;
sellFlag = true;
}
//+------------------------------------------------------------------+
//| Signal End |
//+------------------------------------------------------------------+
//Buy
if (Order == SIGNAL_BUY && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
if(!IsTrade) {
//Check free margin
if (AccountFreeMargin() < (1000 * Lots)) {
Print("We have no money. Free Margin = ", AccountFreeMargin());
return(0);
}
if (UseStopLoss) StopLossLevel = Ask - StopLoss * Point; else StopLossLevel = 0.0;
if (UseTakeProfit) TakeProfitLevel = Ask + TakeProfit * Point; else TakeProfitLevel = 0.0;
Ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, StopLossLevel, TakeProfitLevel, "Buy(#" + MagicNumber + ")", MagicNumber, 0, DodgerBlue);
if(Ticket > 0) {
if (OrderSelect(Ticket, SELECT_BY_TICKET, MODE_TRADES)) {
Print("BUY order opened : ", OrderOpenPrice());
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Ask, Digits) + " Open Buy");
} else {
Print("Error opening BUY order : ", GetLastError());
}
}
if (EachTickMode) TickCheck = True;
if (!EachTickMode) BarCount = Bars;
return(0);
}
}
//Sell
if (Order == SIGNAL_SELL && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
if(!IsTrade) {
//Check free margin
if (AccountFreeMargin() < (1000 * Lots)) {
Print("We have no money. Free Margin = ", AccountFreeMargin());
return(0);
}
if (UseStopLoss) StopLossLevel = Bid + StopLoss * Point; else StopLossLevel = 0.0;
if (UseTakeProfit) TakeProfitLevel = Bid - TakeProfit * Point; else TakeProfitLevel = 0.0;
Ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, StopLossLevel, TakeProfitLevel, "Sell(#" + MagicNumber + ")", MagicNumber, 0, DeepPink);
if(Ticket > 0) {
if (OrderSelect(Ticket, SELECT_BY_TICKET, MODE_TRADES)) {
Print("SELL order opened : ", OrderOpenPrice());
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Bid, Digits) + " Open Sell");
} else {
Print("Error opening SELL order : ", GetLastError());
}
}
if (EachTickMode) TickCheck = True;
if (!EachTickMode) BarCount = Bars;
return(0);
}
}
if (!EachTickMode) BarCount = Bars;
return(0);
}
//+------------------------------------------------------------------+
Can help me figure out what is wrong?
Here is the entire code below:
#define SIGNAL_NONE 0
#define SIGNAL_BUY 1
#define SIGNAL_SELL 2
#define SIGNAL_CLOSEBUY 3
#define SIGNAL_CLOSESELL 4
extern int MagicNumber = 1;
extern bool SignalMail = False;
extern bool EachTickMode = True;
extern double Lots = 0.3;
extern int Slippage = 1000;
extern bool UseStopLoss = False;
extern int StopLoss = 30;
extern bool UseTakeProfit = False;
extern int TakeProfit = 60;
extern bool UseTrailingStop = False;
extern int TrailingStop = 30;
int BarCount;
int Current;
bool TickCheck = False;
bool buyFlag = false, sellFlag = false;
datetime barStart = 0;
int pipsInProfit = 100;
bool TradingTime = false;
bool NoMoreTrades = false;
bool FailedOnce = false;
bool Uppercross = false;
bool Lowercross = false;
//+------------------------------------------------------------------+
//| expert initialization function |
//+------------------------------------------------------------------+
int init() {
BarCount = Bars;
if (EachTickMode) Current = 0; else Current = 1;
return(0);
}
//+------------------------------------------------------------------+
//| expert deinitialization function |
//+------------------------------------------------------------------+
int deinit() {
return(0);
}
//+------------------------------------------------------------------+
//| expert start function |
//+------------------------------------------------------------------+
int start() {
int Order = SIGNAL_NONE;
int Total, Ticket;
double StopLossLevel, TakeProfitLevel;
if (EachTickMode && Bars != BarCount) TickCheck = False;
Total = OrdersTotal();
Order = SIGNAL_NONE;
//+------------------------------------------------------------------+
//| Variable Begin |
//+------------------------------------------------------------------+
datetime StartTime = StrToTime("6:00");
datetime StopTime = StartTime;
datetime StartTime2 = StrToTime("12:00");
datetime StopTime2 = StartTime2;
double Upper1 = iBands(NULL, 0, 20, 2, 0, PRICE_CLOSE, MODE_UPPER, Current + 1);
double Lower1 = iBands(NULL, 0, 20, 2, 0, PRICE_CLOSE, MODE_LOWER, Current + 1);
double Middle1 = iMA(NULL, 0, 20, 0, MODE_SMA, PRICE_CLOSE, Current + 1);
double Open1 = iOpen(NULL, 0, Current + 1);
double Close1 = iClose(NULL, 0, Current + 1);
double High1 = iHigh(NULL, 0, Current + 1);
double Low1 = iLow(NULL, 0, Current + 1);
//Buy
//Close1 > Open1 && High1 > Upper1
//Sell
//Close1 < Open1 && Low1 < Lower1
//CloseBuy
//Close1 < Open1 && Close1 < Middle1
//CloseSell
//Close1 > Open1 && Close1 > Middle1
//+------------------------------------------------------------------+
//| Variable End |
//+------------------------------------------------------------------+
if (barStart < Time[0]) //start of new bar
{
barStart = Time[0];
buyFlag = false;
sellFlag = false;
if (TimeCurrent() == StartTime)
{
TradingTime = true;
NoMoreTrades = false;
FailedOnce = false;
}
if (TimeCurrent() == StartTime2)
{
TradingTime = true;
FailedOnce = false;
}
if (Close1 > Open1 && Close1 > Upper1)
{
Uppercross = true;
}
if (Close1 < Open1 && Close1 < Lower1)
{
Lowercross = true;
}
if (Close1 < Open1 && Close1 < Middle1)
{
Uppercross = false;
}
if (Close1 > Open1 && Close1 > Middle1)
{
Lowercross = false;
}
}
//Check position
bool IsTrade = False;
for (int i = 0; i < Total; i ++) {
OrderSelect(i, SELECT_BY_POS, MODE_TRADES);
if(OrderType() <= OP_SELL && OrderSymbol() == Symbol()) {
IsTrade = True;
if(OrderType() == OP_BUY) {
//Close
//+------------------------------------------------------------------+
//| Signal Begin(Exit Buy) |
//+------------------------------------------------------------------+
if (buyFlag == false && Close1 < Open1 && Close1 < Middle1)
{
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) >= pipsInProfit*Point)
{
NoMoreTrades = true;
}
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) < pipsInProfit*Point && FailedOnce == true)
{
TradingTime = false;
}
if (OrderType() == OP_BUY && (Bid - OrderOpenPrice()) < pipsInProfit*Point && FailedOnce == false)
{
FailedOnce = true;
}
Order = SIGNAL_CLOSEBUY;
}
//+------------------------------------------------------------------+
//| Signal End(Exit Buy) |
//+------------------------------------------------------------------+
if (Order == SIGNAL_CLOSEBUY && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
OrderClose(OrderTicket(), OrderLots(), Bid, Slippage, MediumSeaGreen);
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Bid, Digits) + " Close Buy");
if (!EachTickMode) BarCount = Bars;
IsTrade = False;
continue;
}
//Trailing stop
if(UseTrailingStop && TrailingStop > 0) {
if(Bid - OrderOpenPrice() > Point * TrailingStop) {
if(OrderStopLoss() < Bid - Point * TrailingStop) {
OrderModify(OrderTicket(), OrderOpenPrice(), Bid - Point * TrailingStop, OrderTakeProfit(), 0, MediumSeaGreen);
if (!EachTickMode) BarCount = Bars;
continue;
}
}
}
} else {
//Close
//+------------------------------------------------------------------+
//| Signal Begin(Exit Sell) |
//+------------------------------------------------------------------+
if (sellFlag == false && Close1 > Open1 && Close1 > Middle1)
{
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) >= pipsInProfit*Point)
{
NoMoreTrades = true;
}
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) < pipsInProfit*Point && FailedOnce == true)
{
TradingTime = false;
}
if (OrderType() == OP_SELL && (OrderOpenPrice() - Ask) < pipsInProfit*Point && FailedOnce == false)
{
FailedOnce = true;
}
Order = SIGNAL_CLOSESELL;
}
//+------------------------------------------------------------------+
//| Signal End(Exit Sell) |
//+------------------------------------------------------------------+
if (Order == SIGNAL_CLOSESELL && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
OrderClose(OrderTicket(), OrderLots(), Ask, Slippage, DarkOrange);
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Ask, Digits) + " Close Sell");
if (!EachTickMode) BarCount = Bars;
IsTrade = False;
continue;
}
//Trailing stop
if(UseTrailingStop && TrailingStop > 0) {
if((OrderOpenPrice() - Ask) > (Point * TrailingStop)) {
if((OrderStopLoss() > (Ask + Point * TrailingStop)) || (OrderStopLoss() == 0)) {
OrderModify(OrderTicket(), OrderOpenPrice(), Ask + Point * TrailingStop, OrderTakeProfit(), 0, DarkOrange);
if (!EachTickMode) BarCount = Bars;
continue;
}
}
}
}
}
}
//+------------------------------------------------------------------+
//| Signal Begin(Entry) |
//+------------------------------------------------------------------+
if (TradingTime == true && NoMoreTrades == false && Close1 > Open1 && Close1 > Upper1)
{
Order = SIGNAL_BUY;
buyFlag = true;
}
if (TradingTime == true && NoMoreTrades == false && Close1 < Open1 && Close1 < Lower1)
{
Order = SIGNAL_SELL;
sellFlag = true;
}
//+------------------------------------------------------------------+
//| Signal End |
//+------------------------------------------------------------------+
//Buy
if (Order == SIGNAL_BUY && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
if(!IsTrade) {
//Check free margin
if (AccountFreeMargin() < (1000 * Lots)) {
Print("We have no money. Free Margin = ", AccountFreeMargin());
return(0);
}
if (UseStopLoss) StopLossLevel = Ask - StopLoss * Point; else StopLossLevel = 0.0;
if (UseTakeProfit) TakeProfitLevel = Ask + TakeProfit * Point; else TakeProfitLevel = 0.0;
Ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, StopLossLevel, TakeProfitLevel, "Buy(#" + MagicNumber + ")", MagicNumber, 0, DodgerBlue);
if(Ticket > 0) {
if (OrderSelect(Ticket, SELECT_BY_TICKET, MODE_TRADES)) {
Print("BUY order opened : ", OrderOpenPrice());
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Ask, Digits) + " Open Buy");
} else {
Print("Error opening BUY order : ", GetLastError());
}
}
if (EachTickMode) TickCheck = True;
if (!EachTickMode) BarCount = Bars;
return(0);
}
}
//Sell
if (Order == SIGNAL_SELL && ((EachTickMode && !TickCheck) || (!EachTickMode && (Bars != BarCount)))) {
if(!IsTrade) {
//Check free margin
if (AccountFreeMargin() < (1000 * Lots)) {
Print("We have no money. Free Margin = ", AccountFreeMargin());
return(0);
}
if (UseStopLoss) StopLossLevel = Bid + StopLoss * Point; else StopLossLevel = 0.0;
if (UseTakeProfit) TakeProfitLevel = Bid - TakeProfit * Point; else TakeProfitLevel = 0.0;
Ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, StopLossLevel, TakeProfitLevel, "Sell(#" + MagicNumber + ")", MagicNumber, 0, DeepPink);
if(Ticket > 0) {
if (OrderSelect(Ticket, SELECT_BY_TICKET, MODE_TRADES)) {
Print("SELL order opened : ", OrderOpenPrice());
if (SignalMail) SendMail("[Signal Alert]", "[" + Symbol() + "] " + DoubleToStr(Bid, Digits) + " Open Sell");
} else {
Print("Error opening SELL order : ", GetLastError());
}
}
if (EachTickMode) TickCheck = True;
if (!EachTickMode) BarCount = Bars;
return(0);
}
}
if (!EachTickMode) BarCount = Bars;
return(0);
}
//+------------------------------------------------------------------+