Erros, bugs, perguntas - página 1620

 
Infelizmente, nem sempre. Se não se ligar durante muito tempo, o terminal emite "Account disable" (desactivar conta) e depois tem de iniciar a sessão manualmente. Isto acontece, por exemplo, numa fundação onde os servidores são normalmente desligados à noite.
 
Dmitri Custurov:
Infelizmente, nem sempre. Se não se ligar durante muito tempo, o terminal emite "Account disable" (desactivar conta) e depois tem de iniciar a sessão manualmente. Isto acontece, por exemplo, numa fundação onde os servidores são normalmente desligados à noite.
E neste caso (com uma longa falta de ligação), se executar o comando "Ficheiro" -> "Ligar à conta de negociação" na janela será exactamente a mesma conta de negociação?
 
Exactamente o mesmo. Só criei uma conta.
 
Dmitri Custurov:
Olá a todos. Fiz esta pergunta há várias páginas, mas vou tentar novamente. Há alguma forma de voltar a registar a minha conta quando a ligação ao servidor MT5 é interrompida? A pesquisa nos fóruns não deu nada.
Se eu reiniciar o terminal, começa com a execução de EAs (não tenho o terminal instalado, não posso verificar)? Se sim, então pode escrever um guião de shell que fará o reinício. E retira este guião do teu EA.
 
Dmitri Custurov:
Infelizmente, nem sempre. Se não se ligar durante muito tempo, o terminal emite "Account disable" (desactivar conta) e depois tem de iniciar a sessão manualmente. Isto acontece, por exemplo, num fundo onde os servidores são normalmente desligados à noite.
Isto é ou um bug ou uma configuração específica do corretor. Por favor contacte o Service Desk com este problema. Isso não deveria acontecer.
 
Podem os criadores comentar a capacidade prometida, mas não implementada, de devolver um valor de função por referência? Não a comentaram, ou há alguma dificuldade com ela?
 
Dmitri Custurov:
Infelizmente nem sempre. Se não se ligar durante muito tempo, o terminal emite "Account disable" (desactivar conta) e depois tem de fazer o login manualmente. Isto acontece, por exemplo, numa fundação onde os servidores são normalmente desligados à noite.

Aqui está o script que traz o menu "File" - "Connect to trading account" - clique no botão "OK" - para que o terminal se ligue à última conta de negociação que foi autenticada:

Ligar a uma conta de negociação

//+------------------------------------------------------------------+
//|                                                    ClickMenu.mq5 |
//|                              Copyright © 2016, Vladimir Karputov |
//|                                           http://wmua.ru/slesar/ |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2016, Vladimir Karputov"
#property link      "http://wmua.ru/slesar/"
#property version   "1.00"
#property script_show_inputs
input int number_menu=1;               //меню "Файл"
input int item_menu=14;                //пункт "Подключиться к торговому счёту"

#ifndef  _IsX64
#define  HWND long
#define  HMENU long
#define  HBITMAP long
#define  ULONG_PTR long
#else
#define  HWND int
#define  HMENU int
#define  HBITMAP int
#define  ULONG_PTR int
#endif 

#define  UINT int
#define  GA_ROOT            0x0002      // Retrieves the root window by walking the chain of parent windows
#define  WM_COMMAND         0x0111
#define  MIIM_STRING        0x00000040
#define  MIIM_SUBMENU       0x00000004
#define  BM_CLICK           0x000000F5

#import "user32.dll"
int  GetLastError();
//+------------------------------------------------------------------+
//| GetAncestor. Retrieves the handle to the ancestor of the         |
//| specified window. Извлекает дескриптор предка заданного окна     |
//+------------------------------------------------------------------+
HWND  GetAncestor(HWND hwnd,UINT gaFlags);
HMENU GetMenu(HWND hWnd);
//int   GetMenuItemCount(HMENU hMenu);
HMENU GetSubMenu(HMENU hMenu,int   nPos);
int   GetMenuItemID(HMENU hMenu,int nPos);
bool  PostMessageW(HWND hWnd,UINT Msg,int wParam,int lParam);
HWND  GetLastActivePopup(HWND hWnd);
HWND  GetDlgItem(HWND hDlg,int nIDDlgItem);
#import
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
//---
   long  mainChartID=ChartID();                          //возвращает идентификатор текущего графика
   int   hdlmainChartID=ChartWindowsHandle(mainChartID); //получает хэндл графика   
   HWND  hdlRoot=GetAncestor(hdlmainChartID,GA_ROOT);    //получает хендл предка указанного окна
                                                         //Print("hdlRoot = ",IntegerToString(hdlRoot));

   HMENU hmenu=GetMenu(hdlRoot);                         //получает хэндл главного меню терминала
/*int count_hmenu=GetMenuItemCount(hmenu);
   Print("в главном меню ",IntegerToString(count_hmenu)," элементов");*/

   HMENU hsubmenu=GetSubMenu(hmenu,number_menu);         //получает хэндл заданного подменю ("Файл")
/*int count_hsubmenu=GetMenuItemCount(hsubmenu);
   Print("в подменю ",IntegerToString(number_menu)," ",IntegerToString(count_hsubmenu)," элементов");*/
   
   int hpos=GetMenuItemID(hsubmenu,item_menu);           //получает хэндл пункта "Подключиться к торговому счёту"
   PostMessageW(hdlRoot,WM_COMMAND,hpos,0);              //кликаем на пункт "Подключиться к торговому счёту"

   Sleep(2000);
   HWND hlastPopup=GetLastActivePopup(hdlRoot);          //получает хендл последнего PopUp меню
   HWND hOK=GetDlgItem(hlastPopup,0x00000001);           //получает хенд кнопки из диалога
   PostMessageW(hOK,BM_CLICK,0,0);                       //кликаем на кнопку "OK"
  }
//+------------------------------------------------------------------+
//| The function gets the handle graphics                            |
//| Функция получает хэндл графика                                   |
//+------------------------------------------------------------------+
int ChartWindowsHandle(long chart_ID)
  {
//--- prepare the variable to get the property value
//--- подготовим переменную для получения значения свойства
   long result=-1;
//--- reset the error value
//--- сбросим значение ошибки
   ResetLastError();
//--- receive the property value
//--- получим значение свойства
   if(!ChartGetInteger(chart_ID,CHART_WINDOW_HANDLE,0,result))
     {
      //--- display the error message in Experts journal
      //--- выведем сообщение об ошибке в журнал "Эксперты"
      Print(__FUNCTION__+", Error Code = ",GetLastError());
     }
//--- return the value of the chart property
//--- вернем значение свойства графика
   return((int)result);
  }
//+------------------------------------------------------------------+

Se tudo funcionar, limparei o código e afixá-lo-ei no KodoBase.

Arquivos anexados:
ClickMenu.mq5  5 kb
 

MQL4. A descrição StringToCharArray() diz "Simbolicamente copia uma corda convertida de unicode para ansi num local especificado de um conjunto de tipo uchar". Tenho a impressão de que existe um erro na descrição. Com esta função, pode simplesmente converter um carácter num número correspondente ao código, dependendo da codificação do carácter (a função tem 5 parâmetros). Ou seja, aqui não há conversão "... de unicode para ansi...". Corrija-me se estiver errado.

Se precisar de encontrar código, por exemplo, por símbolo de euros para Ansi, então no lugar do 5º parâmetro, escreverei CP_ACP. Se como UTF7, então CP_UTF7. Se para Unicode, eu uso StringToShortArray() (ver guião).

#property strict
void OnStart()
  {
   string a = "€"; // euro symbol
   uchar  ArrayAnsi[1], ArrayUTF7[1];
   ushort ArrayUnicode[1];
   
   int Count;
   Count=StringToCharArray(a,ArrayAnsi,0,WHOLE_ARRAY,CP_ACP);
   Print("1) € in Ansi = ",IntegerToString(ArrayAnsi[0]));
   
   Count=StringToCharArray(a,ArrayUTF7,0,WHOLE_ARRAY,CP_UTF7);
   Print("2) € in UTF7 = ",IntegerToString(ArrayUTF7[0]));

   Count=StringToShortArray(a,ArrayUnicode,0,WHOLE_ARRAY);
   Print("3) € in Unicode = ",IntegerToString(ArrayUnicode[0]));
  }


 

Um erro no compilador.

template<typename T>  void  Func (T&)     {  }
template<typename T>  void  Func (T*&)    {  }

template<typename T>  void  InterFunc(T& var)  { Func(var); }   // 'var' - parameter conversion not allowed
  

class A {  };


void F1()  { A a;   InterFunc(a);  }

void F2()  { A* a;  Func(a);  }

Se retirar a função F2, no entanto, esta compila normalmente.

 

Erro de compilação.

class A {  };


void Func(A* const&)   {   }


void OnStart()
  {    
    A* const a= NULL;
    
    Func(a);  // 'a' - cannot convert from const pointer to nonconst pointer
  }
Razão: