LOLCODE

llenguatge de programació

LOLCODE és un llenguatge de programació esotèric inspirat en el llenguatge expressat en exemples del meme d'internet lolcat.[1] El llenguatge va ser creat el 2007 per Adam Lindsay, investigador al Departament de Computació de la Universitat de Lancaster.[2] El llenguatge està clarament definit respecte a prioritat d'operadors i sintaxi correcta, però ja existeixen diferents interpretadors i compiladors funcionals. S'ha demostrat que el llenguatge és Turing complet.[3]

Infotaula de llenguatge de programacióLOLCODE
LOLCode logo.png
Tipusllenguatge de programació esotèric, llenguatge de programació i llenguatge de programació procedural Modifica el valor a Wikidata
Data de creació2007
DesenvolupadorAdam Lindsay
Paradigma de programacióesotèric
Darrera versió estable0.10.5 () Modifica el valor a Wikidata
Influenciat perLolcats
Extensió dels fitxerslol i lols Modifica el valor a Wikidata
Pàgina weblolcode.org Modifica el valor a Wikidata

Estructura del llenguatgeModifica

Paraules reservadesModifica

Les paraules reservades del LOLCODE es treuen del patuès altament comprimit (abreviat) del meme d'Internet lolcat. Totes les paraules reservades s'escriuen en majúscula.

Codi Comentari
HAI En tots els programes en LOLCODE, HAI introdueix el programa.
BTW Comment Introdueix un comentari d'una línia. Es pot utilitzar OBTW Comment TLDR per fer comentaris de múltiples línies.
CAN HAS [library]? En molts llenguatges de programació, una de les primeres instruccions seria una inclusió d'una llibreria per a les funcions bàsiques com les d'entrada i sortida. Normalment s'inclouen amb crides com #include <stdio.h> [stdio referint-se a la llibreria d'entrada i sortida estàndard]. Aquesta instrucció és una derivada d'allò, demanant si es pot obtenir la llibreria, obtenint-la si és possible, i llançant una excepció si no ho és.[4] Es posa principalment per autenticitat — de fet, en les implementacions actuals de LOLCODE s'ignora.
VISIBLE [message] Imprimeix un missatge per pantalla.
GIMMEH [var] Mostra una variable com una cadena de text.
I HAS A [var] Defineix una nova variable. Per defecte aquesta té valor nul, però se li pot assignar afegint a darrere ITZ [value], ITZ A [type] o ITZ LIEK A [var].
[var] R [value] Assigna un valor a una variable.
BOTH SAEM [expr] AN [expr] Compara dues expressions. Retorna WIN si són iguals i FAIL si són diferents. El mètode contrari de BOTH SAEM és DIFFRINT.
BIGGR OF [expr] AN [expr] Obté l'expressió més gran. Per obtenir la més petita s'utilitza SMALLR.
SUM OF [expr] AN [expr] Obté la suma de dues expressions. De manera similar, DIFF obté la resta, PRODUKT el producte, QUOSHUNT el quocient i MOD el mòdul.
MAEK [expr] A [type] Transforma una expressió a un tipus concret. Si l'expressió és una variable aquesta no canvia, excepte utilitzant [var] R MAEK [var] A [type] o bé de forma equivalent [var] IS NOW A [type].
SRS [var] Interpreta una variable de text com un identificador.
[expr], O RLY?
 YA RLY
 [code]
 NO WAI
 [code]
 OIC
Condicional de tipus 'if', si es compleix s'executa el codi dins de YA RLY, si no el de NO WAI.
[expr], WTF?
 OMG [value]
 [code]
 OMG [value]
 [code]
 OMGWTF
 [code]
 OIC
Condicional de tipus 'case'.
IM IN YR [label]
	[code]
IM OUTTA YR [label]
Bucle infinit. A la primera línia s'hi pot incloure una variable comptador fins a cert màxim, afegint-hi UPPIN|NERFIN YR [var] (UPPIN per incrementar i NERFIN per reduir) i/o una condició de tipus until o while amb TIL|WILE [expr] (TIL sent l'equivalent a until i WILE a while).
KTHXBYE HAI introdueix el programa, per tant, KTHXBYE (que significa "Okay Thanks, Bye") el finalitza.

FuncionsModifica

Les funcions són declarades de la següent manera:

HOW IZ I [nom de la funció] (YR [argument1] (AN YR [argument2] (AN YR [argument3] ...))) [bloc de codi] IF U SAY SO

La funció pot retornar un valor concret fent servir FOUND YR [expression] o bé un valor nul amb GTFO.

Per executar la funció es fa amb:

I IZ [nom de la funció] (YR [argument1] (AN YR [argument2] (AN YR [argument3] ...))) MKAY

Si els arguments són expressions, s'evaluen abans d'executar la funció.

Tipus de variablesModifica

Codi Comentari
NOOB Variable no definida.
TROOF Variable booleana, pot ser WIN (true) o FAIL (false).
NUMBR Nombre enter. Pot ser positiu o negatiu.
NUMBAR Nombre amb decimals.
YARN Cadena de caràcters.
BUKKIT Llista d'elements.

YARN és indicada entre cometes ("). Tots els caràcters de la cadena representen el seu propi valor excepte :, que és el caràcter d'escapament. :) és el salt de línia, :> és una tabulació, :" permet incloure les cometes i :: els dos punts, :([hex]) mostra un caràcter indicat amb codi hexadecimal, :{[var]} permet inserir el valor actual d'una variable a la cadena, i :[[char name]] obté una lletra a partir del seu nom normatiu Unicode.

La següent funció interna permet concatenar diferents YARN:

SMOOSH [argument1] AN [argument2] (AN [argument3] (AN [argument4] ...)) MKAY

BUKKIT es pot definir de dues maneres:

BTW declaration of the BUKKIT
I HAS A [object] ITZ A BUKKIT

BTW creating a variable in a slots
[object] HAS A [var] ITZ [value]

BTW creating a function inside the BUKKIT
HOW IZ [object] [function name] (YR [argument1] (AN YR [argument2] (AN YR [argument3] ...)))
	[function code]
IF U SAY SO
BTW declaration of the BUKKIT
O HAI IM [object]
	BTW creating a variable in a slot
	I HAS A [var] ITZ [value]

	BTW creating a function inside the BUKKIT
	HOW IZ I [function name] (YR [argument1] (AN YR [argument2] (AN YR [argument3] ...)))
		[function code]
	IF U SAY SO
KTHX

ExemplesModifica

Els següents programes són un programa Hola Món! i un programa simple per imprimir un fitxer per pantalla.[5] El Houston Chronicle va publicar-ne un codi semblant.[1]

Exemple 1Modifica

HAI
CAN HAS STDIO?
VISIBLE "HAI WORLD!"
KTHXBYE

Exemple 2Modifica

 HAI
 CAN HAS STDIO?
 PLZ OPEN FILE "LOLCATS.TXT"?
 AWSUM THX
 VISIBLE FILE
 O NOES
 INVISIBLE "ERROR!"
 KTHXBYE

En aquest exemple, s'introdueixen les instruccions per a obrir un fitxer(PLZ OPEN FILE "NAME"? — "Please try to open a file?"), i tractament d'errors (AWSUM THX — "Awesome, thanks!", i O NOES — "Oh no!").[5]

Altres comandes inclouen I HAS A variable per a declarar variables, variable R valor ("variable [és/està/sent] value") per a tal d'assignar valors a les variables, enviant errors per la sortida amb INVISIBLE en comptes de VISIBLE, i BTW ("by the way") per a anotar comentaris, fent que l'analitzador sintàctic ignori la resta de la línia. Els bucles es creen amb IM IN YR etiqueta (del meme d'internet "I'm in your ___"), i acaben amb IM OUTTA YR etiqueta. Els bucles no tenen comptadors ni condicions, i, per tant, no acaben intrínsecament. Els bucles també es poden acabar amb la comanda condicional IZ:

Exemple 3Modifica

HAI
CAN HAS STDIO?
I HAS A VAR
IM IN YR LOOP
 UP VAR!!1
 IZ VAR BIGGER THAN 10? KTHX
 VISIBLE VAR
IM OUTTA YR LOOP
KTHXBYE

Aquest simple programa imprimeix per pantalla els nombres de l'1 al 10 i acaba (amb l'especificació 1.0). El mateix programa amb l'especificació 1.2 (assumint que VAR comença a 0):

HAI
CAN HAS STDIO?
IM IN YR LOOP UPPIN YR VAR TIL BOTH SAEM VAR AN 10
 VISIBLE SUM OF VAR AN 1
IM OUTTA YR LOOP
KTHXBYE

ImplementacionsModifica

La primera implementació LOLCODE va ser un analitzador sintàctic PHP escrit per Jeff Jones.[6][7] La web de l'analitzador sintàctic també va ser la primera web usant LOLCODE com a llenguatge de scripts. Com que és codi lliure amb una llicència d'estil BSD, s'ha bifurcat i usat en diverses webs per a implementar scripts LOLCODE. La presentació Pecha Kucha guanyadora a l'edició del 2008 de PHP Works era sobre aquest analitzador.[8][9]

Hi ha un compilar .NET per a LOLCODE escrit per Nick Johnson,[10] i que va tenir un article en els seminaris d'entrenament de desenvolupadors de Microsoft, la Conferència TechEd de 2007 (Austràlia).[11][12][13]

PL/LOLCODE, un projecte dirigit per Josh Tolley, fa que el LOLCODE estigui disponible com a llenguatge de programació des d'un servidor dins de PostgreSQL.[14]

El Dynamic Language Runtime de Microsoft té una implementació de LOLCODE per a fins experimentals.[15]

També hi ha disponible un interpretador JavaScript.[16]

També hi ha un compilador LOLCODE inclòs amb la màquina virtual Parrot com un dels llenguatges demostrant l'ús de les eines de compilació del Parrot.[17]

Existeix un interpretador de baix nivell escrit en C, mantingut per Justin J. Meza, per a proveir d'interpretació LOLCODE en diverses plataformes.[18]

Projectes relacionatsModifica

LOLCODE també ha inspirat LOLPython, escrit per Andrew Dalke. LOLPython usa una sintaxi inspirada en Lolcats similar a la del LOLCODE, però amb estil semblant al Python. Funciona traduint la font Python en codi Python.[19]

ReferènciesModifica

  1. 1,0 1,1 Dwight Silverman. «I'm in ur newspaper writin mah colum». Chron.com, 06-06-2007. [Consulta: 6 juny 2007].
  2. Hammock, Anne «The new fame: Internet celebrity». CNN, 01-05-2008.
  3. Arachnid. «Proof that LOLCode is turing complete:BrainF*** interpreter in LOLCode». forum.lolcode.com. Arxivat de l'original el 2007-07-11. [Consulta: 5 octubre 2008].
  4. «keywords:can-has · LOLCODE». Arxivat de l'original el 2008-02-06. [Consulta: 10 febrer 2008].
  5. 5,0 5,1 Adam Lindsay. «" LOLCODE main page». lolcode.com, 25-05-2007. [Consulta: 2 octubre 2007].
  6. «First Parser Comment». Lindsay.at. Arxivat de l'original el 2009-05-19. [Consulta: 9 juny 2009].
  7. «Tetraboy's LOLCODE parser». Tetraboy.com. Arxivat de l'original el 2009-02-27. [Consulta: 9 juny 2009].
  8. «"The Best Web Language: LOLCODE" Slides». Slideshare.net. [Consulta: 9 juny 2009].
  9. PHP Works
  10. LOLCODE .NET compiler Arxivat 2016-03-10 a Wayback Machine. at Google Code
  11. TechEd Day 2: Microsoft announces LOLCode support, Long Zheng
  12. LOLcode in next Visual Studio? For young and funny cats, NetworkWorld.com
  13. «Video of LOLCODE presentation at TechEd 2007». Blip.tv, 17-08-2007. Arxivat de l'original el 2009-02-05. [Consulta: 9 juny 2009].
  14. PL/LOLCODE Arxivat 2010-11-28 a Wayback Machine., pgFoundry
  15. Deep DLR, John Lam and Martin Maly
  16. «LolCode». Fullvolume.co.uk. [Consulta: 9 juny 2009].
  17. «Lightning-Parrot». lolcode.com. Arxivat de l'original el 2009-03-22. [Consulta: 20 juny 2009].
  18. [enllaç sense format] http://www.icanhaslolcode.org/ Arxivat 2011-07-18 a Wayback Machine. I Can Has lolcode? - an efficient LOLCODE interpreter written in C.
  19. «LOLPython». Dalkescientific.com, 01-06-2007. [Consulta: 9 juny 2009].

Enllaços externsModifica