Skip to content

Latest commit

 

History

History
532 lines (471 loc) · 18.9 KB

README.md

File metadata and controls

532 lines (471 loc) · 18.9 KB

GitHub release (latest by date) https://t.me/joinchat/EBHu7z6l6_paWtcJgu9DVQ Join the chat at https://gitter.im/primitivorm/latino

Build Status License codecov.io

| <!-- | README | English | Français | Português | Italiano | | ---- | ------ | ------------------------------------------------ | ------------------------------------------------- | -------------------------------------------------- | ------------------------------------------------- |>

Tabla de contenidos

¿Qué es lenguaje Latino?

Latino es un lenguaje de programación con sintaxis en Español creado en C, inspirado en Lua y Python. Éste proyecto nace de la necesidad de incrementar la educación de nivel básico y avanzado, para que niños, adolescentes y también adultos se motiven a entrar en el mundo de la programación y desarrollar aplicaciones en una sintaxis a su idioma. Además, Latino es también para desarrolladores que les gustaría programar en Español, ya que Latino es completamente funcional en cualquier API en raw.

Vídeo introductorio de Latino (clic en la imagen)

Video Introductorio de Latino

¿Por qué usar Latino?

Latino al ser un lenguaje de programación con sintaxis en Español nos provee de ciertas ventajas a la hora de programar en el.

  1. Intuitivo:

    Su sintaxis en Español hace más fácil la comprensión del código, reduciendo así el tiempo de aprendizaje al programar.

  2. Fácil:

    Latino tiene una sintaxis limpia y no requiere del uso de punto y coma (;) al final de cada código como en el caso se Java, Javascript, C/C++, entre otros.

  3. Lenguaje de alto nivel:

    Esto significa que es un lenguaje que se asemeja a la gramática que usamos para leer y escribir. Sin embargo, los lenguajes de bajo nivel son aquellos que entiende la máquina tales como el código binario o el Lenguaje ensamblador.

  4. Portátil:

    Cuando escribes tu código en Latino este puede ser ejecutado en cualquier otra plataforma de manera fácil y segura a diferencia de otros lenguajes de programación como es el caso de Visual Basic que solo opera en plataformas MS-Windows.

  5. Código abierto:

    Cualquiera puede descargar el código fuente de Latino, modificarlo, extender sus librerías y aportar en su desarrollo si así lo desea.


Captura_de_Pantalla-Latino

Instalar Latino

Windows

Puedes instalar Latino en Linux usando los paquetes de instalación disponibles en el "release" o utilizar el siguiente "bash script" para una instalación totalmente automatizada (solo en Linux)

git clone https://github.com/lenguaje-latino/instalacion.git && cd instalacion && sudo chmod +x latino_instalacion-linux.sh && ./latino_instalacion-linux.sh

Para mayor información sobre el script de arribe, mirar aquí git:lenguaje-latino/instalacion

Documentación

Aprende sobre este lenguaje de programación visitando su documentación oficial en el siguiente enlace.

Latino-Wiki

Visita la Wiki de Latino aquí en GitHut para saber como colaborar en este proyecto y para aprender a como compilar Latino en cada sistema operativo.

Otras Ayuda

Latino dispone de un foro en su página web oficial, así como también un grupo en Telegram y Gitter, además de un canal en Youtube a las que puedes dirigirte en caso de cualquier duda.

Contribuciones

Si deseas contribuir en este proyecto reportando errores, proponiendo sugerencias o aportando al código fuente, te dejamos el siguiente enlace con nuestras normas.

SINTAXIS DE LATINO

A continuación se explica de manera general la definición del lenguaje de programación Latino

I. Comentarios:

Los comentarios de una linea empezaran por el signo de gato # (como en python) o // (como en C).

#Este es un comentario estilo python
//Este es un comentario estilo C

Los comentarios multilínea son al estilo C. inician con /* y terminan con */.

/*
Este es un
comentario
multilínea
*/

II. Variables:

Las variables son identificadores asociados a valores.

nombre = "Juan Perez"
calificacion = 10
numeros = [1, 2, 3, 4, 5]  //esto es una lista ó arreglo.
sueldos = { "Jesus" : 10000, "Maria" : 20000, "Jose" : 30000 } //esto es un diccionario

Es posible asignar más de una variable en una sola línea de código

a, b, c = 1, 2, 3   #a = 1  b = 2  c = 3
a, b, c = 1, 2      #a = 1  b = 2  c = nulo
a, b    = 1, 2, 3   #a = 1  b = 2  se descarta el valor 3

Un identificador puede:

  1. Empezar por guión bajo _ o letras a-z ó A-Z. No son validas las letras acentuadas ni la ñ como letras en los identificadores.
  2. Contener caracteres en mayúsculas y minúsculas. Latino es sensible a mayúsculas y minúsculas. Por lo que los siguientes identificadores no son los mismos.
mensaje = "Hola mundo"
Mensaje = "¡Hasta la vista baby!"

Un identificador NO puede:

  1. Empezar por un número.
  2. Empezar por un símbolo, ni tampoco que sea una palabra reservada.

III. Constantes:

Cuando se declara una constante, también se debe asignar el valor forzosamente.

Las constantes se deben declarar en mayúsculas.

PI = 3.14159
G = 9.8

IV. Tipos de datos

latino tipo de dato en C
lógico bool
numérico double
cadena o literal char*
lista (arreglo) struct
diccionario struct

V. Operadores:

A continuación se listan los operadores:

Categoría Operadores
Aritmético +, -, *, /, % (modulo), ^ (potencia)
Lógico && (y), || (o)
Concatenación ..
Incremento, decremento ++, -- (valido solo en post)
Relacional ==, !=, <, >, <=, >=, ~= (regex)
Asignación =
Acceso a miembro .
Operador ternario (condicion) ? opcion1 : opcion2

La precedencia de operadores es la misma que otros lenguajes de programación como C / Python / Lua.

El operador ternario se puede usar para asignar valores basado en una condición, los paréntesis son requeridos para obtener el resultado esperado.

numero = -5
mensaje = (numero < 0) ? " es negativo" : " es positivo"
escribir("El número " .. numero .. mensaje)
#salida: El número -5 es negativo

VI. Estructuras de control:

si (if)

Evalua una condición y si el resultado es verdadero ejecuta las instrucciones a continuación. Los paréntesis son opcionales en la condición.

si (condicion)
   #codigo
fin

edad = 18
si edad >= 18
    escribir("Eres mayor de edad, ya puedes votar.")
fin
#salida: Eres mayor de edad, ya puedes votar.

En caso de que el resultado de la condición sea falso se deberá de ejecutar el código después de la palabra reservada sino.

si condicion
   #codigo
sino
   #codigo
fin

edad = 5
si edad >= 18
    escribir("Eres mayor de edad, ya puedes votar.")
sino
    escribir("Eres un niño, tienes que ir a la escuela.")
fin
#salida: Eres un niño, tienes que ir a la escuela.

Es posible el anidamiento de las sentencias si-sino de la siguiente manera:

si condicion
   #codigo
sino
    si condicion
        #codigo
    sino
        #codigo
    fin
fin

Existe una forma más elegante de escribir el código anterior con la palabra reservada osi. En python es elif expresion:.

si condicion1
    #codigo
osi condicion2
    #codigo
osi condicion3
    #codigo
sino
    #codigo
fin

elegir (switch case)

Evalúa una opción de múltiples posibles casos. La opción puede ser una expresión, en caso de que ninguna opción se cumpla en algún caso se ejecuta el código después de la palabra reservada otro o defecto. Los valores de los casos solo pueden ser numéricos o cadenas.

elegir (opcion)
    caso valor1:
        #codigo
    caso valor2:
        #codigo
    caso valor3:
        #codigo
    defecto:
        #codigo
fin

calificacion = 'B'
elegir(calificacion)
    caso 'A':
        escribir("Excelente!.")
    caso 'B':
        escribir("Bien echo!.")
    caso 'C':
        escribir("Bien echo!.")
    caso 'D':
        escribir("Todavia pasas.")
    caso 'F':
        escribir("Estas reprobado.")
    otro:
        escribir("Calificación invalida.")
fin
#salida: Bien echo!

Notese que se tiene que repetir el caso para B y C por el momento no se permiten casos múltiples como una sola opción.


desde (for loop)

Hace que una instrucción o bloque de instrucciones se repitan desde una condición inicial y mientras la condición se cumpla (es decir sea verdadero), en esta sentencia los paréntesis si son requeridos.

desde (condicion_inicial; condicion; incremento)
     #codigo
fin

desde (i=0; i <= 10; i++)
     escribir(i)
fin
#salida: 0 1 2 3 4 5 6 7 8 9 10

desde (i=10; i >= 0; i--)
     escribir(i)
fin
#salida: 10 9 8 7 6 5 4 3 2 1 0

Se puede especificar un salto diferente cambiando la expresión de incremento.

desde(i=0; i < 50; i=i+10)
    imprimir(i)
fin
#salida: 0 10 20 30 40

mientras (do while)

Hace que una instrucción o bloque de instrucciones se repitan mientras la condición sea verdadero, los paréntesis son opcionales en la condición.

mientras (condicion)
    #codigo
fin

i=0
mientras i < 10
    escribir(i)
    i++ #incremento
fin
#salida: 0 1 2 3 4 5 6 7 8 9

repetir-hasta (parecido al repeat de Lua)

Hace que una instrucción o bloque de instrucciones se repitan mientra la condición sea falso, las instrucciones de código se ejecutan al menos una vez. Los paréntesis son opcionales en la condición.

repetir
    #codigo
hasta condicion

i=0
repetir
    escribir(i)
    i++ #incremento
hasta i == 10
#salida: 0 1 2 3 4 5 6 7 8 9

Se puede salir de los bucles (desde, mientras y repetir) con la palabra reservada romper.

desde(i=0; i < 10; i++)
    si (i == 5)
        romper    #se sale del ciclo desde
    fin
    imprimir(i)
fin
#salida: 0 1 2 3 4   #se imprime solo hasta el 4

VII. Funciones

Una función consiste generalmente de una lista de sentencias a ejecutar, una lista de parámetros de entrada que regularán dicha acción.

Las funciones se definen con la palabra reservada funcion o la forma corta fun.

Se puede regresar el valor con la palabra clave regresar, retornar o la forma corta ret. La estructura de una función es la siguiente:

funcion nombreFuncion (argumento1, argumento2)
    #codigo
    retornar resultado
fin

#La siguiente función suma dos números
fun sumar(a, b)
  ret a + b
fin

Para invocar (ejecutar) una función se hace con el nombre de la función y la lista de parámetros entre paréntesis.

r = sumar(2, 3)  #se almacena el resultado en la variable r
escribir(r)
#salida: 5

Se pueden crear funciones con un número variable de argumentos con ... en el ultimo parámetro de la definición.

funcion varArgs(arg1, arg2, ...)
  va = [...] #se obtienen los parametros 3 en adelante como una lista y se asignan a la variable va
  escribir("parametro 1: " .. arg1) #imprime el parametro 1
  escribir("parametro 2: " .. arg2) #imprime el parametro 2
  escribir("parametro 3: " .. va[0]) #imprime el parametro 3
  retornar arg1 + arg2
fin

#llamada a función varArgs con 2 elementos
r = varArgs(1, 2)
escribir(r)
#salida:
parametro 1: 1
parametro 2: 2
parametro 3: nulo
3

#llamada a funcion varArgs con 3 elementos
r = varArgs(1, 2, 3)
escribir(r)
#salida:
parametro 1: 1
parametro 2: 2
parametro 3: 3
3

VIII. Listas

Una lista es un tipo de colección. Es equivalente a lo que en otros lenguajes se conoce por arreglos o vectores.

Las listas pueden contener cualquier tipo de dato: lógico, númerico, literal, cadena, listas, diccionarios.

Crear una lista es tan sencillo como indicar entre corchetes y separados por comas los valores que queremos incluir en la lista.

#declaracion de listas
numeros = [1, 2, 3, 4, 5]
vacia = []

Podemos acceder a cada uno de los elementos de la lista escribiendo el nombre de la lista e indicando el índice del elemento entre corchetes []. Ten en cuenta que el índice del primer elemento de la lista es 0:

escribir(numeros[1])
#salida: 2

También podemos utilizar este operador para modificar un elemento de la lista si lo colocamos en la parte izquierda de una asignación:

numeros[0] = 99
escribir(numeros)
#salida: [99, 2, 3, 4, 5]

Podemos utilizar también números negativos. Si se utiliza un número negativo como índice, esto se traduce en que el índice empieza a contar desde el final, hacia la izquierda; es decir, con [-1] accederíamos al último elemento de la lista, con [-2] al penúltimo, con [-3], al antepenúltimo, y así sucesivamente.

escribir(numeros[-1])
#salida: 5

IX. Diccionarios

Los diccionarios, también llamados matrices asociativas, deben su nombre a que son colecciones que relacionan una clave y un valor, entre llaves y separado el valor de la clave con dos puntos.

#Diccionario de personajes y actores:
actores = { "Chilindrina": "Maria Antonieta de las Nieves",
     "El chavo del 8": "Roberto Gomez Bolaños",
     "Tres patines": "Leopoldo Fernandez" }

El primer valor se trata de la clave y el segundo del valor asociado a la clave.

Como clave usamos cadenas, esto es así porque los diccionarios se implementan como tablas hash, y a la hora de introducir un nuevo par clave-valor en el diccionario se calcula el hash de la clave para después poder encontrar la entrada correspondiente rápidamente.

Si se modificara el objeto clave después de haber sido introducido en el diccionario, evidentemente, su hash también cambiaría y no podría ser encontrado.

La diferencia principal entre los diccionarios y las listas es que a los valores almacenados en un diccionario se les accede no por su índice, porque de hecho no tienen orden, sino por su clave, utilizando corchetes [].

escribir(actores["Chilindrina"])
#salida: Maria Antonieta de las Nieves

Al igual que en listas también se puede utilizar corchetes para reasignar valores.

actores["Chilindrina"] = "Maria Antonieta"
escribir(actores["Chilindrina"])
#salida: Maria Antonieta

X. Palabras reservadas hasta el momento

caso
cierto  | verdadero
defecto | otro
desde
elegir
falso
fin
funcion | fun
global
hasta
mientras
nulo
para
repetir
regresar | retornar | ret
romper
si
sino
osi

Licencia

Licenciado bajo la licencia MIT
Cualquier aportación o sugerencia es bienvenida.