Antecedentes
Soy autor de un artículo científico que contiene código y recientemente recibí las pruebas, es decir, lo que las máquinas de escribir de la revista crearon a partir de mi manuscrito. El resultado no fue aceptable: la sangría es inconsistente; hay un punto final al final de cada bloque de código; las comillas se han destruido, etc. Tenga en cuenta que todos los errores no fueron específicos del lenguaje de programación que utilicé.
Ahora, puedo ver por qué alguien que no tiene experiencia en programación y no tiene recursos externos cometería tales errores, pero en tiempos de Internet nadie debería estar sin recursos externos. Por lo tanto, consulté a mi motor de búsqueda favorito para buscar algo que sugerir y no encontré ... nada. Hay muchas guías para programadores sobre cómo escribir código bellamente en LaTeX o similar, lo cual es agradable y apropiado, pero esto obviamente no está hecho para la máquina de escribir que tiene que escribir el código de otra persona.
Pregunta
Estoy buscando un recurso que:
- explica los conceptos básicos del código de composición tipográfica,
- está dirigido a máquinas de escribir sin experiencia en programación.
fuente
Respuestas:
Quizás el punto real es que el código no debería estar realmente compuesto de la forma en que las personas entienden la composición. Por lo tanto, al poner código en un documento, debe colocarse allí literalmente , como en todos los espacios, pestañas, caracteres especiales o no especiales y saltos de línea intactos.
¡Asegúrese de que su aplicación no haga sustituciones!
Eso significa que no hay ligaduras.
Además, la aplicación de muchos programas (como Word e InDesign) cambia las comillas rectas a pares de tipógrafos. Asegúrese de que tales opciones estén deshabilitadas antes de colocar el código en su documento.
El código no es texto del cuerpo, no sigue ninguna convención tipográfica. Pregúntese ¿escribiría texto en una ilustración?
Si eres un experto
Si usted es un experto y conoce el idioma en cuestión, se aplica lo siguiente.
Nota : No adivine ni infiera, lea lo que se dijo. Muchos idiomas tienen el mismo aspecto y el código puede ser un pseudo lenguaje que parece un código real. Entonces tú puedes:
Al editor le gusta colorear / poner en negrita / poner en cursiva las palabras clave si y solo si su sustitución tiene el mismo ancho fijo. Lo mejor es que un editor haga esto por usted (los editores como digamos que scintilla puede exportar el código formateado). Recuerde que el editor necesita saber el idioma, tal vez las bibliotecas también.
Tenga en cuenta que si hace esto mal, causa más daño que bien.
Si eres un experto en dominios. Como en conocer el idioma y la biblioteca y comprender el código en cuestión:
Luego, puede volver a alinear el código en varias líneas si no se ajusta a su diseño. No haga esto a menos que realmente sepa lo que está haciendo, puede terminar haciendo un daño irreparable.
La prueba de fuego es si podría haber escrito el código en cuestión. Si no, entonces no puedes juzgar. Pregúntale al autor.
Como lidiar con esto? Los programadores entienden los estándares de estilo de código. Simplemente escriba en la guía de envío que solo puede caber X caracteres por línea. Los programadores pueden hacer esto por sí mismos. Los editores de código frecuentemente tienen herramientas para esto. Otra razón más para usar una fuente monoespaciada.
Pero entonces sabías todo esto, eras un experto después de todo. Mejor deje que el autor edite el código.
¿Línea de números?
Algunos lenguajes de programación y casos de uso pueden beneficiarse de los números de línea. Sin embargo, tenga cuidado aquí, ya que este es un paso en falso en algunos idiomas.
Problemas.
Tenga en cuenta que no importa lo que haga, de hecho puede enfrentar obstáculos técnicos imposibles. El código no debe estar realmente compuesto, solo debe ser texto sin formato. Esto lleva a problemas sorprendentes.
Por ejemplo: muchos visores de PDF no pueden manejar lenguajes como Python, como Adobe Acrobat. Si pega el código del archivo PDF, el editor decide no incluir el espacio anterior al copiar y pegar. Esto destruye la capacidad de pegar código desde PDF al editor. ¡Realmente no hay una buena manera de manejar esto!
fuente
La respuesta, por supuesto, puede depender de muchos factores, pero si comenzamos con un código de texto plano correcto y bien formateado , entonces uno puede generalizar más o menos las cosas aquí.
El 'formato' inicial en el texto fuente será: nueva línea , espacio y caracteres de tabulación . Tenga en cuenta que la nueva línea y el salto de línea manual (como en el software DTP) no son lo mismo, y viceversa, algunos idiomas raros pueden permitir otros caracteres de formato, aunque nunca he oído hablar de ellos.
Los comentarios no son parte ejecutable del código, por lo que pueden formatearse sin mucho riesgo, si se sabe si realmente es un comentario. Entonces, lo primero que debe observar es cómo se etiquetan los comentarios.
Es bueno conocer algunos conceptos básicos sobre el formato de texto sin formato inicial. Por ejemplo, para Python, existe la guía de estilo PEP8 . Si bien está hecho para Python, esta guía de formato se puede utilizar como referencia para los principales lenguajes como C / C ++ y Java. Examinar varios proyectos de ejemplo puede ayudar en caso de duda.
Por lo tanto, el primer principio sería: No cambie el texto fuente. Revisaría una lista de verificación, asegúrese de que:
En realidad, si la fuente original está formateada correctamente, no debería haber ningún ajuste de línea. Si las líneas ajustadas siguen apareciendo y son inevitables, entonces una sangría colgante de un nivel es la solución más común (ver PEP vinculada anteriormente). Si es necesario romper la línea, mejor consulte la guía de estilo o al autor.
Todavía algunos caracteres menores de 'espacio en blanco' pueden requerir reemplazo. Dado que la fuente puede incluir caracteres de tabulación, esto significa, por supuesto, que la fuente debe asegurarse de que todas las tabulaciones al comienzo de cada línea sean consistentes, es decir, las sangrías anidadas se conservan visualmente y cada siguiente nivel de sangría es del mismo ancho (ca. cuatro x anchos por un nivel de sangría).
Idealmente, las hendiduras que se hicieron con caracteres de espacio o espacios mixtos y pestañas deben reemplazarse con tabulación (o con lo que el software DTP puede hacer mejor para las sangrías anidadas), por lo que, si es necesario, ajustar las sangrías puede ser más fácil.
Por supuesto, uno puede dejar espacios, pero puede ser más difícil administrar su ancho al cambiar la fuente y más difícil alinear las hendiduras de la línea interna como en las columnas de la tabla.
Fuente monoespaciada + espacios
Tenga en cuenta que si la fuente está formateada con espacios intencionalmente y estaba destinada a leerse solo en fuentes monoespaciadas (por ejemplo, diagramas ASCII o arte ASCII), uno debe preservar los espacios sin cambios , pero esta decisión debe tomarse desde el principio. La fuente "Courier New" es más común en este caso. Sin embargo, si no es realmente necesario, desaconsejo el monoespacio, porque cada vez menos personas eligen el monoespaciado para la codificación hoy en día, y en caso de revisión, las fuentes proporcionales brindarán una mejor experiencia de lectura.
En general, las fuentes condensadas (por ejemplo, Arial estrechas) o más pequeñas pueden funcionar mejor: da más énfasis en contraste con el texto del cuerpo, hará que el código sea más compacto y, por lo tanto, sea menos probable que aparezca un ajuste de línea no deseado.
Creo que aquí se puede dibujar una línea, y si se hace lo anterior, entonces hay un 99% de probabilidad de que todo esté bien, al menos para un bloque de código de fuente simple sin colores.
Herramientas y formateo avanzado
Además, el aspecto se puede mejorar significativamente mediante el resaltado de sintaxis.
impresión en color o visualización en pantalla: en un diseño a todo color se pueden usar todas las funciones de resaltado, por lo que es el mejor de los casos, pero la impresión puede dar algunos cambios de color.
escala de grises o impresión en blanco y negro: aquí, por supuesto, uno puede usar negrita (por ejemplo, palabras clave) o cursiva (por ejemplo, comentarios), pero tenga en cuenta que los colores se convertirán a gris con todas las consecuencias. Por ejemplo, los comentarios en gris pueden verse bien en una pantalla, pero pueden volverse demasiado pálidos en el papel.
La pregunta más importante es si el creador de diseño tiene herramientas que puedan representar el código de forma legible. Afortunadamente, hay muchas herramientas gratuitas para la edición de código, las más destacadas (para Windows) son: Notepad ++, VSCode, Visual Studio . Pero tenga en cuenta las posibles autoconversiones implícitas de pestañas a espacios.
En Notepad ++ hay una opción para exportar el código como RTF , que preservará todo el formato y el resaltado de sintaxis de la fuente.
Si el diseño no requiere un cambio en el flujo de texto en la presentación del código, uno puede usar directamente imágenes (capturas de pantalla): no es tan flexible como el texto, pero conservará el formato al 100% y la numeración de líneas, y puede ahorrar mucho tiempo. Por ejemplo, los números de línea pueden ser difíciles de preservar en forma de texto. También exportar a PDF es una buena alternativa, pero no todo el software DTP puede incrustar archivos PDF y se puede perder algo de formato al imprimir en PDF.
Por ejemplo, mi configuración para el código Python en Notepad ++ se ve así:
Esto es solo para ilustrar, que uno puede usar capturas de pantalla directamente y que en realidad puede ser el método más fácil. Hay varias herramientas que pueden ayudar con la captura de pantalla: una puede necesitar "coser" las pantallas para obtener imágenes de mayor resolución.
El esquema de color es, por supuesto, individual, definido en el configurador de estilo del editor, que ya conoce el lenguaje admitido, lo que dificulta el formateo falso incluso si uno no conoce la sintaxis. Aquí las reglas generales de tipografía deberían funcionar: no demasiados colores, fuentes consistentes, hendiduras, espacios de líneas cómodos.
También son comunes herramientas / complementos adicionales para definiciones de lenguaje personalizadas, pero requieren conocimiento de sintaxis.
fuente
a[i][j] = 1
⮠a[m][n] = 2
.En HTML, hay un conjunto de etiquetas <code> ... </code> que le dice al lector / intérprete que trate el contenido absolutamente literalmente. Además, <pre> ... </pre> hace lo mismo. Como alguien que a menudo tenía que componer fórmulas, ecuaciones y códigos para su publicación, también abogo por el uso de IMÁGENES para hacer esto ... hacer un .gif o .jpg o .png del elemento problemático.
Otro factor es que el código se representa tradicionalmente en Courier monoespacio, u otra fuente monoespaciada, porque envía semáforos o telégrafos al lector de que no es texto del cuerpo. Me suscribo a esta elección de estilo, creo que tiene mucho sentido.
En la mayoría de los sistemas de composición tipográfica "heredados", las ecuaciones matemáticas de una complejidad razonablemente alta consumían mucho tiempo ... y estaban llenas de errores.
fuente