#import "TestLib.dll" //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { int x=41; TestClass::Inc(x); Print(x); }El código C# de la función Inc de la clase TestClass tiene el aspecto siguiente:
public class TestClass { public static void Inc(ref int x) { x++; } }Como resultado de la ejecución, el script retornará el valor 42.
struct MqlTick
{
datetime time; // Hora de la última actualización de precios
double bid; // Precio Bid actual
double ask; // Precio Ask actual
double last; // Precio actual de la última transacción (Last)
ulong volume; // Volumen para el precio Last actual
long time_msc; // Hora de la última actualización de precios en milisegundos
uint flags; // Banderas de los ticks
double volume_real; // Volumen para el precio Last actual con precisión aumentada
};
struct MqlBookInfo { ENUM_BOOK_TYPE type; // tipo de solicitud de la enumeración ENUM_BOOK_TYPE double price; // precio long volume; // volumen double volume_real; // volumen con precisión aumentada };
//+------------------------------------------------------------------+ //| Default packing | //+------------------------------------------------------------------+ struct A { char a; int b; }; //+------------------------------------------------------------------+ //| Specified packing | //+------------------------------------------------------------------+ struct B pack(4) { char a; int b; }; //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { Print("sizeof(A)=",sizeof(A)); Print("sizeof(B)=",sizeof(B)); } //+------------------------------------------------------------------+Conclusión:
sizeof(A)=5 sizeof(B)=8Podrá encontrar información más detallada sobre la alineación de estructuras en MSDN.
enum Main { PRICE_CLOSE_, PRICE_OPEN_ }; input Main Inp=PRICE_CLOSE; //+------------------------------------------------------------------+ //| Start function | //+------------------------------------------------------------------+ void OnStart() { }El compilador mostrará la advertencia:
class X { }; void f(int) { } template<typename T> void a(T*) { new T(2); } // antes, en este lugar el compilador daba error template<typename T> void a() { f(0); } void OnInit() { a<X>(); }
Documentación actualizada.
Ha sido actualizada la documentación.
Actualización de la documentación.
datetime iTime( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
double iOpen( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
double iHigh( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
double iLow( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
double iClose( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
long iVolume( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
int iBars( string symbol, // símbolo ENUM_TIMEFRAMES timeframe // periodo );
int iBarShift( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo datetime time, // hora y fecha bool exact=false // modo );
int iLowest( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int type, // identificador de la serie temporal int count, // número de elementos int start // índice );
int iHighest( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int type, // identificador de la serie temporal int count, // número de elementos int start // índice );
long iRealVolume( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
long iTickVolume( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
long iSpread( string symbol, // símbolo ENUM_TIMEFRAMES timeframe, // periodo int shift // desplazamiento );
void TesterHideIndicators( bool hide // bandera );
Actualización de la documentación.
Correciones de crash logs.
MetaTrader 5 build 1745 es la última versión de la plataforma comercial que da soporte a Microsoft Windows XP/2003/Vista.
Hace unos meses, ya anunciamos que las antiguas versiones de los sistemas operativos dejarían de tener soporte.
Windows 2003, Windows Vista y sobre todo Microsoft Windows XP son ya
muy antiguos. Microsoft dejó de dar soporte a Windows XP hace 3 años,
puesto que, debido a sus limitaciones técnicas, este sistema no permite
implementar al cien por cien las posibilidades potenciales del equipo.
MetaTrader 5 build 1745, así como las versiones de la plataforma
anteriormente publicadas, continuarán funcionando en los sistemas
operativos indicados, pero ya no recibirán ninguna actualización.
Asimismo, en los sistemas operativos mencionados tampoco se iniciarán
los instaladores.
La versión mínima para trabajar con
MetaTrader 5 será Windows 7, pero le recomendamos encarecidamente
utilizar las versiones de 64 bits de Windows 10.
La nueva versión de la plataforma no dará soporte a los terminales de escritorio y móviles de las versiones antiguas:
Para dar soporte a los nuevos proyectos compartidos se ha modificado el
protocolo de trabajo con el repositorio online MQL5 Storage. Por
desgracia, después de actualizar a la nueva versión de la plataforma,
usted deberá extraer (check-out) de nuevo todos los datos del
repositorio. Los propios datos que se guardan en él no se tocarán ni
perderán.
Antes de actualizar a la nueva versión de la
plataforma, le recomendamos enviar todos los cambios locales al
repositorio (ejecutar Commit).
Añadida la posibilidad de crear instrumentos financieros sintéticos, es decir, instrumentos basados en uno o más de los disponibles. Solo tiene que especificar la fórmula para el cálculo de las cotizaciones y la plataforma generará los ticks del instrumento sintético en tiempo real, y también creará su historia de minutos.
Cómo sucede esto
Por ejemplo, usted puede crear un instrumento que muestre el índice del dólar (USDX). Su fórmula tendrá el aspecto siguiente:
50.14348112 * pow(ask(EURUSD),-0.576) * pow(USDJPY,0.136) * pow(ask(GBPUSD),-0.119) * pow(USDCAD,0.091) * pow(USDSEK,0.042) * pow(USDCHF,0.036)
Nota: en la fórmula original del índice del dólar se usan las
parejas USDEUR y USDGBP. Puesto que en la plataforma solo hay parejas de
divisas inversas, en la fórmula del instrumento sintético para ellas se
usa la potencia negativa y el precio Ask en lugar de Bid.
La
plataforma calculará en tiempo real el precio del nuevo instrumento
basándose en las cotizaciones de los otros seis instrumentos,
proporcionados por su bróker. En la Observación del mercado y en el
gráfico, podrá ver cómo cambiar su precio:
int CustomTicksAdd( const string symbol, // nombre del símbolo const MqlTick& ticks[] // matriz con los datos de ticks que se deben aplicar al instrumento personalizado );La función CustomTicksAdd permite retransmitir los ticks como si llegaran del servidor del bróker. Los datos se registran directamente en la base de ticks, y luego se envían a la ventana "Observación del mercado". Y ya desde ella, el terminal guarda los ticks en su base. Si se transmite un gran volumen de datos en una llamada, la función cambia su comportamiento para ahorrar recursos. Si se transmiten más de 256 ticks, los datos se dividen en dos partes. La primera parte (la más grande) se registra directamente en la base de ticks (como hace CustomTicksReplace). La segunda parte, compuesta de los últimos 128 ticks, se transmite a la ventana de "Observación de mercado" y, después de ello, se guarda en la base del terminal.
En el MetaEditor han aparecido los proyectos completos. Así, desarrollar programas es mucho más cómodo.
Ahora como proyecto no actúa el principal archivo MQ5 del programa. El
proyecto es un archivo "MQPROJ" aparte, en el que se guardan los ajustes
del programa, los parámetros de compilación y la información sobre
todos los archivos utilizados. El acceso a los ajustes principales del
proyecto se organiza a través de una ventana de diálogo aparte, ya no
hay necesidad de indicarlos en el código fuente con la ayuda de
#property.
Para trabajar más cómodamente con el proyecto, ahora existe una
pestaña aparte en el Navegador. En esta se representan por categorías
todos los archivos utilizados: de inclusión, de recursos, de encabezado,
etc. Además, los archivos se añaden al navegador del proyecto de forma
automática. Por ejemplo, si usted incluye un nuevo archivo MQH en el
código, se mostrará automáticamente en el apartado "Dependencies" del
navegador.
Hemos previsto directamente la posibilidad de
trabajar con nuevos proyectos en el repositorio online MQL5 Storage.
Ahora resulta mucho más cómodo desarrollar grandes proyectos junto a
otros miembros de MQL5.community.
Para trabajar en dichos proyectos compartidos, se ha añadido el nuevo apartado Shared Projects. El proyecto creado en este apartado se envía directamente al repositorio: usted podrá conceder derechos a otros miembros y proceder al desarrollo conjunto rápidamente.
Al compilar el proyecto en Shared Project, el archivo ejecutable EX5 se copia automáticamente en el catálogo local Experts, Indicators o Scripts, dependiendo del tipo de programa. Usted podrá iniciar directamente el programa en el gráfico, sin copiar los archivos manualmente cada vez.
Cambios en el trabajo con el repositorio MQL5 Storage
Para implementar la posibilidad de trabajar con proyectos compartidos, se ha rehecho por completo el protocolo de trabajo con el repositorio MQL5 Storage. Por desgracia, después de actualizar a la nueva versión de la plataforma, usted deberá extraer (check-out) de nuevo todos los datos del repositorio. Los propios datos que se guardan en él no se tocarán ni perderán.
El comando "Extraer datos del repositorio" (Checkout from Storage) ahora no está disponible. Para extraer datos de utilizan los comandos "Activar MQL5 Storage" y "Obtener archivos del repositorio":
Nuevos proyectos: ejemplo de creación y detalles del funcionamiento
En el MetaEditor ahora existe un nuevo elemento: el proyecto propiamente dicho. Se trata de un archivo con la expansión mqproj, en el que se guardan las propiedades generales del programa, así como información sobre todos los archivos utilizados. Ahora es posible gestionar cómodamente las propiedades del programa en una ventana de diálogo propia del MetaEditor, sin tener que modificarlas manualmente en el código fuente (directivas #property).
Si usted ya dispone de desarrollos, el método más sencillo de probar los nuevos proyectos es usar el comando "Nuevo proyecto a partir de un Archivo fuente".
En el mismo catálogo que se encuentra el archivo fuente, se creará un archivo de proyecto homónimo con la expansión mqproj. Al proyecto se añadirán de forma automática las propiedades principales del programa, indicadas como #property en el archivo fuente: el nombre, el copyright, la versión, el enlace al desarrollador y la descripción.
En las propiedades de los proyectos han aparecido dos nuevas opciones para compilar programas MQL5:
Para trabajar con un proyecto se ha diseñado la pestaña aparte "Proyecto", en la ventana "Navegador". En esta pestaña se muestran cómodamente todos los archivos usados en el proyecto. Al generar el proyecto a partir de un archivo fuente, se añaden automáticamente al apartado "Dependencies" todos los archivos de inclusión utilizados (indicados con la ayuda de la directiva #include en el archivo MQ5 principal y en todos los archivos incluidos en él).
Al añadir nuevos archivos de inclusión al código fuente, dichos archivos también aparecerán en el Navegador del proyecto. En el apartado Headers se añadirán los archivos de encabezado utilizados, y en el apartado Resources, las imágenes, sonidos y otros programas MQL5 incluidos en el proyecto en forma de recursos. En el apartado Sources se muestran los archivos MQ5 con el código fuente. Al apartado Settings and files podemos añadir otros archivos, por ejemplo, los ajustes para la simulación y las plantillas para los gráficos.
Para añadir los archivos existentes al proyecto y eliminar archivos del mismo, use los comandos del menú contextual. Preste mucha atención al eliminar archivos: usted puede quitar un archivo del proyecto (suprimir la vinculación) o eliminarlo completamente del disco duro:
Crear un nuevo proyecto es igual de fácil que crear un programa MQL5 normal. Pulse "Nuevo proyecto" y, ya en el Wizard de MQL5 en el modo normal, elija el tipo de programa a crear, indicando también sus propiedades (nombre, manejador de eventos, etc).
Para obtener un archivo ejecutable EX5, usted podrá abrir el proyecto y ejecutar el comando de compilación (F7) o, como antes, abrir el archivo MQ5 principal del programa y compilarlo.
Proyectos compartidos en MQL5 Storage: detalles del funcionamiento
Para trabajar con proyectos compartidos, se ha diseñado el apartado Shared Projects. Si usted aún no ha activado el repositorio, ejecute en el menú contextual de esta carpeta el comando Activate MQL5 Storage. El MetaEditor comprobará de inmediato si hay datos guardados en su repositorio, y también si hay disponible para usted algún proyecto compartido. Los datos disponibles se extraerán instantáneamente del repositorio y luego serán cargados en la computadora (Checkout). Los proyectos compartidos disponibles se mostrarán en el apartado Shared Project, para obtenerlos, pulse "Extraer archivos del repositorio" en el menú contextual.
Para crear un nuevo proyecto compartido, elija la carpeta Shared Projects y pulse "Nuevo proyecto":
A continuación, siga los pasos estándar del Wizard MQL5: indique el tipo, el nombre y las propiedades del futuro programa. Elija para los proyectos compartidos nombres claros y comprensibles, para que los demás miembros puedan distinguirlos fácilmente. En los nombres solo se permiten letras latinas, no están permitidos los espacios en blanco.
Una vez creado, el proyecto se añadirá automáticamente al repositorio MQL5 Storage. Los archivos utilizados de la biblioteca estándar no son añadidos al repositorio, podrá añadirlos manualmente en caso necesario.
Para permitir trabajar en el proyecto a los otros integrantes, abra las propiedades del mismo. Aquí podrá conceder derechos a usuarios concretos (indicando el login de MQL5.community), y también establecer los parámetros generales del trabajo cooperativo:
Para trabajar con mayor comodidad, al compilar un proyecto
compartido, el archivo ejecutable final (EX5) se copia de forma
automática en la carpeta Experts, Indicators o Scripts, dependiendo del
tipo de programa. De esta forma, usted podrá iniciar directamente el
programa en el terminal, sin copiarlo manualmente al catálogo necesario.
Proyectos públicos en MQL5 Storage: participación en los desarrollos
Como ya hemos mencionado anteriormente, cada proyecto compartido en MQL5 Storage dispone de ajustes de privacidad: el proyecto puede ser privado o estár abierto para otros usuarios. Ahora todos los proyectos en los que se puede participar libremente se representan en la pestaña aparte "Proyectos públicos".
Cualquier usuario puede encontrar un proyecto interesante y participar en su desarrollo. Basta con pulsar "Unirse", y después recibir el proyecto desde el repositorio.
//+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { //--- archivo de la plantilla en forma de matriz binaria unsigned char my_template[]= { 0xFF,0xFE,0x3C, ... ,0x00 // la matriz de datos ha sido acortada en el ejemplo }; //--- guardamos y aplicamos la plantilla if(FileSave("my_template.tpl",my_template)) { Print("Custom template saved in \\MQL5\\Files"); if(ChartApplyTemplate(0,"\\Files\\my_template.tpl")) Print("Custom template applied to the current chart"); else Print("Failed to apply custom template"); } else Print("Failed to save custom template"); }
Función | Acción |
---|---|
CustomSymbolCreate | Crea un símbolo personalizado con el nombre indicado en el grupo indicado |
CustomSymbolDelete | Elimina el símbolo personalizado con el nombre indicado |
CustomSymbolSetInteger | Establece para el símbolo personalizado el valor de propiedad de tipo de número entero |
CustomSymbolSetDouble | Establece para el símbolo personalizado el valor de propiedad de tipo real |
CustomSymbolSetString | Establece para el símbolo personalizado el valor de propiedad de tipo string |
CustomSymbolSetMarginRate | Establece para el símbolo personalizado los coeficientes del margen de carga dependiendo del tipo y la dirección de la orden |
CustomSymbolSetSessionQuote | Establece la hora de comienzo y finalización de la sesión de cotizaciones indicada para los símbolos y el día de la semana indicados |
CustomSymbolSetSessionTrade | Establece la hora de comienzo y finalización de la sesión de comercial indicada para los símbolos y el día de la semana indicados |
CustomRatesDelete | Elimina todas las barras en el intervalo temporal indicado de la historia de precios del instrumento personalizado |
CustomRatesReplace | Sustituye totalmente la historia de precios del instrumento personalizado en el intervalo temporal indicado, con los datos de la matriz del tipo MqlRates |
CustomRatesUpdate | Añade a la historia del instrumento personalizado las barras ausentes y sustituye las existentes con datos de la matriz del tipo MqlRates |
CustomTicksAdd | Añade a la historia de precios del instrumento personalizado los datos de la matriz del tipo MqlTick. El símbolo personalizado debe ser elegido en la ventana de MarketWatch (Observación del mercado) |
CustomTicksDelete | Elimina todos los ticks en el intervalo temporal indicado de la historia de precios del instrumento personalizado |
CustomTicksReplace | Sustituye totalmente la historia de precios del instrumento personalizado en el intervalo temporal indicado, con los datos de la matriz del tipo MqlTick |
La biblioteca se ubica en el catálogo de trabajo del terminal en la carpeta Include\Generic.
bool ArraySwap( void& array1[], // primera matriz void& array2[] // segunda matriz );La función adopta matrices dinámicas de idéntico tipo e idénticas dimensiones. Para las matrices multidimensionales, deberá coincidir el número de elementos en todas las dimensiones, excepto la primera.
Añadida la posibilidad de visualizar las estadísticas de mercado de los instrumentos financieros cuyo comercio se está realizando en el modo de ejecución bursátil. Para ello, es necesario llamar desde Market Watch el menú del símbolo que le interese y desplegar sus estadísticas.
Optimizado el trabajo con las posiciones en la pestaña "Comercio". Ahora, al dar un toque sobre la celda de una posición/orden, se mostrará una imagen detallada de la misma y las posibles variantes de acción: cerrar, modificar o incrementar la posición, y también abrir el gráfico del símbolo del cual está abierta la posición.
En MetaTrader 5 Android se ha añadido la posibilidad de abrir rápidamente cuentas preliminares (preliminary) con un bróker. Para ello, usted deberá elegir el punto del menú "Abrir una cuenta real" e indicar en la lista de brókeres el suyo. A continuación, solo le quedará adjuntar a la solicitud un documento que certifique se identidad y un extracto bancario. Su solicitud de apertura de una cuenta real se enviará de inmediato al bróker, que en caso necesario le pedirá a usted información adicional.
union LongDouble { long long_value; double double_value; };A diferencia de la estructura, los diferentes miembros de una unión se relacionan con una misma zona de la memoria. En este ejemplo se ha declarado la unión LongDouble, en la que el valor del tipo long y el valor del tipo double comparten la misma zona de la memoria. Es importante comprender que no es posible hacer que la unión guarde al mismo tiempo valores de tipo entero long y reales double (como sucedía en la estructura), puesto que las variables long_value y double_value se solapan (en la memoria) una sobre otra. Sin embargo, un programa MQL5 puede en cualquier momento procesar la información que se contiene en esta unión como un valor entero (long) o como uno real (double). Por consiguiente, la unión permite obtener dos (o más) variantes de representación de una misma secuencia de datos.
union LongDouble { long long_value; double double_value; }; //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { //--- LongDouble lb; //--- obtenemos el número no válido -nan(ind) y lo mostramos lb.double_value=MathArcsin(2.0); printf("1. double=%f integer=%I64X",lb.double_value,lb.long_value); //--- valor mayor normalizado (DBL_MAX) lb.long_value=0x7FEFFFFFFFFFFFFF; printf("2. double=%.16e integer=%I64X",lb.double_value,lb.long_value); //--- menor positivo normalizado (DBL_MIN) lb.long_value=0x0010000000000000; printf("3. double=%.16e integer=%.16I64X",lb.double_value,lb.long_value); } /* Resultado de la ejecución 1. double=-nan(ind) integer=FFF8000000000000 2. double=1.7976931348623157e+308 integer=7FEFFFFFFFFFFFFF 3. double=2.2250738585072014e-308 integer=0010000000000000 */
class Foo { int value; public: string Description(void){return IntegerToString(value);}; //--- constructor por defecto Foo(void){value=-1;}; //--- constructor con parámetros Foo(int v){value=v;}; }; //+------------------------------------------------------------------+ //| estructura que contiene el objeto del tipo Foo | //+------------------------------------------------------------------+ struct MyStruct { string s; Foo foo; }; //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { //--- MyStruct a,b; Foo an_foo(5); a.s="test"; a.foo=an_foo; Print("a.s=",a.s," a.foo.Description()=",a.foo.Description()); Print("b.s=",b.s," b.foo.Description()=",b.foo.Description()); //--- Print("b=a"); b=a; //--- Print("a.s=",a.s," a.foo.Description()=",a.foo.Description()); Print("b.s=",b.s," b.foo.Description()=",b.foo.Description()); /* Resultado de la ejecución; a.s=test a.foo.Description()=5 b.s= b.foo.Description()=-1 b=a a.s=test a.foo.Description()=5 b.s=test b.foo.Description()=5 */ }En el operador implícito se realiza el copiado por miembros de los objetos.
ENUM_POSITION_REASON | ENUM_DEAL_REASON | ENUM_ORDER_REASON | Descripción de las causas |
---|---|---|---|
POSITION_REASON_CLIENT | DEAL_REASON_CLIENT | ORDER_REASON_CLIENT | La operación se ha ejecutado como resultado de la activación de una orden colocada desde el terminal de escritorio |
POSITION_REASON_MOBILE | DEAL_REASON_MOBILE | ORDER_REASON_MOBILE | La operación se ha ejecutado como resultado de una orden colocada desde el terminal móvil |
POSITION_REASON_WEB | DEAL_REASON_WEB | ORDER_REASON_WEB | La operación se ha ejecutado como resultado de la activación de una orden colocada desde la plataforma web |
POSITION_REASON_EXPERT | DEAL_REASON_EXPERT | ORDER_REASON_EXPERT | La operación se ha ejecutado como resultado de la activación de una orden colocada desde un programa MQL5: un asesor o script |
- | DEAL_REASON_SL | ORDER_REASON_SL | La operación se ha ejecutado como resultado de la activación de un Stop Loss |
- | DEAL_REASON_TP | ORDER_REASON_TP | La operación se ha ejecutado como resultado de la activación de un Take Profit |
- | DEAL_REASON_SO | ORDER_REASON_SO | La operación se ha ejecutado como resultado del evento Stop Out |
- | DEAL_REASON_ROLLOVER | - | La transacción se ha ejecutado a causa del traslado de una posición |
- | DEAL_REASON_VMARGIN | - | La transacción se ha ejecutado después de abonarse/retirarse el margen de variación |
- | DEAL_REASON_SPLIT | - | La transacción se ha ejecutado a causa del fraccionamiento (reducción del precio) de una acción u otro activo que tenía una posición abierta en el momento del anuncio del fraccionamiento |
En MetaTrader 5 iOS se ha añadido la posibilidad de abrir rápidamente cuentas preliminares (preliminary) con un bróker. Ahora es suficiente con elegir el punto del menú "Abrir una cuenta real" e indicar su servidor en la lista de servidores. Después de rellenar los datos personales, solo queda adjuntar dos documentos que acrediten su identidad y su dirección, y enviar la solicitud de registro. De esta forma, el bróker podrá abrirle una cuenta real, pidiéndole información adicional en el caso necesario.
En el build 1605 de MetaTrader 5 iOS también se ha optimizado y rediseñado el correo:
Actualización de la documentación.
Se ha añadido a MetaTrader 5 Android la representación de la historia comercial en forma de posiciones. Anteriormente, en la pestaña "Historia" se representaban solo las transacciones y órdenes de la historia, ahora es posible utilizar las posiciones para el análisis comercial. Para ello, todas las transacciones relacionadas con una posición se agrupan en un solo registro, donde se podrá ver:
Añadida la presentación de la historia comercial en forma de posiciones. Anteriormente, en la pestaña "Historia" se exhibían operaciones y órdenes, ahora en esta también se muestran las posiciones. La plataforma comercial reúne los datos de las operaciones relacionadas con una posición, y luego agrupa dichos datos en una única entrada. En esta entrada podrá ver:
//+------------------------------------------------------------------+ //| Función de plantilla | //+------------------------------------------------------------------+ template<typename T1,typename T2> string Assign(T1 &var1,T2 var2) { var1=(T1)var2; return(__FUNCSIG__); } //+------------------------------------------------------------------+ //| Sobrecarga especial para el caso bool+string | //+------------------------------------------------------------------+ string Assign(bool &var1,string var2) { var1=(StringCompare(var2,"true",false) || StringToInteger(var2)!=0); return(__FUNCSIG__); } //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { int i; bool b; Print(Assign(i,"test")); Print(Assign(b,"test")); }Como resultado de la ejecución de este código, veremos que para la pareja int+string se ha usado la función de plantilla Assign(), y en la segunda llamada bool+string ya se ha usado la función sobrecargada.
string Assign<int,string>(int&,string) string Assign(bool&,string)
template<typename T> T Func() { return (T)0; } void OnInit() { Func<double>(); // especialización explícita de la función de plantilla }De esta forma, la especialización tiene lugar no a través de los parámetros de llamada, sino mediante la indicación directa de los tipos.
Actualización de la documentación.
Actualización de la documentación.
Añadida
la posibilidad de acceder o registrase en MQL5.com a través de
Facebook. Si usted tiene una cuenta en esta red social, ahora con un par
de clicks podrá acceder a los chats y a la gama completa de servicios
para
MetaTrader 5.
#resource ruta_al_archivo_del_recurso as tipo_de_variable_de_recurso nombre_de_la_variable_de_recurso
#resource "data.bin" as int ExtData[] // declaración de matriz de tipo numérico que contiene los datos del archivo data.bin #resource "data.bin" as MqlRates ExtData[] // declaración de matriz de estructuras sencillas que contiene los datos del archivo data.bin #resource "data.txt" as string ExtCode // declaración de línea que contiene los datos del archivo data.txt #resource "data.txt" as string ExtCode[] // declaración de matriz de línea que contiene los datos del archivo data.txt #resource "image.bmp" as bitmap ExtBitmap[] // declaración de matriz unidimensional que contiene el ráster del archivo BMP, tamaño de la matriz = height * width #resource "image.bmp" as bitmap ExtBitmap2[][] // declaración de matriz bidimensional que contiene el ráster del archivo BMP, tamaño de la matriz [height][width]
Actualización de la documentación.
string str; ... if(str) // surgirá el error de compilación "Cannot convert type 'string' to 'bool'" (en los anteriores builds no sucedía así) Print("str is true");Debemos escribir una condición explícita:
string str; ... //--- comprueba si la línea de caracteres ha sido inicializada if(str!=NULL) Print("str is true"); o //--- comprueba si el valor de la línea de caracteres es "true" if(StringCompare(str,"true",false)) Print("str is true"); o //--- comprueba si la línea de caracteres es un número y es distinto de cero if((int)str!=0) Print("str is true");
Correciones de crash logs.