Site hosted by Angelfire.com: Build your free website today!
Página principal | Lista de componentes | Lista de archivos | Miembros de las clases | Archivos de los miembros

Referencia del Archivo ADH_port.h

Encabezado para que los programas puedan ser compilados con varios compiladores. Más...

Ir al código fuente de este archivo.

Definiciones

#define ADH_port_h
 Evita la inclusión múltiple.
#define OPEN_namespace(N)   namespace N {
 Abre namespace "N".
#define CLOSE_namespace(N)   }
 Cierra namespace "N".
#define USING_namespace(N)   using namespace N
 Usa namespace "N".


Descripción detallada

Encabezado para que los programas puedan ser compilados con varios compiladores.

Este archivo de encabezado permite compilar los programas de adolfo@di-mare.com usando cualquiera de estos compiladores:

Uso de "namespace"
Para permitir que el código sea compilador con el Borland C++ v3.1, que no permite usar "namespace", los programas están escritos usando estas macros, que sirven para iniciar, usar y terminar un "namespace":

Uso de "#include"
El compilador C++ de Visual Studio .NET usa nombres de archivos de encabezado que no tienen el sufijo ".h". Por ejemplo, para usar un flujo de entrada, el programador debe incluir estas líneas:

Para incluir el archivo de encabezado correcto es necesario establecer cuál compilador se está usando. Para evitar usar varias directivas # ifdef, se puede definir una macro que indica cuál archivos de encabezado incluir. No todos los encabezados estándar están incorporados aquí, pero sí los más usados. Por ejemplo, para usar el archvio de encabadezdos <iostream> basta incluir en el código fuente la definición de este macro:

Diferencias entre MSC++ v6 y MSC++ .NET
Lo usual es encontrar código escrito para la versión vieja del compilador de Microsoft, el MSC++ v6.0 o anterior. Con frecuencia, basta hacer estas modificaciones para que el código pueda ser compilador con MSC++ .NET:

Borland C++ v3.1
En algunas ocasiones conviene más usar el compilador BC++ v3.1 porque es un compilador que requiere muy pocos recursos traducir programas.Desafortundamente, el BC++ v3.1 tiene varias restricciones de funcionamiento entre las que se destacan éstas:

Algunos ejemplos C++ son sólo puedes ser expresado correctamente usando el lenguaje C++ moderno, est ndar. Pero muchos otros no requieren tanta expresividad por lo que pueden ser compilados con BC++ v3.1. Para lograrlo es necesario usar.

Ejemplo de uso
    #ifndef String_h
    #define String_h // Evita la inclusión múltiple

    #define  INCLUDE_iostream // ==> # include <iostream>
    #include "ADH_port.h"

    OPEN_namespace(ADH)
    USING_namespace(std); // es necesario agregar el punto y coma

    class String{
        // ...
    };

    CLOSE_namespace(ADH)

    USING_namespace(ADH); // es necesario agregar el ";"
    ADH::String& operator<<( std::ostream COUT&; ADH::String& s);

    #endif // String_h
Resultado en Borland C++ v3.1
    #ifndef String_h
    #define String_h // Evita la inclusión múltiple

    #include <iostream.h>
    #include "ADH_port.h"

    // namespace ADH {       //  ==> eliminado
    ; // using namespace std // ==> eliminado

    class String{
        // ...
    };

    // }  ==> eliminado

    // using namespace ADH;  // ==> eliminado  // ADH && std ==> eliminado
    ::String& operator<<( ::ostream COUT&; ::String& s);

    #endif // String_h
Resultado en Microsft C++ .NET
    #ifndef String_h
    #define String_h // Evita la inclusión múltiple

    #include <iostream> // sin ".h"
    #include "ADH_port.h"
    using namespace std; // Agregado en "ADH_port.h"

    namespace ADH {
    using namespace std;

    class String{
        // ...
    };

    } // namespace ADH

    using namespace ADH;
    ADH::String& operator<<( std::ostream COUT&; ADH::String& s);

    #endif // String_h
Autor:
Adolfo Di Mare <adolfo@di-mare.com>
Fecha:
2005

Definición en el archivo ADH_port.h.


Documentación de las definiciones

#define ADH_port_h
 

Evita la inclusión múltiple.

Definición en la línea 145 del archivo ADH_port.h.

#define OPEN_namespace  )     namespace N {
 

Abre namespace "N".

Definición en la línea 153 del archivo ADH_port.h.

#define CLOSE_namespace  )     }
 

Cierra namespace "N".

Definición en la línea 156 del archivo ADH_port.h.

#define USING_namespace  )     using namespace N
 

Usa namespace "N".

Definición en la línea 159 del archivo ADH_port.h.


Generado el Tue Nov 15 14:57:19 2005 para A45510-A33018 Tarea Programada #8 por  doxygen 1.4.1