]> git.llucax.com Git - z.facultad/75.00/informe.git/blobdiff - source/d.rst
Reemplazar multi-procesador por multi-core
[z.facultad/75.00/informe.git] / source / d.rst
index 4b411d8e3b0c4768832da2d6d73b54a94b72c698..a6af7c336fc1221cdcaf74e6a6365332979d48d2 100644 (file)
@@ -1,9 +1,5 @@
 
 
-.. Introducción y breve reseña del lenguaje de programación D. También
-   se presentan las necesidades particulares de D con respecto al
-   recolector de basura y su estado actual.
-   ESTADO: TERMINADO, CORREGIDO (A)
-
+.. highlight:: d
 
 .. _d_lang:
 
 
 .. _d_lang:
 
@@ -29,7 +25,8 @@ compilaba a código nativo, y está fuertemente influenciado por éste. Sin
 embargo toma muchos conceptos de otros lenguajes de más alto nivel, como Java_
 o incluso lenguajes dinámicos como Perl_, Python_ y Ruby_.
 
 embargo toma muchos conceptos de otros lenguajes de más alto nivel, como Java_
 o incluso lenguajes dinámicos como Perl_, Python_ y Ruby_.
 
-El origen del lenguaje está plasmado en su sitio web, en donde se cita:
+El origen del lenguaje está plasmado en su sitio web, en donde se cita
+[DWEB]_:
 
    It seems to me that most of the "new" programming languages fall into one
    of two categories: Those from academia with radical new paradigms and those
 
    It seems to me that most of the "new" programming languages fall into one
    of two categories: Those from academia with radical new paradigms and those
@@ -101,7 +98,7 @@ mantenida y usada; y una alternativa de mayor calidad y apertura a la
 comunidad (pero no estándar). El peor problema es que ambas son
 **incompatibles**, por lo que un programa hecho con Tango_ no funciona con
 Phobos_ y viceversa (a menos que el programador haya invertido una cantidad de
 comunidad (pero no estándar). El peor problema es que ambas son
 **incompatibles**, por lo que un programa hecho con Tango_ no funciona con
 Phobos_ y viceversa (a menos que el programador haya invertido una cantidad de
-tiempo considerable en asegurarse de que funcione con ambas).
+tiempo considerable en asegurarse que funcione con ambas).
 
 Esto hace que la compatibilidad de programas y bibliotecas esté muy
 fragmentada entre las dos bibliotecas base. Si bien no parece que vaya a haber
 
 Esto hace que la compatibilidad de programas y bibliotecas esté muy
 fragmentada entre las dos bibliotecas base. Si bien no parece que vaya a haber
@@ -141,33 +138,21 @@ compatibilidad hacia atrás, y cuenta con la experiencia del camino recorrido
 por C++, pudiendo extraer de él los mejores conceptos pero evitando sus
 mayores problemas.
 
 por C++, pudiendo extraer de él los mejores conceptos pero evitando sus
 mayores problemas.
 
-Otra gran diferencia con C++ es la facilidad para ser analizado
-sintácticamente (*parsing*), ya que fue especialmente diseñado para ser
-sencillo y a diferencia de C y C++ su gramática es independiente del contexto
-(*context-free grammar*). Esto permite que D pueda ser compilado en pequeños
-pasos bien separados:
-
-1. Análisis léxico.
-2. Análisis sintáctico.
-3. Análisis semántico.
-4. Optimizaciones.
-5. Generación de código.
-
-Esto favorece la creación de herramientas dada la facilidad de usar solamente
-la cantidad de análisis necesario para cada una (por ejemplo un editor de
-textos puede tener hasta análisis sintáctico para proveer resaltado o un
-entorno de desarrollo puede proveer herramientas para re-factorizar el código
-haciendo uso del análisis semántico).
+Una gran diferencia con C++ es que el análisis sintáctico (*parsing*) se puede
+realizar sin ningún tipo de análisis semántico, dado que a diferencia de éstos
+su gramática es libre de contexto (*context-free grammar*). Esto acelera
+y simplifica considerablemente el proceso de compilación [WBB10]_ [DWOV]_.
 
 
-Una de las características que nunca pudo entrar en el estándar de C++ es la
-recolección de basura. D_ no comete el mismo error.
+Otra gran diferencia es que D_ decide incluir recolección de basura como parte
+del lenguaje, mientras que en el comité de estandarización de C++ nunca se
+llegó a un consenso para su incorporación.
 
 
 Características del lenguaje
 ----------------------------------------------------------------------------
 
 A continuación se enumeran las principales características de D_, agrupadas
 
 
 Características del lenguaje
 ----------------------------------------------------------------------------
 
 A continuación se enumeran las principales características de D_, agrupadas
-por unidades funcionales o paradigmas que soporta:
+por unidades funcionales o paradigmas que soporta [DWLR]_:
 
 
 
 
 
 
@@ -195,20 +180,19 @@ D_ provee las siguientes herramientas para realizar programación genérica
 y meta-programación:
 
 ``if`` estático (``static if``)
 y meta-programación:
 
 ``if`` estático (``static if``)
-   puede verse como similar a la directiva del preprocesador de C/C++ ``#if``,
-   pero a diferencia de esto, en D_ el ``static if`` tiene acceso a todos los
-   símbolos del compilador (constantes, tipos, variables, etc).
+   Esta construcción es similar a la directiva del preprocesador de C/C++
+   ``#if``, pero a diferencia de éste, el ``static if`` de D_ tiene acceso
+   a todos los símbolos del compilador (constantes, tipos, variables, etc)
+   [DWSI]_.
 
    Ejemplo::
 
       static if ((void*).sizeof == 4)
          pragma(msg, "32 bits");
 
 
    Ejemplo::
 
       static if ((void*).sizeof == 4)
          pragma(msg, "32 bits");
 
-   Más información en http://www.digitalmars.com/d/1.0/version.html#staticif
-
 Inferencia de tipos básica implícita y explícita (mediante ``typeof``)
 Inferencia de tipos básica implícita y explícita (mediante ``typeof``)
-   si no se especifica un tipo al declarar una variable, se infiere del tipo
-   de su valor de inicialización.
+   Si no se especifica un tipo al declarar una variable, se infiere a partir
+   del tipo de su valor de inicialización [DWIN]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -216,22 +200,17 @@ Inferencia de tipos básica implícita y explícita (mediante ``typeof``)
       const d = 6.0;    // d es double
       auto s = "hola"; // s es string (que es un alias de char[])
 
       const d = 6.0;    // d es double
       auto s = "hola"; // s es string (que es un alias de char[])
 
-   Más información en
-   http://www.digitalmars.com/d/1.0/declaration.html#AutoDeclaration
-
    Mediante el uso de ``typeof`` se puede solicitar el tipo de una expresión
    Mediante el uso de ``typeof`` se puede solicitar el tipo de una expresión
-   arbitraria.
+   arbitraria [DWTO]_.
 
    Ejemplo::
 
       typeof(5 + 6.0) d; // d es double
 
 
    Ejemplo::
 
       typeof(5 + 6.0) d; // d es double
 
-   Más información en http://www.digitalmars.com/d/1.0/declaration.html#typeof
-
 Iteración sobre colecciones (``foreach``)
 Iteración sobre colecciones (``foreach``)
-   cualquier tipo de colección (arreglos estáticos y dinámicos, arreglos
+   Cualquier tipo de colección (arreglos estáticos y dinámicos, arreglos
    asociativos, clases, estructuras o delegados) puede ser iterada mediante la
    asociativos, clases, estructuras o delegados) puede ser iterada mediante la
-   sentencia ``foreach``.
+   sentencia ``foreach`` [DWFE]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -241,11 +220,11 @@ Iteración sobre colecciones (``foreach``)
          total += i;
 
 *Templates*
          total += i;
 
 *Templates*
-   clases y funciones pueden ser generalizadas. Esto permite desarrollar
+   Tanto clases como funciones pueden ser generalizadas. Esto permite desarrollar
    algoritmos genéricos sin importar el tipo de los datos de entrada, siempre
    y cuando todos los tipos tengan una *interfaz* común.   Esto también es
    conocido como *polimorfismo en tiempo de compilación*, y es la forma más
    algoritmos genéricos sin importar el tipo de los datos de entrada, siempre
    y cuando todos los tipos tengan una *interfaz* común.   Esto también es
    conocido como *polimorfismo en tiempo de compilación*, y es la forma más
-   básica de programación genérica.
+   básica de programación genérica [DWTP]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -272,75 +251,79 @@ Iteración sobre colecciones (``foreach``)
    La utilidad más prominente de los bloques generalizados se da al
    acompañarse de *mixins*.
 
    La utilidad más prominente de los bloques generalizados se da al
    acompañarse de *mixins*.
 
-Instanciación implícita de funciones generalizadas
-   el lenguaje es capaz de deducir los parámetros siempre que no hayan
-   ambigüedades.
+   Además las *templates* de D_ tienen las siguientes características
+   destacables:
 
 
-   Ejemplo::
+   Instanciación implícita de funciones generalizadas
+      El lenguaje es capaz de deducir los parámetros siempre que no hayan
+      ambigüedades.
 
 
-      auto i = sumar(5, 6);          // i == 11
-      auto f = sumar(5.0f, 6.0f); // f == 11.0f
+      Ejemplo::
 
 
-Especialización explícita y parcial de *templates*
-   la especialización de *templates* consiste, al igual que en C++, en proveer
-   una implementación especializada para un tipo de dato (o valor) de los
-   parámetros.   Especialización parcial se refiere a la capacidad de
-   especializar un parámetro a través de un subtipo. Por ejemplo, se puede
-   especializar un *template* para cualquier tipo de puntero, o para cualquier
-   tipo de arreglo dinámico, sin necesidad de especificar el tipo al que
-   apunta dicho puntero o el tipo almacenado por el arreglo.
+         auto i = sumar(5, 6);          // i == 11
+         auto f = sumar(5.0f, 6.0f); // f == 11.0f
 
 
-   Ejemplo de especialización::
+   Especialización explícita y parcial de *templates*
+      La especialización de *templates* consiste, al igual que en C++, en
+      proveer una implementación especializada para un tipo de dato (o valor)
+      de los parámetros.   Especialización parcial se refiere a la capacidad
+      de especializar un parámetro a través de un subtipo. Por ejemplo, se
+      puede especializar un *template* para cualquier tipo de puntero, o para
+      cualquier tipo de arreglo dinámico, sin necesidad de especificar el tipo
+      al que apunta dicho puntero o el tipo almacenado por el arreglo.
 
 
-      T sumar(T: int)(T x, T y) { return x + y + 1; }
-      auto i = sumar(5, 6);         // i == 12
-      auto f = sumar(5.0f, 6.0f) // f == 11.0f
+      Ejemplo de especialización::
 
 
-   Ejemplo de especialización parcial::
+         T sumar(T: int)(T x, T y) { return x + y + 1; }
+         auto i = sumar(5, 6);         // i == 12
+         auto f = sumar(5.0f, 6.0f) // f == 11.0f
 
 
-      T sumar(T: T*)(T x, T y) { return *x + *y; }
-      int x = 5, y = 6;
-      auto i = sumar(&x, &y); // i == 11
-      float v = 5.0f, w = 6.0f;
-      auto f = sumar(&v, &w); // f == 11.0f
+      Ejemplo de especialización parcial::
 
 
-Tipos, valores (incluyendo *strings*) y *templates* como parámetros
-   esto es otro bloque de construcción importantísimo para la programación
-   genérica en D, ya que combinando *templates* que toman *strings* como
-   parámetro en combinación con *string mixins* pueden hacerse toda clase de
-   meta-programas.
+         T sumar(T: T*)(T x, T y) { return *x + *y; }
+         int x = 5, y = 6;
+         auto i = sumar(&x, &y); // i == 11
+         float v = 5.0f, w = 6.0f;
+         auto f = sumar(&v, &w); // f == 11.0f
 
 
-   Ejemplo::
+   Tipos, valores (incluyendo *strings*) y *templates* como parámetros
+      Este es otro bloque de construcción importantísimo para la programación
+      genérica en D, ya que combinando *templates* que toman *strings* como
+      parámetro en combinación con *string mixins* pueden hacerse toda clase
+      de meta-programas.
 
 
-      template hash(string s, uint so_far=0) {
-         static if (s.length == 0)
-            const hash = so_far;
-         else
-            const hash = hash!(s[1 .. length], so_far * 11 + s[0]);
-      }
-      string s = hash!("hola"); // calculado en tiempo de compilación
+      Ejemplo::
 
 
-Cantidad de parámetros variables para *templates*
-   Esto permite implementar tuplas u otros algoritmos que inherentemente deben
-   tomar una cantidad variable de parámetros en tiempo de compilación.
+         template hash(string s, uint so_far=0) {
+            static if (s.length == 0)
+               const hash = so_far;
+            else
+               const hash = hash!(s[1 .. length], so_far * 11 + s[0]);
+         }
+         string s = hash!("hola"); // calculado en tiempo de compilación
 
 
-   Ejemplo::
+   Cantidad de parámetros variables para *templates*
+      Esta característica permite implementar tuplas y otros algoritmos que
+      inherentemente deben tomar una cantidad variable de parámetros en tiempo
+      de compilación.
 
 
-      double sumar(T...)(T t) {
-         double res = 0.0;
-         foreach (x; t)
-            res += x;
-         return res;
-      }
-      double d = sumar(1, 2.0, 3.0f, 4l); // d == 10.0
+      Ejemplo::
+
+         double sumar(T...)(T t) {
+            double res = 0.0;
+            foreach (x; t)
+               res += x;
+            return res;
+         }
+         double d = sumar(1, 2.0, 3.0f, 4l); // d == 10.0
 
 *CTFE* (*compile-time function execution*)
 
 *CTFE* (*compile-time function execution*)
-   si una función cumple ciertas reglas básicas (como por ejemplo no tener
+   Si una función cumple ciertas reglas básicas (como por ejemplo no tener
    efectos colaterales) puede ser ejecutada en tiempo de compilación en vez de
    tiempo de ejecución. Esto permite hacer algunos cálculos que no cambian de
    ejecución en ejecución al momento de compilar, mejorando el rendimiento
    o permitiendo formas avanzadas de meta-programación. Esta característica se
    efectos colaterales) puede ser ejecutada en tiempo de compilación en vez de
    tiempo de ejecución. Esto permite hacer algunos cálculos que no cambian de
    ejecución en ejecución al momento de compilar, mejorando el rendimiento
    o permitiendo formas avanzadas de meta-programación. Esta característica se
-   vuelve particularmente útil al combinarse con *string mixins*.
+   vuelve particularmente útil al combinarse con *string mixins* [DWCF]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -353,15 +336,15 @@ Cantidad de parámetros variables para *templates*
       static int x = factorial(5); // calculado en tiempo de compilación
       int x = factorial(5); // calculado en tiempo de ejecución
 
       static int x = factorial(5); // calculado en tiempo de compilación
       int x = factorial(5); // calculado en tiempo de ejecución
 
-   Esta característica es vital para evitar la duplicación de código.
+   Esta característica es muy importante para evitar la duplicación de código.
 
 *Mixins*, incluyendo *string mixins*
 
 *Mixins*, incluyendo *string mixins*
-   la palabra *mixin* tiene significados distintos en varios lenguajes de
+   La palabra *mixin* tiene significados distintos en varios lenguajes de
    programación. En D_ *mixin* significa tomar una secuencia arbitraria de
    declaraciones e insertarla en el contexto (*scope*) actual. Esto puede
    realizarse a nivel global, en clases, estructuras o funciones. Esto sirve
    como un mecanismo para evitar duplicación de código que puede ser
    programación. En D_ *mixin* significa tomar una secuencia arbitraria de
    declaraciones e insertarla en el contexto (*scope*) actual. Esto puede
    realizarse a nivel global, en clases, estructuras o funciones. Esto sirve
    como un mecanismo para evitar duplicación de código que puede ser
-   introducida por la falta de herencia múltiple.
+   introducida por la falta de herencia múltiple [DWMT]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -383,7 +366,7 @@ Cantidad de parámetros variables para *templates*
    contenga un fragmento de código en un programa como si este fragmento
    hubiera sido escrito en el código fuente directamente por el programador.
    Esto permite hacer manipulaciones arbitrariamente complejas en combinación
    contenga un fragmento de código en un programa como si este fragmento
    hubiera sido escrito en el código fuente directamente por el programador.
    Esto permite hacer manipulaciones arbitrariamente complejas en combinación
-   con funciones ejecutadas en tiempo de compilación.
+   con funciones ejecutadas en tiempo de compilación [DWME]_ [DWMX]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -395,11 +378,9 @@ Cantidad de parámetros variables para *templates*
          mixin(generar_sumar!("a", b"));
       }
 
          mixin(generar_sumar!("a", b"));
       }
 
-   Más información en http://www.digitalmars.com/d/1.0/mixin.html
-
 Expresiones ``is``
 Expresiones ``is``
-   las *expresiones ``is``* permiten la compilación condicional basada en las
-   características de un tipo.
+   Las *expresiones ``is``* permiten la compilación condicional basada en las
+   características de un tipo [DWIE]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -412,9 +393,6 @@ Expresiones ``is``
 
    Esto provee además una forma simple de reflexión en tiempo de compilación.
 
 
    Esto provee además una forma simple de reflexión en tiempo de compilación.
 
-   Más información en
-   http://www.digitalmars.com/d/1.0/expression.html#IsExpression
-
 
 
 .. _d_low_level:
 
 
 .. _d_low_level:
@@ -429,25 +407,27 @@ el lenguaje de bajo nivel más popular, seguido por C++.
 D_ presenta muchas características de bajo nivel:
 
 Compila a código de máquina nativo
 D_ presenta muchas características de bajo nivel:
 
 Compila a código de máquina nativo
-   no es interpretado ni necesita una máquina virtual como otros lenguajes de
-   más alto nivel como Java_, `C#`_, Python_, etc.
+   Los programas generados por D_ no son interpretados ni necesitan una
+   máquina virtual como otros lenguajes de más alto nivel como Java_, `C#`_,
+   Python_, etc [DWOV]_.
 
 
-Provee acceso a *assembly*
-   por lo tanto, acceso directo al *hardware* y la posibilidad de utilizar
-   cualquier característica de éste que no esté disponible en el lenguaje.
+*Assembly* empotrado
+   Provee acceso directo al *hardware* y la posibilidad de utilizar cualquier
+   característica de éste que no esté disponible en el lenguaje.
 
    Una ventaja sobre C y C++ es que el lenguaje *assembly* utilizado dentro de
    D_ está especificado, por lo que se puede mantener la portabilidad entre
    compiladores incluso cuando se utiliza *assembly* (mientras que no se
 
    Una ventaja sobre C y C++ es que el lenguaje *assembly* utilizado dentro de
    D_ está especificado, por lo que se puede mantener la portabilidad entre
    compiladores incluso cuando se utiliza *assembly* (mientras que no se
-   cambie de arquitectura, por supuesto).
+   cambie de arquitectura, por supuesto) [DWIA]_.
 
 ``goto``
 
 ``goto``
-   al igual que C y C++, D_ provee la flexibilidad del uso de ``goto``.
+   Al igual que C y C++, D_ provee la flexibilidad del uso de ``goto``
+   [DWGT]_.
 
 Compatibilidad con C
 
 Compatibilidad con C
-   soporta todos los tipos de C y es ABI [#abi]_ compatible con éste. Esto
+   Soporta todos los tipos de C y es ABI [#abi]_ compatible con éste. Esto
    permite enlazar archivos objeto estándar de C y D_ en un mismo programa.
    permite enlazar archivos objeto estándar de C y D_ en un mismo programa.
-   Además permite interoperar con C a través de ``extern (C)``.
+   Además permite interoperar con C a través de ``extern (C)`` [DWCC]_.
 
    .. [#abi] Interfaz de Aplicación Binaria (del inglés *Application Binary
       Interface*).
 
    .. [#abi] Interfaz de Aplicación Binaria (del inglés *Application Binary
       Interface*).
@@ -458,16 +438,16 @@ Compatibilidad con C
       printf("3 + 5 == %d\n", 3 + 5); // llama al printf de C
 
 Manejo de memoria explícito
       printf("3 + 5 == %d\n", 3 + 5); // llama al printf de C
 
 Manejo de memoria explícito
-   permite asignar estructuras en el *stack* o en el *heap*, haciendo uso de
-   los servicios del sistema operativo o la biblioteca estándar de C.
+   Permite asignar estructuras en el *stack* o en el *heap*, haciendo uso de
+   los servicios del sistema operativo o la biblioteca estándar de C [DWMM]_.
 
 Objetos y arreglos *livianos*
 
 Objetos y arreglos *livianos*
-   por objetos *livianos* se entiende no-polimórficos. Es decir, un
+   Por objetos *livianos* se entiende no-polimórficos. Es decir, un
    agrupamiento de variables análogo al ``struct`` de C, sin tabla virtual ni
    otro tipo de *overhead*. Los arreglos *livianos* son arreglos estáticos
    como en C, cuyo tamaño es fijo, también sin ningún tipo de *overhead* como
    C. Además puede asignarse un arreglo dinámicamente usando ``malloc()``
    agrupamiento de variables análogo al ``struct`` de C, sin tabla virtual ni
    otro tipo de *overhead*. Los arreglos *livianos* son arreglos estáticos
    como en C, cuyo tamaño es fijo, también sin ningún tipo de *overhead* como
    C. Además puede asignarse un arreglo dinámicamente usando ``malloc()``
-   y utilizar el operador ``[]`` para accederlo.
+   y utilizar el operador ``[]`` para accederlo [DWST]_ [DWCL]_.
 
    Esto también permite interoperar con C, ya que pueden definirse ``structs``
    y arreglos que pueden ser intercambiados con dicho lenguaje sin problemas.
 
    Esto también permite interoperar con C, ya que pueden definirse ``structs``
    y arreglos que pueden ser intercambiados con dicho lenguaje sin problemas.
@@ -491,17 +471,17 @@ Objetos y arreglos *livianos*
       gettimeofday(&tv, null);
 
 Rendimiento
       gettimeofday(&tv, null);
 
 Rendimiento
-   la :ref:`d_generic` permite realizar muchas optimizaciones ya que se
+   La :ref:`d_generic` permite realizar muchas optimizaciones ya que se
    resuelve en tiempo de compilación y por lo tanto aumenta el rendimiento en
    resuelve en tiempo de compilación y por lo tanto aumenta el rendimiento en
-   la ejecución.
+   la ejecución [DWTP]_.
 
 Número de punto flotante de 80 bits
    El tipo ``real`` de D_ tiene precisión de 80 bits si la plataforma lo
 
 Número de punto flotante de 80 bits
    El tipo ``real`` de D_ tiene precisión de 80 bits si la plataforma lo
-   soporta (por ejemplo en i386).
+   soporta (por ejemplo en i386) [DWTY]_.
 
 Control de alineación de miembros de una estructura
    Mediante ``align`` se puede especificar la alineación a tener en una
 
 Control de alineación de miembros de una estructura
    Mediante ``align`` se puede especificar la alineación a tener en una
-   estructura.
+   estructura [DWAL]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -530,18 +510,18 @@ productividad de los programadores. D_ adopta herramientas de muchos lenguajes
 de alto nivel, como Java_ y Python_, por ejemplo:
 
 Manejo automático de memoria
 de alto nivel, como Java_ y Python_, por ejemplo:
 
 Manejo automático de memoria
-   al igual que C/C++ y prácticamente cualquier lenguaje imperativo maneja
+   Al igual que C/C++ y prácticamente cualquier lenguaje imperativo maneja
    automáticamente el *stack*, pero a diferencia de la mayoría de los
    lenguajes de bajo nivel, D_ permite manejar el *heap* de manera automática
    automáticamente el *stack*, pero a diferencia de la mayoría de los
    lenguajes de bajo nivel, D_ permite manejar el *heap* de manera automática
-   también a través de un *recolector de basura*.
+   también a través de un *recolector de basura* [DWGC]_.
 
 Sistema de paquetes y módulos (similar a Java_ o Python_)
 
 Sistema de paquetes y módulos (similar a Java_ o Python_)
-   un módulo es una unidad que agrupa clases, funciones y cualquier otra
+   Un módulo es una unidad que agrupa clases, funciones y cualquier otra
    construcción de lenguaje. Un paquete es una agrupación de módulos. D_
    asocia un módulo a un archivo fuente (y un archivo objeto cuando éste es
    compilado) y un paquete a un directorio. A diferencia de C/C++ no necesita
    de un preprocesador para incluir declaraciones de otros *módulos* (en C/C++
    construcción de lenguaje. Un paquete es una agrupación de módulos. D_
    asocia un módulo a un archivo fuente (y un archivo objeto cuando éste es
    compilado) y un paquete a un directorio. A diferencia de C/C++ no necesita
    de un preprocesador para incluir declaraciones de otros *módulos* (en C/C++
-   no existe el concepto de módulo, solo de unidades de compilación).
+   no existe el concepto de módulo, solo de unidades de compilación) [DWMO]_.
 
    Ejemplo:
 
 
    Ejemplo:
 
@@ -565,12 +545,12 @@ Sistema de paquetes y módulos (similar a Java_ o Python_)
          f(); // ejecuta b.f()
 
 Funciones y delegados
          f(); // ejecuta b.f()
 
 Funciones y delegados
-   las funciones pueden ser sobrecargadas (funciones con el mismo nombre pero
+   Las funciones pueden ser sobrecargadas (funciones con el mismo nombre pero
    distinta cantidad o tipo de parámetros), pueden especificarse argumentos de
    entrada, salida o entrada/salida, argumentos por omisión o argumentos
    evaluados de forma perezosa (*lazy*). Además pueden tener una cantidad de
    argumentos variables pero manteniendo información de tipos (más seguro que
    distinta cantidad o tipo de parámetros), pueden especificarse argumentos de
    entrada, salida o entrada/salida, argumentos por omisión o argumentos
    evaluados de forma perezosa (*lazy*). Además pueden tener una cantidad de
    argumentos variables pero manteniendo información de tipos (más seguro que
-   C/C++).
+   C/C++) [DWFU]_.
 
    Los *delegados* son punteros a función con un contexto asociado. Este
    contexto puede ser un objeto (en cuyo caso la función es un método) o un
 
    Los *delegados* son punteros a función con un contexto asociado. Este
    contexto puede ser un objeto (en cuyo caso la función es un método) o un
@@ -612,13 +592,14 @@ Funciones y delegados
                                  );
 
 Arreglos *dinámicos* y arreglos asociativos
                                  );
 
 Arreglos *dinámicos* y arreglos asociativos
-   los arreglos *dinámicos* son arreglos de longitud variable manejados
+   Los arreglos *dinámicos* son arreglos de longitud variable manejados
    automáticamente por el lenguaje (análogos al ``std::vector`` de C++).
    Soportan concatenación (a través del operador ``~``), rebanado o *slicing*
    automáticamente por el lenguaje (análogos al ``std::vector`` de C++).
    Soportan concatenación (a través del operador ``~``), rebanado o *slicing*
-   (a través del operador ``[x..y]``) y chequeo de límites (*bound checking*).
+   (a través del operador ``[x..y]``) y chequeo de límites (*bound checking*)
+   [DWAR]_.
 
    Los arreglos asociativos (también conocidos como *hashes* o diccionarios)
 
    Los arreglos asociativos (también conocidos como *hashes* o diccionarios)
-   también son provistos por el lenguaje.
+   también son provistos por el lenguaje [DWAA]_.
 
    Ambos son ciudadanos de primera clase, disponiendo de forma literal.
 
 
    Ambos son ciudadanos de primera clase, disponiendo de forma literal.
 
@@ -631,10 +612,10 @@ Arreglos *dinámicos* y arreglos asociativos
       agenda["Pepe"] = 5555_1234;
 
 *Strings*
       agenda["Pepe"] = 5555_1234;
 
 *Strings*
-   al igual que los delegados y arreglos dinámicos y asociativos, los
+   Al igual que los delegados y arreglos dinámicos y asociativos, los
    *strings* son ciudadanos de primera clase, teniendo forma literal y siendo
    codificados en UTF-8/16/32. Son un caso particular de arreglo dinámico y es
    *strings* son ciudadanos de primera clase, teniendo forma literal y siendo
    codificados en UTF-8/16/32. Son un caso particular de arreglo dinámico y es
-   posible utilizarlos en sentencias ``switch``/``case``.
+   posible utilizarlos en sentencias ``switch``/``case`` [DWSR]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -648,12 +629,12 @@ Arreglos *dinámicos* y arreglos asociativos
       }
 
 ``typedef`` y ``alias``
       }
 
 ``typedef`` y ``alias``
-   el primero define un nuevo tipo basado en otro. A diferencia de C/C++ el
+   El primero define un nuevo tipo basado en otro. A diferencia de C/C++ el
    tipo original no puede ser implícitamente convertido al tipo nuevo (excepto
    valores literales), pero la conversión es válida en el otro sentido
    (similar a los ``enum`` en C++). Por el contrario, ``alias`` es análogo al
    ``typedef`` de C/C++ y simplemente es una forma de referirse al mismo tipo
    tipo original no puede ser implícitamente convertido al tipo nuevo (excepto
    valores literales), pero la conversión es válida en el otro sentido
    (similar a los ``enum`` en C++). Por el contrario, ``alias`` es análogo al
    ``typedef`` de C/C++ y simplemente es una forma de referirse al mismo tipo
-   con un nombre distinto.
+   con un nombre distinto [DWDC]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -671,13 +652,11 @@ Documentación embebida
    D_ provee un sistema de documentación embebida, análogo a lo que proveen
    Java_ o Python_ en menor medida. Hay comentarios especiales del código que
    pueden ser utilizados para documentarlo de forma tal que luego el
    D_ provee un sistema de documentación embebida, análogo a lo que proveen
    Java_ o Python_ en menor medida. Hay comentarios especiales del código que
    pueden ser utilizados para documentarlo de forma tal que luego el
-   compilador pueda extraer esa información para generar un documento.
-
-   Más información en http://www.digitalmars.com/d/1.0/ddoc.html
+   compilador pueda extraer esa información para generar un documento [DWDO]_.
 
 Números complejos
    D_ soporta números complejos como ciudadanos de primera clase. Soporta
 
 Números complejos
    D_ soporta números complejos como ciudadanos de primera clase. Soporta
-   forma literal de números imaginarios y complejos.
+   forma literal de números imaginarios y complejos [DWTY]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -696,14 +675,14 @@ herramientas para soportar este paradigma de forma confiable. Entre las
 características más salientes se encuentran:
 
 Objetos *pesados*
 características más salientes se encuentran:
 
 Objetos *pesados*
-   objetos polimórficos como los de cualquier lenguaje con orientación real
+   Objetos polimórficos como los de cualquier lenguaje con orientación real
    a objetos. Estos objetos poseen una tabla virtual para despacho dinámico,
    todos los métodos son virtuales a menos que se indique lo contrario
    y tienen semántica de referencia [#drefsem]_. Estos objetos tienen un
    *overhead* comparados a los objetos *livianos* pero aseguran una semántica
    segura para trabajar con orientación a objetos, evitando problemas con los
    que se enfrenta C++ (como *slicing* [#dslicing]_) debido a que permite
    a objetos. Estos objetos poseen una tabla virtual para despacho dinámico,
    todos los métodos son virtuales a menos que se indique lo contrario
    y tienen semántica de referencia [#drefsem]_. Estos objetos tienen un
    *overhead* comparados a los objetos *livianos* pero aseguran una semántica
    segura para trabajar con orientación a objetos, evitando problemas con los
    que se enfrenta C++ (como *slicing* [#dslicing]_) debido a que permite
-   semántica por valor [#dvalsem]_.
+   semántica por valor [#dvalsem]_ [DWCL]_.
 
    .. [#drefsem] Semántica de referencia significa que el tipo es tratado como
       si fuera un puntero. Nunca se hacen copias del objeto, siempre se pasa
 
    .. [#drefsem] Semántica de referencia significa que el tipo es tratado como
       si fuera un puntero. Nunca se hacen copias del objeto, siempre se pasa
@@ -720,7 +699,7 @@ Objetos *pesados*
    D_ además soporta tipos de retorno covariantes para funciones virtuales.
    Esto significa que una función sobreescrita por una clase derivada puede
    retornar un tipo que sea derivado del tipo retornado por la función
    D_ además soporta tipos de retorno covariantes para funciones virtuales.
    Esto significa que una función sobreescrita por una clase derivada puede
    retornar un tipo que sea derivado del tipo retornado por la función
-   original sobreescrita.
+   original sobreescrita [DWFU]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -735,8 +714,6 @@ Objetos *pesados*
          B test() { return null; } // sobreescribe y es covariante con Foo.test()
       }
 
          B test() { return null; } // sobreescribe y es covariante con Foo.test()
       }
 
-   Más información en http://www.digitalmars.com/d/1.0/function.html
-
 Interfaces
    D_ no soporta herencia múltiple pero sí interfaces. Una interfaz es
    básicamente una tabla virtual, una definición de métodos virtuales que debe
 Interfaces
    D_ no soporta herencia múltiple pero sí interfaces. Una interfaz es
    básicamente una tabla virtual, una definición de métodos virtuales que debe
@@ -745,17 +722,17 @@ Interfaces
    se pierde flexibilidad porque puede conseguirse el mismo efecto de tener
    herencia múltiple a través de interfaces y *mixins* para proveer una
    implementación o atributos en común a varias clases que implementan la
    se pierde flexibilidad porque puede conseguirse el mismo efecto de tener
    herencia múltiple a través de interfaces y *mixins* para proveer una
    implementación o atributos en común a varias clases que implementan la
-   misma interfaz.
+   misma interfaz [DWIF]_.
 
 Sobrecarga de operadores
 
 Sobrecarga de operadores
-   la sobrecarga de operadores permite que un objeto tenga una sintaxis
+   La sobrecarga de operadores permite que un objeto tenga una sintaxis
    similar a un tipo de dato nativo. Esto es muy importante además para la
    similar a un tipo de dato nativo. Esto es muy importante además para la
-   programación genérica.
+   programación genérica [DWOO]_.
 
 Clases anidadas
 
 Clases anidadas
-   al igual que C (con respecto a ``struct``) y C++, pueden anidarse clases
+   Al igual que C (con respecto a ``struct``) y C++, pueden anidarse clases
    dentro de clases. D_ sin embargo provee la posibilidad de acceder
    dentro de clases. D_ sin embargo provee la posibilidad de acceder
-   a atributos de la instancia exterior desde la anidada.
+   a atributos de la instancia exterior desde la anidada [DWNC]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -788,8 +765,8 @@ Clases anidadas
 
 
 Propiedades (*properties*)
 
 
 Propiedades (*properties*)
-   en D_ se refiere a funciones miembro que pueden ser tratadas
-   sintácticamente como campos de esa clase/estructura.
+   En D_ se refiere a funciones miembro que pueden ser tratadas
+   sintácticamente como campos de esa clase/estructura [DWPR]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -806,21 +783,21 @@ Propiedades (*properties*)
    *properties* predefinidos, por ejemplo:
 
    ``sizeof``
    *properties* predefinidos, por ejemplo:
 
    ``sizeof``
-      tamaño ocupado en memoria (ejemplo: ``int.sizeof`` -> 4).
+      Tamaño ocupado en memoria (ejemplo: ``int.sizeof`` -> 4).
 
    ``init``
 
    ``init``
-      valor de inicialización por omisión (ejemplo: ``float.init`` -> *NaN*
+      Valor de inicialización por omisión (ejemplo: ``float.init`` -> *NaN*
       [#dnan]_).
 
    .. [#dnan] Del inglés *Not A Number*, es un valor especial que indica que
       estamos ante un valor inválido.
 
    ``stringof``
       [#dnan]_).
 
    .. [#dnan] Del inglés *Not A Number*, es un valor especial que indica que
       estamos ante un valor inválido.
 
    ``stringof``
-      representación textual del símbolo o expresión (ejemplo:
+      Representación textual del símbolo o expresión (ejemplo:
       ``(1+2).stringof`` -> ``"1 + 2"``).
 
    ``mangleof``
       ``(1+2).stringof`` -> ``"1 + 2"``).
 
    ``mangleof``
-      representación textual del tipo *mutilado* [#dmangle]_.
+      Representación textual del tipo *mutilado* [#dmangle]_.
 
    .. [#dmangle] *Name mangling* es el nombre dado comunmente a una técnica
       necesaria para poder sobrecargar nombres de símbolos. Consiste en
 
    .. [#dmangle] *Name mangling* es el nombre dado comunmente a una técnica
       necesaria para poder sobrecargar nombres de símbolos. Consiste en
@@ -830,7 +807,7 @@ Propiedades (*properties*)
       tengan nombres distintos.
 
    ``alignof``
       tengan nombres distintos.
 
    ``alignof``
-      alineación de una estructura o tipo.
+      Alineación de una estructura o tipo.
 
    Estos son solo los *properties* predefinidos para todos los tipos, pero hay
    una cantidad considerable de *properties* extra para cada tipo.
 
    Estos son solo los *properties* predefinidos para todos los tipos, pero hay
    una cantidad considerable de *properties* extra para cada tipo.
@@ -855,18 +832,18 @@ a esto y provee las siguientes herramientas:
 Excepciones
    D_ soporta excepciones de manera similar a Java_: provee ``try``, ``catch``
    y ``finally``. Esto permite que los errores difícilmente pasen
 Excepciones
    D_ soporta excepciones de manera similar a Java_: provee ``try``, ``catch``
    y ``finally``. Esto permite que los errores difícilmente pasen
-   silenciosamente sin ser detectados.
+   silenciosamente sin ser detectados [DWEX]_.
 
 ``assert``
 
 ``assert``
-   es una condición que debe cumplirse siempre en un programa, como un chequeo
+   Es una condición que debe cumplirse siempre en un programa, como un chequeo
    de integridad. Esto es muy utilizado en C/C++, donde ``assert()`` es una
    *macro* que solo se compila cuando la *macro* ``NDEBUG`` no está definida.
    Esto permite eliminar los chequeos de integridad del programa, que pueden
    ser costosos, para versiones que se suponen estables.
 
    de integridad. Esto es muy utilizado en C/C++, donde ``assert()`` es una
    *macro* que solo se compila cuando la *macro* ``NDEBUG`` no está definida.
    Esto permite eliminar los chequeos de integridad del programa, que pueden
    ser costosos, para versiones que se suponen estables.
 
-   D_ lleva este concepto más allá y hace al ``assert`` parte del lenguaje.
-   Si una verificación no se cumple, lanza una excepción. El ``assert`` no es
-   compilado cuando se utiliza una opción del compilador.
+   D_ lleva este concepto más allá y hace al ``assert`` parte del lenguaje
+   [DWCP]_.  Si una verificación no se cumple, lanza una excepción. El
+   ``assert`` no es compilado cuando se utiliza una opción del compilador.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -874,14 +851,14 @@ Excepciones
       assert (f.ok());
 
 Diseño por contrato
       assert (f.ok());
 
 Diseño por contrato
-   el diseño por contrato es un concepto introducido por el lenguaje Eiffel_
+   El diseño por contrato es un concepto introducido por el lenguaje Eiffel_
    a mediados/finales de los '80. Se trata de incorporar en el lenguaje las
    herramientas para poder aplicar verificaciones formales a las interfaces de
    los programas.
 
    D_ implementa las siguientes formas de diseño por contrato (todas se
    ejecutan siempre y cuando no se compile en modo *release*, de manera de no
    a mediados/finales de los '80. Se trata de incorporar en el lenguaje las
    herramientas para poder aplicar verificaciones formales a las interfaces de
    los programas.
 
    D_ implementa las siguientes formas de diseño por contrato (todas se
    ejecutan siempre y cuando no se compile en modo *release*, de manera de no
-   sacrificar rendimiento cuando es necesario):
+   sacrificar rendimiento cuando es necesario) [DWCP]_:
 
    Pre y post condiciones
       Ejemplo::
 
    Pre y post condiciones
       Ejemplo::
@@ -921,12 +898,10 @@ Diseño por contrato
                }
          }
 
                }
          }
 
-   Más información en http://www.digitalmars.com/d/1.0/dbc.html
-
 Pruebas unitarias
 Pruebas unitarias
-   es posible incluir pequeñas pruebas unitarias en el lenguaje. Éstas son
+   Es posible incluir pequeñas pruebas unitarias en el lenguaje. Éstas son
    ejecutadas (cuando no se compila en modo *release*) al comenzar el
    ejecutadas (cuando no se compila en modo *release*) al comenzar el
-   programa, antes de que la función ``main()``.
+   programa, antes de que la función ``main()`` [DWUT]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -938,20 +913,20 @@ Pruebas unitarias
       }
 
 Orden de construcción estática
       }
 
 Orden de construcción estática
-   a diferencia de C++, D_ garantiza el orden de inicialización de los
+   A diferencia de C++, D_ garantiza el orden de inicialización de los
    módulos. Si bien en C++ no hay módulos si no unidades de compilación, es
    posible que se ejecute código antes del ``main()`` en C++, si hay, por
    ejemplo, instancias globales con un constructor definido. C++ no garantiza
    un orden de inicialización, lo que trae muchos problemas. En D_ se define
    el orden de inicialización y es el mismo orden en que el usuario importa
    módulos. Si bien en C++ no hay módulos si no unidades de compilación, es
    posible que se ejecute código antes del ``main()`` en C++, si hay, por
    ejemplo, instancias globales con un constructor definido. C++ no garantiza
    un orden de inicialización, lo que trae muchos problemas. En D_ se define
    el orden de inicialización y es el mismo orden en que el usuario importa
-   los módulos.
+   los módulos [DWMO]_.
 
 Inicialización garantizada
 
 Inicialización garantizada
-   todas las variables son inicializadas por el lenguaje (a menos que el
-   usuario pida explícitamente que no lo sean). Siempre que sea posible se
-   elijen valores de inicialización que permitan saber al programador que la
-   variable no fue inicializada explícitamente, de manera de poder detectar
-   errores de manera temprana.
+   Todas las variables son inicializadas por el lenguaje (a menos que el
+   usuario pida explícitamente que no lo sean) [DWTY]_ [DWVI]_. Siempre que
+   sea posible se elijen valores de inicialización que permitan saber al
+   programador que la variable no fue inicializada explícitamente, de manera
+   de poder detectar errores de manera temprana.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -962,7 +937,7 @@ Inicialización garantizada
       long l = void; // NO inicializado (explícitamente)
 
 *RAII* (*Resource Adquisition Is Initialization*)
       long l = void; // NO inicializado (explícitamente)
 
 *RAII* (*Resource Adquisition Is Initialization*)
-   es una técnica muy utilizada en C++ que consiste en reservar recursos por
+   Es una técnica muy utilizada en C++ que consiste en reservar recursos por
    medio de la construcción de un objeto y liberarlos cuando se libera éste.
    Al llamarse al destructor de manera automática cuando se sale del *scope*,
    se asegura que el recurso será liberado también.
    medio de la construcción de un objeto y liberarlos cuando se libera éste.
    Al llamarse al destructor de manera automática cuando se sale del *scope*,
    se asegura que el recurso será liberado también.
@@ -974,7 +949,7 @@ Inicialización garantizada
    basura (en la mayoría de los casos el recurso a administrar es
    sencillamente memoria). Sin embargo en los casos en donde es necesario,
    puede utilizarse *RAII* mediante la utilización de la palabra reservada
    basura (en la mayoría de los casos el recurso a administrar es
    sencillamente memoria). Sin embargo en los casos en donde es necesario,
    puede utilizarse *RAII* mediante la utilización de la palabra reservada
-   ``scope``, que limita la vida de un objeto un bloque de código.
+   ``scope``, que limita la vida de un objeto un bloque de código [DWES]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -988,9 +963,10 @@ Inicialización garantizada
       } // en este punto se llama al destructor de archivo
 
 Guardias de bloque (*scope guards*)
       } // en este punto se llama al destructor de archivo
 
 Guardias de bloque (*scope guards*)
-   además de poder limitar la vida de una instancia a un *scope*, es posible
+   Además de poder limitar la vida de una instancia a un *scope*, es posible
    especificar un bloque de código arbitrario a ejecutar al abandonar un
    especificar un bloque de código arbitrario a ejecutar al abandonar un
-   *scope*, ya sea cuando se sale del *scope* normalmente o por una falla.
+   *scope*, ya sea cuando se sale del *scope* normalmente o por una falla
+   [DWES]_.
 
    Ejemplo::
 
 
    Ejemplo::
 
@@ -1015,13 +991,13 @@ Guardias de bloque (*scope guards*)
    acciones a ejecutar al finalizar el *scope*.
 
 Primitivas de sincronización de hilos
    acciones a ejecutar al finalizar el *scope*.
 
 Primitivas de sincronización de hilos
-   la programación multi-hilo está directamente soportada por el lenguaje,
+   La programación multi-hilo está directamente soportada por el lenguaje,
    y se provee una primitiva de sincronización al igual que Java_. La palabra
    reservada ``synchronized`` puede aparecer como modificador de métodos (en
    cuyo caso se utiliza un *lock* por clase para sincronizar) o como una
    sentencia, en cuyo caso se crea un *lock* global por cada bloque
    ``synchronized`` a menos que se especifique sobre qué objeto realizar la
    y se provee una primitiva de sincronización al igual que Java_. La palabra
    reservada ``synchronized`` puede aparecer como modificador de métodos (en
    cuyo caso se utiliza un *lock* por clase para sincronizar) o como una
    sentencia, en cuyo caso se crea un *lock* global por cada bloque
    ``synchronized`` a menos que se especifique sobre qué objeto realizar la
-   sincronización. Por ejemplo::
+   sincronización [DWSY]_. Por ejemplo::
 
       class Foo {
          synchronized void bar() { /* cuerpo */ }
 
       class Foo {
          synchronized void bar() { /* cuerpo */ }