Loops/Infinite: Difference between revisions

no edit summary
(Rapira Infinite Loop)
No edit summary
 
(34 intermediate revisions by 27 users not shown)
Line 25:
 
=={{header|11l}}==
<langsyntaxhighlight lang="11l">L
print(‘SPAM’)</langsyntaxhighlight>
 
=={{header|360 Assembly}}==
This for sure will result in a severe WTO buffer shortage.
<syntaxhighlight lang="360 assembly">
<lang 360 Assembly>
INFINITE CSECT , this PGM control section
INFINITE AMODE 31 addressing mode 31 bit
Line 47:
RETURN PR , return to caller
END INFINITE
</syntaxhighlight>
</lang>
 
=={{header|4DOS Batch}}==
 
<langsyntaxhighlight lang="4dos">@echo off
do forever
echo SPAM
enddo</langsyntaxhighlight>
 
=={{header|6502 Assembly}}==
Specific OS/hardware routines for printing are left unimplemented.
<langsyntaxhighlight lang="6502asm">InfiniteLoop LDX #0
PrintLoop: LDA MSG,x
JSR PrintAccumulator ;routine not implemented
Line 66:
BEQ InfiniteLoop
 
MSG .byte "SPAM", $0A</langsyntaxhighlight>
 
=={{header|6800 Assembly}}==
<syntaxhighlight lang="text"> .cr 6800
.tf spam6800.obj,AP1
.lf spam6800
Line 99:
;=====================================================;
string .as "SPAM",#13,#10,#0
.en</langsyntaxhighlight>
 
=={{header|68000 Assembly}}==
Hardware-specific routines for I/O are left unimplemented and just displayed as a subroutine, as this is not the focus of the task.
<langsyntaxhighlight lang="68000devpac">doSPAM:
LEA Message,A0
JSR PrintString
Line 110:
Message:
DC.B "SPAM",13,10,0
EVEN</langsyntaxhighlight>
 
=={{header|8086 Assembly}}==
{{works with|https://www.dosbox.com DOSBox}}
===Loading Immediates===
<langsyntaxhighlight lang="asm">Spam:
mov ah,02h
mov dl,'S' ;VASM replaces a character in single quotes with its ascii equivalent
Line 135:
int 21h
 
jmp Spam</langsyntaxhighlight>
 
===Loading From A Data Source===
<langsyntaxhighlight lang="asm">mov ah, 02h ;prep int 21h for printing to screen
mov ax, seg SpamMessage ;load into ax whatever segment the address of our message is in.
mov ds, ax ;segment registers on the original 8086 must be loaded from a register
Line 154:
jmp SpamInner
 
SpamMessage db "SPAM",13,10,0</langsyntaxhighlight>
 
=={{header|8th}}==
One way:
<langsyntaxhighlight lang="forth">
: inf "SPAM\n" . recurse ;
</syntaxhighlight>
</lang>
Another way:
<langsyntaxhighlight lang="forth">
: inf repeat "SPAM\n" . again ;
</syntaxhighlight>
</lang>
=={{header|AArch64 Assembly}}==
{{works with|as|Raspberry Pi 3B version Buster 64 bits}}
<syntaxhighlight lang="aarch64 assembly">
<lang AArch64 Assembly>
/* ARM assembly AARCH64 Raspberry PI 3B */
/* program infinite64.s */
Line 201:
/* for this file see task include a file in language AArch64 assembly */
.include "../includeARM64.inc"
</syntaxhighlight>
</lang>
=={{header|ACL2}}==
<langsyntaxhighlight Lisplang="lisp">(defun spam ()
(declare (xargs :mode :program))
(if nil
nil
(prog2$ (cw "SPAM~%")
(spam))))</langsyntaxhighlight>
 
=={{header|Action!}}==
<langsyntaxhighlight Actionlang="action!">PROC Main()
DO
PrintE("SPAM")
OD
RETURN</langsyntaxhighlight>
{{out}}
[https://gitlab.com/amarok8bit/action-rosetta-code/-/raw/master/images/Infinite.png Screenshot from Atari 8-bit computer]
Line 235:
 
=={{header|ActionScript}}==
<langsyntaxhighlight lang="actionscript">while (true) {
trace("SPAM");
}</langsyntaxhighlight>
 
=={{header|Ada}}==
<langsyntaxhighlight lang="ada">loop
Put_Line("SPAM");
end loop;</langsyntaxhighlight>
 
=={{header|Agena}}==
Tested with Agena 2.9.5 Win32
<langsyntaxhighlight lang="agena">do
print( "SPAM" )
od</langsyntaxhighlight>
 
=={{header|Aime}}==
<langsyntaxhighlight lang="aime">while (1) {
o_text("SPAM\n");
}</langsyntaxhighlight>
 
=={{header|ALGOL 60}}==
Line 265:
'''end'''
{{works with|ALGOL 60|OS/360}}
<langsyntaxhighlight lang="algol60">'BEGIN' 'COMMENT' Loops/Infinite - Algol60 - 23/06/2018;
'INTEGER' I;
'FOR' I := 1 'STEP' 0 'UNTIL' 2 'DO'
OUTSTRING(1,'('SPAM')')
'END'</langsyntaxhighlight>
 
=={{header|ALGOL 68}}==
<langsyntaxhighlight lang="algol68">DO
printf($"SPAM"l$)
OD</langsyntaxhighlight>
Or the classic "dynamic halt":
<langsyntaxhighlight lang="algol68">loop x:
printf($"SPAM"l$);
loop x</langsyntaxhighlight>
 
=={{header|ALGOL W}}==
<langsyntaxhighlight lang="algolw">begin
for i := 1 step 0 until 2 do write( "SPAM" )
end.</langsyntaxhighlight>
 
=={{header|AmigaE}}==
<langsyntaxhighlight lang="amigae">PROC main()
LOOP
WriteF('SPAM')
ENDLOOP
ENDPROC</langsyntaxhighlight>
 
=={{header|AppleScript}}==
<langsyntaxhighlight lang="applescript">repeat
log "SPAM"
end repeat</langsyntaxhighlight>
 
=={{header|ARM Assembly}}==
<syntaxhighlight lang="arm_assembly">
<lang ARM_Assembly>
.global main
 
Line 310:
message:
.asciz "SPAM\n"
</syntaxhighlight>
</lang>
 
=={{header|ArnoldC}}==
<langsyntaxhighlight ArnoldClang="arnoldc">IT'S SHOWTIME
STICK AROUND @NO PROBLEMO
TALK TO THE HAND "SPAM"
CHILL
YOU HAVE BEEN TERMINATED</langsyntaxhighlight>
 
=={{header|Arturo}}==
<langsyntaxhighlight lang="rebol">while [true] [
print "SPAM"
]</langsyntaxhighlight>
 
=={{header|AutoHotkey}}==
<langsyntaxhighlight lang="autohotkey">Loop
MsgBox SPAM `n</langsyntaxhighlight>
 
=={{header|AWK}}==
<langsyntaxhighlight lang="awk">BEGIN {
while(1) {
print "SPAM"
}
}</langsyntaxhighlight>
 
=={{header|Axe}}==
Warning: running this program will cause you to need to reset your calculator, thereby losing any user data stored in RAM.
 
<langsyntaxhighlight lang="axe">While 1
Disp "SPAM",i
End</langsyntaxhighlight>
 
=={{header|BASIC}}==
{{works with|QuickBasic|4.5}}
Old-fashioned syntax:
<langsyntaxhighlight lang="qbasic">while 1
print "SPAM"
wend</langsyntaxhighlight>
 
Standard BASIC:
<langsyntaxhighlight lang="qbasic">do
print "SPAM"
loop</langsyntaxhighlight>
 
Also
<langsyntaxhighlight lang="qbasic">for i = 1 to 10 step 0
print "SPAM"
next i</langsyntaxhighlight>
 
{{works with|Applesoft BASIC}}
{{works with|Commodore BASIC}}
{{works with|Tiny BASIC}}
{{works with|ZX Spectrum Basic}}
 
The most intuitive method is to use the <code>GOTO</code> statement.
 
<langsyntaxhighlight lang="gwbasic">10 print "SPAM"
20 goto 10</langsyntaxhighlight>
 
Generally, using <code>GOSUB</code> in place of <code>GOTO</code> is incorrect. Some programming bugs come about when a <code>GOSUB</code> causes a potentially infinite loop, however, eventually stack memory will fill up and cause a terminating error as shown in this Commodore BASIC example:
Line 386 ⟶ 387:
The solution is to keep the stack empty, however, this will also clear all variables used and prevent the use of <code>RETURN</code>ing from the "subroutine". This is accomplished with the <code>CLEAR</code> (or <code>CLR</code> in Commodore BASIC) placed at the start of the loop.
 
<langsyntaxhighlight lang="gwbasic">10 clr:print "Commodore Spam! ";:gosub 10</langsyntaxhighlight>
<langsyntaxhighlight lang="gwbasic">10 clear : print "Apple Spam! ";: gosub 10</langsyntaxhighlight>
 
Rather than a <code>GOTO</code>, instead we can use a <code>FOR... NEXT</code> statement:
 
<langsyntaxhighlight lang="gwbasic">10 for i = 1 to 10 step 0 : rem A zero step makes the loop infinite
20 print "SPAM";
30 next i</langsyntaxhighlight>
 
In most cases, we can also call the <code>RUN</code> command from within the program.
 
<langsyntaxhighlight lang="gwbasic">10 print "Spam! ";
20 run</langsyntaxhighlight>
 
<code>IF... THEN</code> has an implied <code>GOTO</code> on some BASICs...
 
<langsyntaxhighlight lang="gwbasic">10 print "SPAM SPAM! ";:if 1 then 10</langsyntaxhighlight>
 
==={{header|Applesoft BASIC}}===
<langsyntaxhighlight ApplesoftBasiclang="applesoftbasic">FOR I = 0 TO 1 STEP 0 : PRINT "SPAM" : NEXT</langsyntaxhighlight>
 
 
==={{header|BASIC256}}===
<langsyntaxhighlight BASIC256lang="basic256">while true
print "SPAM"
end while</langsyntaxhighlight>
 
==={{header|CommodoreChipmunk BASICBasic}}===
{{works with|Chipmunk Basic|3.6.4}}
<syntaxhighlight lang="qbasic">10 while 1
20 print "SPAM"
30 wend</syntaxhighlight>
 
==={{header|Commodore BASIC}}===
In addition to the general examples listed above for [[#BASIC|BASIC]], there is a trick to get a Commodore BASIC program to endlessly loop its listing. All of the lines of code are a linked list in RAM. The trick is accomplished by modifying the pointer to the next line, which is recorded at the very start of each tokenized BASIC line. Instead of it pointing to the next line, you can make it point to a previous line, or itself. This will affect execution when any <code>GOTO</code> or <code>GOSUB</code> needs to reference any line number '''after''' the affected line, since the line search will be corrupted (and endless...)
 
Line 446 ⟶ 452:
ready.
&#9608;</pre>
 
==={{header|Craft Basic}}===
<syntaxhighlight lang="text">
do
print "SPAM"
loop
</syntaxhighlight>
 
==={{header|GW-BASIC}}===
{{works with|PC-BASIC}}
<syntaxhighlight lang="qbasic">10 WHILE 1
20 PRINT "SPAM"
30 WEND</syntaxhighlight>
Also
<syntaxhighlight lang="qbasic">10 PRINT "SPAM"
20 GOTO 10</syntaxhighlight>
 
==={{header|IS-BASIC}}===
<langsyntaxhighlight ISlang="is-BASICbasic">100 DO
110 PRINT "SPAM"
120 LOOP</langsyntaxhighlight>
 
==={{header|MSX Basic}}===
<syntaxhighlight lang="qbasic">10 FOR I = 1 TO 10 STEP 0
20 PRINT "SPAM"
30 NEXT I</syntaxhighlight>
Also
<syntaxhighlight lang="qbasic">10 PRINT "SPAM"
20 GOTO 10</syntaxhighlight>
 
==={{header|QB64}}===
<langsyntaxhighlight QB64lang="qb64">'Using Do loop
Do 'Alternatively this could have a conditional, "Do While 1"
Print "SPAM"
Line 461 ⟶ 491:
While 1
Print "SPAM"
Wend</langsyntaxhighlight>
 
==={{header|Quite BASIC}}===
<syntaxhighlight lang="qbasic">10 print "SPAM"
20 goto 10</syntaxhighlight>
 
==={{Header|Tiny BASIC}}===
<syntaxhighlight lang="qbasic"> 10 PRINT "SPAM"
GOTO 10</syntaxhighlight>
 
==={{header|True BASIC}}===
<langsyntaxhighlight lang="qbasic">DO
PRINT "SPAM"
LOOP
END</langsyntaxhighlight>
 
==={{header|Yabasic}}===
<syntaxhighlight lang="yabasic">do
<lang Yabasic>do
print "SPAM"
loop</langsyntaxhighlight>
 
O también
<langsyntaxhighlight Yabasiclang="yabasic">while true
print "SPAM"
wend</langsyntaxhighlight>
 
=={{header|Batch File}}==
Using <code>goto</code>:
<langsyntaxhighlight lang="dos">@echo off
:loop
echo SPAM
goto loop</langsyntaxhighlight>
Another variant which uses Windows NT's <code>for</code> statement:
 
{{works with|Windows NT|4 or later}}
<langsyntaxhighlight lang="dos">for /l %%x in (1,0,2) do @echo SPAM</langsyntaxhighlight>
This essentially is a counted loop which starts at <code>1</code>, increments by <code>0</code> and stops when the counter reaches <code>2</code>.
 
=={{header|BBC BASIC}}==
<langsyntaxhighlight lang="bbcbasic"> REPEAT
PRINT "SPAM"
UNTIL FALSE</langsyntaxhighlight>
 
=={{header|bc}}==
<langsyntaxhighlight lang="bc">while (1) "SPAM
"</langsyntaxhighlight>
 
=={{header|BCPL}}==
<langsyntaxhighlight BCPLlang="bcpl">get "libhdr"
 
let start() be writes("SPAM*N") repeat</langsyntaxhighlight>
 
=={{header|beeswax}}==
<langsyntaxhighlight lang="beeswax">_>`SPA`p
bN`M`<</langsyntaxhighlight>
 
=={{header|Befunge}}==
Because the 2-D code space is toroidal, all loops are infinite
unless explicitly stopped with '''@'''.
<langsyntaxhighlight lang="befunge">55+"MAPS",,,,,</langsyntaxhighlight>
 
=={{header|Binary Lambda Calculus}}==
Adding "SPAM\n" to the BLC8 cycle program generated from https://github.com/tromp/AIT/blob/master/lists/cycle.lam
gives the 16 byte program
<pre>11 a1 72 34 00 2d e5 e7 ef b3 40 53 50 41 4d 0a</pre>
 
=={{header|blz}}==
<langsyntaxhighlight lang="blz">while true
print("SPAM")
end</langsyntaxhighlight>
 
=={{header|bootBASIC}}==
Using <code>goto</code>:
<langsyntaxhighlight bootBASIClang="bootbasic">10 print "SPAM"
20 goto 10</langsyntaxhighlight>
 
Using <code>run</code>:
<langsyntaxhighlight bootBASIClang="bootbasic">10 print "SPAM"
20 run</langsyntaxhighlight>
 
=={{header|BQN}}==
Line 533 ⟶ 575:
The main way of performing an infinite loop in BQN is using recursion.
 
<langsyntaxhighlight BQNlang="bqn">{𝕊 •Out 𝕩}"SPAM"</langsyntaxhighlight>
 
will likely end in a stack overflow.
 
=={{header|Bracmat}}==
<syntaxhighlight lang ="bracmat">whl'out$SPAM</langsyntaxhighlight>
 
=={{header|Brainf***}}==
Optimized for code size:
<langsyntaxhighlight lang="bf">++++++++++[->++++++>++++++++>+<<<]>+++++>
[+++.---.<.>---.+++>.<]</langsyntaxhighlight>
 
Optimized for execution speed:
<langsyntaxhighlight lang="bf">10++++++++++
[-> 8++++++++ > 8++++++++ > 6++++++ > 8++++++++ > 1+ <<<<<]>
83+++ > 80 > 65+++++ > 77--- <<<
[.>.>.>.>.<<<<]</langsyntaxhighlight>
 
=={{header|Brat}}==
<langsyntaxhighlight lang="brat">loop { p "SPAM" }</langsyntaxhighlight>
 
=={{header|Bruijn}}==
<syntaxhighlight lang="bruijn">
:import std/String .
 
main [spam spam]
spam ["SPAM\n" ++ (0 0)]
</syntaxhighlight>
 
=={{header|C}}==
<langsyntaxhighlight lang="c">while(1) puts("SPAM");</langsyntaxhighlight>
or
<langsyntaxhighlight lang="c"> for(;;) puts("SPAM");</langsyntaxhighlight>
or
<langsyntaxhighlight lang="c">do { puts("SPAM"); } while(1);</langsyntaxhighlight>
or
<langsyntaxhighlight lang="c">while(puts("SPAM"));</langsyntaxhighlight>
or
<syntaxhighlight lang="c">
<lang c>
spam: puts("SPAM");
goto spam;
</syntaxhighlight>
</lang>
 
=={{header|C sharp|C#}}==
 
<langsyntaxhighlight lang="csharp">while (true)
{
Console.WriteLine("SPAM");
}</langsyntaxhighlight>
 
=={{header|C++}}==
{{trans|C}}
<langsyntaxhighlight lang="cpp">while (true)
std::cout << "SPAM\n";</langsyntaxhighlight>
or
<langsyntaxhighlight lang="cpp">for (;;)
std::cout << "SPAM\n";</langsyntaxhighlight>
or
<langsyntaxhighlight lang="cpp">do
std::cout << "SPAM\n";
while (true);</langsyntaxhighlight>
 
=={{header|C3}}==
<syntaxhighlight lang="c3">while(1) io::printn("SPAM");</syntaxhighlight>
or
<syntaxhighlight lang="c3">for(;;) io::printn("SPAM");</syntaxhighlight>
or
<syntaxhighlight lang="c3">do { io::printn("SPAM"); } while(1);</syntaxhighlight>
or
<syntaxhighlight lang="c3">switch (1)
{
case 1:
io::printn("SPAM");
nextcase 1;
}
</syntaxhighlight>
 
=={{header|Chapel}}==
<langsyntaxhighlight lang="chapel">while true do writeln("SPAM");</langsyntaxhighlight>
 
=={{header|ChucK}}==
<syntaxhighlight lang="text">
while(true) <<<"SPAM">>>;
</syntaxhighlight>
</lang>
 
=={{header|Clojure}}==
<langsyntaxhighlight lang="lisp">(loop [] (println "SPAM") (recur))</langsyntaxhighlight>
 
=={{header|COBOL}}==
<langsyntaxhighlight lang="cobol"> IDENTIFICATION DIVISION.
PROGRAM-ID. Spam.
 
Line 608 ⟶ 673:
 
GOBACK
.</langsyntaxhighlight>
[[OpenCOBOL]] supports a <code>FOREVER</code> clause for <code>PERFORM</code> which will have the same effect.
 
=={{header|CoffeeScript}}==
<langsyntaxhighlight lang="coffeescript">loop
console.log 'SPAM'
</syntaxhighlight>
</lang>
 
=={{header|ColdFusion}}==
Line 620 ⟶ 685:
 
With tags:
<langsyntaxhighlight lang="cfm"><cfloop condition = "true NEQ false">
SPAM
</cfloop></langsyntaxhighlight>
With script:
<langsyntaxhighlight lang="cfm"><cfscript>
while( true != false )
{
writeOutput( "SPAM" );
}
</cfscript></langsyntaxhighlight>
 
=={{header|Comal}}==
<langsyntaxhighlight Comallang="comal">LOOP
PRINT "SPAM"
ENDLOOP</langsyntaxhighlight>
 
=={{header|Common Lisp}}==
<langsyntaxhighlight lang="lisp">(loop (write-line "SPAM"))</langsyntaxhighlight>
 
=== Using DO ===
<langsyntaxhighlight lang="lisp">
(do () ; Not initialization
(nil) ; Not break condition
(print "SPAM")) ; On every loop as requested
</syntaxhighlight>
</lang>
 
{{out}}
Line 653 ⟶ 718:
 
=={{header|Corescript}}==
<syntaxhighlight lang="corescript">
<lang Corescript>
:top
print Spam!
goto top
</syntaxhighlight>
</lang>
 
=={{header|Cowgol}}==
<langsyntaxhighlight lang="cowgol">include "cowgol.coh";
 
loop
print("Spam\n");
end loop;</langsyntaxhighlight>
 
=={{header|Crystal}}==
<langsyntaxhighlight lang="crystal">loop do
puts "SPAM"
end</langsyntaxhighlight>
 
Using <code>while</code>/<code>until</code>:
<langsyntaxhighlight lang="crystal">while true
puts "SPAM"
end</langsyntaxhighlight>
<langsyntaxhighlight lang="crystal">until false
puts "SPAM"
end</langsyntaxhighlight>
 
Using an infinite range:
<langsyntaxhighlight lang="crystal">(0..).each do
puts "SPAM"
end</langsyntaxhighlight>
 
=={{header|D}}==
Some common ways to create an infinite printing loop:
<langsyntaxhighlight lang="d">import std.stdio;
 
void main() {
while (true)
writeln("SPAM");
}</langsyntaxhighlight>
 
<langsyntaxhighlight lang="d">import std.stdio;
 
void main() {
Line 699 ⟶ 764:
writeln("SPAM");
while (true);
}</langsyntaxhighlight>
 
<langsyntaxhighlight lang="d">import std.stdio;
 
void main() {
for ( ; ; )
writeln("SPAM");
}</langsyntaxhighlight>
 
<langsyntaxhighlight lang="d">import std.stdio;
 
void main() {
Line 714 ⟶ 779:
writeln("SPAM");
goto LOOP;
}</langsyntaxhighlight>
 
=={{header|Dart}}==
<syntaxhighlight lang="text">
main() {
while(true) {
Line 723 ⟶ 788:
}
}
</syntaxhighlight>
</lang>
 
=={{header|dc}}==
<langsyntaxhighlight lang="dc">[[SPAM
]P dx]dx</langsyntaxhighlight>
 
This loop is a tail-recursive function.
Line 735 ⟶ 800:
 
=={{header|DCL}}==
<langsyntaxhighlight DCLlang="dcl">$ loop:
$ write sys$output "SPAM"
$ goto loop</langsyntaxhighlight>
 
=={{header|Delphi}}==
''See [[#Pascal|Pascal]]''
 
=={{header|DIBOL-11}}==
<syntaxhighlight lang="DIBOL-11">
START ;Infinite Loop
 
RECORD SPAM
, A4, 'SPAM'
 
PROC
XCALL FLAGS (0007000000,1) ;Suppress STOP message
 
OPEN(8,O,'TT:')
LOOP,
WRITES(8,SPAM)
GOTO LOOP
END
</syntaxhighlight>
 
=={{header|Draco}}==
<langsyntaxhighlight lang="draco">proc nonrec main() void:
while true do
writeln("SPAM")
od
corp</langsyntaxhighlight>
 
=={{header|DWScript}}==
 
<langsyntaxhighlight Delphilang="delphi">while True do
PrintLn('SPAM');</langsyntaxhighlight>
 
=={{header|Dyalect}}==
 
<langsyntaxhighlight Dyalectlang="dyalect">while true {
print("SPAM")
}</langsyntaxhighlight>
 
=={{header|Déjà Vu}}==
<langsyntaxhighlight lang="dejavu">while true:
!print "SPAM"</langsyntaxhighlight>
Infinite recursion thanks to tail calls:
<langsyntaxhighlight lang="dejavu">labda:
!print "SPAM"
recurse
call</langsyntaxhighlight>
 
=={{header|E}}==
 
<langsyntaxhighlight lang="e">while (true) {
println("SPAM")
}</langsyntaxhighlight>
 
<langsyntaxhighlight lang="e">def f() {
println("SPAM")
f <- ()
}
f <- ()</langsyntaxhighlight>
 
The difference between these is that in the second,
other activities can be interleaved with the loop;
in the first, no other processing will occur in this vat.
 
=={{header|EasyLang}}==
<syntaxhighlight lang="easylang">
while 1 = 1
print "SPAM"
.
</syntaxhighlight>
 
=={{header|EDSAC order code}}==
The EDSAC instruction set does not include an unconditional jump: it is necessary to synthesize it by using either an <code>E</code> "branch on accumulator sign bit clear" or <code>F</code> "branch on accumulator sign bit set" order, in circumstances where the condition is guaranteed to be met. For this specific task, guaranteeing it is trivial: printing characters does not change the contents of the accumulator at all. The solution presented here, however, is more general. We use a <code>T</code> "transfer and clear" order to store the accumulator's contents in storage address <i>θ</i>+17, then jump back to the beginning of the loop and reload the accumulator with an <code>A</code> "add" order. Note that the storage address used as a temporary variable should be set to zero on entry to the loop.
<langsyntaxhighlight lang="edsac">[ Infinite loop
=============
 
Line 819 ⟶ 908:
[ 17 ] PF
 
EZPF</langsyntaxhighlight>
 
=={{header|Ela}}==
Line 825 ⟶ 914:
===Direct Approach===
 
<langsyntaxhighlight lang="ela">open monad io
 
loop () = do
Line 831 ⟶ 920:
loop ()
 
loop () ::: IO</langsyntaxhighlight>
 
===Non-strict version===
 
<langsyntaxhighlight lang="ela">open monad io
 
xs = "SPAM"::xs
Line 844 ⟶ 933:
takeit (num - 1) xs
 
_ = takeit 10 xs ::: IO</langsyntaxhighlight>
 
=={{header|Elena}}==
ELENA 46.x:
<langsyntaxhighlight lang="elena">public program()
{
while (true)
{
console.writeLine:("spam")
}
}</langsyntaxhighlight>
 
=={{header|Elixir}}==
<langsyntaxhighlight lang="elixir">defmodule Loops do
def infinite do
IO.puts "SPAM"
Line 864 ⟶ 953:
end
 
Loops.infinite</langsyntaxhighlight>
or
<langsyntaxhighlight lang="elixir">Stream.cycle(["SPAM"]) |> Enum.each(&IO.puts &1)</langsyntaxhighlight>
 
=={{header|Emacs Lisp}}==
 
<langsyntaxhighlight lang="lisp">(while t
(message "SPAM"))</langsyntaxhighlight>
 
=={{header|EMal}}==
<syntaxhighlight lang="emal">
for ever
writeLine("SPAM")
end
</syntaxhighlight>
 
=={{header|Erlang}}==
<langsyntaxhighlight lang="erlang">
-module (main).
-export ([main/0]).
Line 881 ⟶ 977:
io:fwrite( "SPAM~n" ),
main().
</syntaxhighlight>
</lang>
 
=={{header|ERRE}}==
<syntaxhighlight lang="erre">
<lang ERRE>
LOOP
PRINT("SPAM")
END LOOP
</syntaxhighlight>
</lang>
You can use also WHILE TRUE..END WHILE or REPEAT...UNTIL FALSE loops.
 
=={{header|Euphoria}}==
<syntaxhighlight lang="euphoria">
<lang Euphoria>
while 1 do
puts(1, "SPAM\n")
end while
</syntaxhighlight>
</lang>
 
=={{header|F Sharp|F#}}==
<langsyntaxhighlight lang="fsharp">
// Imperative Solution
while true do
Line 908 ⟶ 1,004:
printfn "SPAM"
forever ()
</syntaxhighlight>
</lang>
 
=={{header|Factor}}==
Tail recursion:
<langsyntaxhighlight lang="factor">: spam ( -- ) "SPAM" print spam ;</langsyntaxhighlight>
Looping combinators:
<langsyntaxhighlight lang="factor">[ "SPAM" print t ] loop</langsyntaxhighlight>
<langsyntaxhighlight lang="factor">USE: combinators.extras
[ "SPAM" print ] forever</langsyntaxhighlight>
 
=={{header|FALSE}}==
<langsyntaxhighlight lang="false">[1]["SPAM
"]#</langsyntaxhighlight>
 
=={{header|Fantom}}==
 
<langsyntaxhighlight lang="fantom">
class Main
{
Line 935 ⟶ 1,031:
}
}
</syntaxhighlight>
</lang>
 
=={{header|Fermat}}==
<langsyntaxhighlight lang="fermat">while 1 do !!'SPAM'; od</langsyntaxhighlight>
 
=={{header|Fish}}==
<langsyntaxhighlight lang="fish">a"MAPS"ooooo</langsyntaxhighlight>
 
=={{header|Forth}}==
<langsyntaxhighlight lang="forth">: email begin ." SPAM" cr again ;</langsyntaxhighlight>
 
=={{header|Fortran}}==
FORTRAN 77
<langsyntaxhighlight lang="fortran">
10 WRITE(*,*) 'SPAM'
GO TO 10
END
</syntaxhighlight>
</lang>
 
Fortran 90
<langsyntaxhighlight lang="fortran">
program spam
implicit none
Line 962 ⟶ 1,058:
end do
end program spam
</syntaxhighlight>
</lang>
 
=={{header|Fortress}}==
<langsyntaxhighlight lang="fortress">
component loops_infinite
export Executable
Line 972 ⟶ 1,068:
end
end
</syntaxhighlight>
</lang>
 
=={{header|FreeBASIC}}==
<langsyntaxhighlight lang="freebasic">' FB 1.05.0
 
Do
Print "SPAM"
Loop</langsyntaxhighlight>
 
=={{header|Frink}}==
<langsyntaxhighlight lang="frink">
while true
println["SPAM"]
</syntaxhighlight>
</lang>
 
=={{header|FutureBasic}}==
Loop de loop -- whose great idea was this?
<langsyntaxhighlight lang="futurebasic">include "NSLog.incl"
 
dispatchglobal
Line 997 ⟶ 1,093:
dispatchend
 
HandleEvents</langsyntaxhighlight>
 
=={{header|Gambas}}==
'''[https://gambas-playground.proko.eu/?gist=e63dcdc939f8a7dcfd3194d884f8d4a5 Click this link to run this code]'''
<langsyntaxhighlight lang="gambas">Public Sub Main()
 
Do
Line 1,007 ⟶ 1,103:
Loop
 
End</langsyntaxhighlight>
 
=={{header|GAP}}==
<langsyntaxhighlight lang="gap">while true do
Print("SPAM\n");
od;</langsyntaxhighlight>
 
=={{header|GB BASIC}}==
<langsyntaxhighlight GBlang="gb BASICbasic">10 print "SPAM"
20 goto10</langsyntaxhighlight>
 
=={{header|GDScript}}==
{{works with|Godot|4.0.1}}
 
<syntaxhighlight lang="gdscript">
extends MainLoop
 
 
func _process(_delta: float) -> bool:
print("SPAM")
return false # _process loops until true is returned
 
</syntaxhighlight>
 
=={{header|GlovePIE}}==
GlovePIE does not natively support multiple lines of output. As such, this code continuously changes the single line of output to SPAM. The below code does this without specifying an infinite loop because all GlovePIE scripts loop indefinitely until the program is stopped.
<langsyntaxhighlight GlovePIElang="glovepie">debug = "SPAM"</langsyntaxhighlight>
 
=={{header|GML}}==
<langsyntaxhighlight GMLlang="gml">while(1)
show_message("SPAM")</langsyntaxhighlight>
 
=={{header|Go}}==
<langsyntaxhighlight lang="go">package main
 
import "fmt"
Line 1,035 ⟶ 1,144:
fmt.Printf("SPAM\n")
}
}</langsyntaxhighlight>
 
=={{header|Groovy}}==
<langsyntaxhighlight lang="groovy">while (true) {
println 'SPAM'
}</langsyntaxhighlight>
 
=={{header|Halon}}==
<langsyntaxhighlight lang="halon">forever {
echo "SPAM";
}</langsyntaxhighlight>
or (due to optimizations, these are equally fast)
<langsyntaxhighlight lang="halon">while (true) {
echo "SPAM";
}</langsyntaxhighlight>
 
=={{header|Hare}}==
<syntaxhighlight lang="hare">use fmt;
 
export fn main() void = {
for (true) {
fmt::println("SPAM")!;
};
};</syntaxhighlight>
 
=={{header|Haskell}}==
<langsyntaxhighlight lang="haskell">forever (putStrLn "SPAM")</langsyntaxhighlight>
or
<langsyntaxhighlight lang="haskell">import Control.Monad.Fix (fix)
fix (putStrLn "SPAM" >>) </langsyntaxhighlight>
 
=={{header|Haxe}}==
<langsyntaxhighlight lang="haxe">while (true)
Sys.println("SPAM");</langsyntaxhighlight>
 
=={{header|hexiscript}}==
<langsyntaxhighlight lang="hexiscript">while true; println "SPAM"; endwhile</langsyntaxhighlight>
 
=={{header|HicEst}}==
<langsyntaxhighlight lang="hicest">DO i = 1, 1E20 ! for i with 16 or more digits: i == i + 1 == loop infinite
WRITE() "SPAM"
ENDDO</langsyntaxhighlight>
 
=={{header|HolyC}}==
<langsyntaxhighlight lang="holyc">while(1) Print("SPAM\n");</langsyntaxhighlight>
 
=={{header|Icon}} and {{header|Unicon}}==
There are several ways to write infinite loops in Icon. The most straightforward would be with repeat.
<langsyntaxhighlight lang="icon">procedure main()
repeat write("SPAM")
end</langsyntaxhighlight>
 
Alternately one could use one of these:
<langsyntaxhighlight lang="icon">until &fail do write("SPAM") # always fails, needs succeed to break
...
while write("SPAM") # always succeeds, needs failure to break
Line 1,087 ⟶ 1,205:
while write(|"SPAM") # this is a common mistake that results in an endless loop
...
while write(1 to 5) # a clearer version of the same mistake that generates endless 1's</langsyntaxhighlight>
 
=={{header|IDL}}==
<syntaxhighlight lang IDL="idl">while 1 do print,'SPAM'</langsyntaxhighlight>
 
=={{header|Intercal}}==
Assuming Turing Text I/O with 8-bit ASCII-compatible character set, using COME FROM:
 
<langsyntaxhighlight lang="intercal"> NOTE THIS IS INTERCAL
PLEASE ,1 <- #5
DO ,1 SUB #1 <- #54
Line 1,105 ⟶ 1,223:
DO READ OUT ,1
(2) DO ,1 SUB #1 <- #134
(1) PLEASE ABSTAIN FROM (2)</langsyntaxhighlight>
 
=={{header|Io}}==
<langsyntaxhighlight lang="io">loop("SPAM" println)</langsyntaxhighlight>
 
=={{header|J}}==
 
<syntaxhighlight lang ="j">(-[smoutput bind ]F.(echo@'SPAM')^:_(1)0</langsyntaxhighlight>
 
Alternatively,
 
<langsyntaxhighlight lang="j">smoutput bind 'SPAM'^:1e99 ''</langsyntaxhighlight>
 
This second implementation relies on numeric inaccuracies in IEEE floating point notation.
Line 1,123 ⟶ 1,241:
 
=={{header|Java}}==
<syntaxhighlight lang ="java">while (true) {
while (true) System.out.printlnprint("SPAM\n");
</syntaxhighlight>
}</lang>
 
<syntaxhighlight lang ="java">for (;;) {
for (;;) System.out.printlnprint("SPAM\n");
</syntaxhighlight>
}</lang>
 
=={{header|JavaScript}}==
<langsyntaxhighlight lang="javascript">for (;;) console.log("SPAM");</langsyntaxhighlight>
<langsyntaxhighlight lang="javascript">while (true) console.log("SPAM");</langsyntaxhighlight>
 
=={{header|Joy}}==
<langsyntaxhighlight lang="joy">DEFINE loop == [true []] dip while.
["SPAM\n" putchars] loop.</syntaxhighlight>
 
["SPAM\n" putchars] loop.</lang>
 
=={{header|jq}}==
<langsyntaxhighlight lang="jq">recurse("SPAM")</langsyntaxhighlight>
{{Out}}
"SPAM"
Line 1,150 ⟶ 1,267:
 
=={{header|Jsish}}==
<langsyntaxhighlight lang="javascript">for (;;) puts('SPAM');</langsyntaxhighlight>
 
=={{header|Julia}}==
<syntaxhighlight lang="julia">
<lang Julia>
while true
println("SPAM")
end
</syntaxhighlight>
</lang>
{{out}}
<pre>
Line 1,171 ⟶ 1,288:
 
=={{header|K}}==
<langsyntaxhighlight Klang="k"> while[1; `0:"SPAM\n"]</langsyntaxhighlight>
 
=={{header|Kotlin}}==
<langsyntaxhighlight lang="scala">// version 1.0.6
 
fun main(args: Array<String>) {
while (true) println("SPAM")
}</langsyntaxhighlight>
 
=={{header|LabVIEW}}==
Line 1,184 ⟶ 1,301:
 
=={{header|Lambdatalk}}==
<langsyntaxhighlight lang="scheme">
{def loops_infinite
{lambda {}
Line 1,192 ⟶ 1,309:
{loops_infinite}
-> SPAM forever...
</syntaxhighlight>
</lang>
 
=={{header|Lang}}==
<syntaxhighlight lang="lang">
loop {
fn.println(SPAM)
}
</syntaxhighlight>
 
=={{header|Lang5}}==
<langsyntaxhighlight lang="lang5">do "SPAM\n" . loop</langsyntaxhighlight>
 
=={{header|Lasso}}==
<langsyntaxhighlight Lassolang="lasso">// not wise to run this!
while(1 > 0) => {^
'SPAM\r'
^}</langsyntaxhighlight>
 
=={{header|LDPL}}==
<syntaxhighlight lang="ldpl">procedure:
label spam
display "SPAM" lf
goto spam
</syntaxhighlight>
 
=={{header|Liberty BASIC}}==
<CTRL><Break> is used to terminate such loops.
<syntaxhighlight lang="lb">
<lang lb>
while 1
print "SPAM"
wend
end
</syntaxhighlight>
</lang>
 
=={{header|Lily}}==
<langsyntaxhighlight lang="lily">
while 1: print("SPAM")
</syntaxhighlight>
</lang>
 
=={{header|Lingo}}==
<langsyntaxhighlight lang="lingo">repeat while TRUE
put "SPAM"
end repeat</langsyntaxhighlight>
 
=={{header|Lisaac}}==
Line 1,228 ⟶ 1,359:
 
=={{header|LiveCode}}==
<langsyntaxhighlight LiveCodelang="livecode">repeat forever
put "SPAM" & return
end repeat</langsyntaxhighlight>
 
=={{header|Logo}}==
<langsyntaxhighlight lang="logo">forever [print "SPAM]</langsyntaxhighlight>
 
=={{header|LOLCODE}}==
<langsyntaxhighlight lang="lolcode">HAI
CAN HAS STDIO?
IM IN YR LOOP
VISIBLE "SPAM"
IM OUTTA YR LOOP
KTHXBYE</langsyntaxhighlight>
 
=={{header|Lua}}==
<langsyntaxhighlight lang="lua">
while true do
print("SPAM")
Line 1,253 ⟶ 1,384:
print("SPAM")
until false
</syntaxhighlight>
</lang>
 
=={{header|M2000 Interpreter}}==
Line 1,259 ⟶ 1,390:
If Esc works then Ctrl + Y (and other letters except C, A, Z, X, N, M. F, L), open Control form, which we can do: Next Step, Slow Flow, Stop, and we can show code,current stack, variables, or execute immediate statements. This works only in console, not in M2000 forms.
 
<syntaxhighlight lang="m2000 interpreter">
<lang M2000 Interpreter>
Module CheckIt {
Print "SPAM"
Line 1,265 ⟶ 1,396:
}
Checkit
</syntaxhighlight>
</lang>
Using a Repeat (or Do) - Always block
<syntaxhighlight lang="m2000 interpreter">
<lang M2000 Interpreter>
Module CheckIt {
Repeat {
Line 1,274 ⟶ 1,405:
}
Checkit
</syntaxhighlight>
</lang>
 
Printing text rendering using Report.
<syntaxhighlight lang="m2000 interpreter">
<lang M2000 Interpreter>
Module CheckIt {
\\ stop in every 2/3 of cosole lines
Line 1,288 ⟶ 1,419:
Report {SPAM
}
</syntaxhighlight>
</lang>
 
=={{header|M4}}==
<langsyntaxhighlight M4lang="m4">define(`spam',`SPAM
spam')
spam</langsyntaxhighlight>
 
=={{header|MACRO11}}==
<syntaxhighlight lang="MACRO11">
; Infinte Loop under RT11
.MCALL .PRINT
.EVEN
BEGIN:
LOOP:
.PRINT #SPAM
BR LOOP
SPAM: .ASCIZ /SPAM/
.END BEGIN
</syntaxhighlight>
 
 
=={{header|MAD}}==
<syntaxhighlight lang="mad"> VECTOR VALUES SPAM = $4HSPAM*$
LOOP PRINT FORMAT SPAM
TRANSFER TO LOOP
END OF PROGRAM</syntaxhighlight>
 
=={{header|Make}}==
<langsyntaxhighlight lang="make">spam:
@echo SPAM
$(MAKE)</langsyntaxhighlight>
 
 
=={{header|Malbolge}}==
<langsyntaxhighlight lang="malbolge">
bP&A@?>=<;:9876543210/.-,+*)('&%$T"!~}|;]yxwvutslUSRQ.yx+i)J9edFb4`_^]\yxwRQ)(TSRQ]m!G0KJIyxFvDa%_@?"=<5:98765.-2+*/.-,+*)('&%$#"!~}|utyrqvutsrqjonmPkjihgfedc\DDYAA\>>Y;;V886L5322G//D,,G))>&&A##!7~5:{y7xvuu,10/.-,+*)('&%$#"yb}|{zyxwvutmVqSohmOOjihafeHcEa`YAA\[ZYRW:U7SLKP3NMLK-I,GFED&%%@?>=6;|9y70/4u210/o-n+k)"!gg$#"!x}`{zyxZvYtsrqSoRmlkjLhKfedcEaD_^]\>Z=XWVU7S6QPON0LKDI,GFEDCBA#?"=};438y6543s1r/o-&%*k('&%e#d!~}|^z]xwvuWsVqponPlOjihgIeHcba`B^A\[ZY;W:UTSR4PI2MLKJ,,AFE(&B;:?"~<}{zz165v3s+*/pn,mk)jh&ge#db~a_{^\xwvoXsrqpRnmfkjMKg`_GG\aDB^A?[><X;9U86R53ONM0KJC,+FEDC&A@?!!6||3876w4-tr*/.-&+*)('&%$e"!~}|utyxwvutWlkponmlOjchg`edGba`_XW\?ZYRQVOT7RQPINML/JIHAFEDC&A@?>!<;{98yw5.-ss*/pn,+lj(!~ff{"ca}`^z][wZXtWUqTRnQOkNLhgfIdcFaZ_^A\[Z<XW:U8SRQPOHML/JIHG*ED=%%:?>=~;:{876w43210/(-,+*)('h%$d"ca}|_z\rqYYnsVTpoRPledLLafIGcbE`BXW??TY<:V97S64P31M0.J-+G*(DCB%@?"=<;|98765.3210p.-n+$)i'h%${"!~}|{zyxwvuXVlkpSQmlOjLbafIGcbE`BXW??TY<:V97S64P31M0.J-+G*(D'%A@?"=<}:98y6543,1r/.o,+*)j'&%eez!~a|^tsx[YutWUqjinQOkjMhJ`_dGEaDB^A?[><X;9U86R53O20LKJ-HG*ED'BA@?>7~;:{y7x5.3210q.-n+*)jh&%$#"c~}`{z]rwvutWrkpohmPkjihafI^cba`_^A\[>YXW:UTS5QP3NM0KJ-HGF?D'BA:?>=~;:z8765v32s0/.-nl$#(ig%fd"ca}|_]yrqvYWsVTpSQmPNjMKgJHdGEa`_B]\?ZY<WVUTMR5PO20LK.IHA))>CB%#?87}}49zx6wu3tr0qo-nl*ki'hf$ec!~}`{^yxwvotsrUponQlkMihKIe^]EEZ_B@\?=Y<:V97S64P31M0.J-+GFE(C&A@?8=<;:{876w43s10qo-&%kk"'hf$ec!b`|_]y\ZvYWsVTpSQmlkNiLgf_dcba`C^]\?ZY;WV97SLK33HM0.J-+G*(D'%A$">!};|z8yw543t1r/(-,+*)(i&%fd"!~}|_t]xwvutslqTonmPkjLhKIeHFbEC_^A?[TSX;9UT7R4JIN1/K.,H+)E(&B%#?"~<}{987x/4ussr).o,+l)(h&ge#db~a_{^\x[YutWrTjinQOkNLhgJeG]\aDB^]@[=SRW:877LQP3N0FEJ-+**?DC&A#98=~|:98yx/4u21rp(',mk)(ig%|{"ca}`^z][wZXtWUqTRnQOkNLhKIedcFE`YB@@?ZYRW:UTS6QPO11F..CHGF)(CB;@#>!~;XzV7gwu-QrrqMoJIkZF'WC$#AbQ`_{^L9wI64"VDConzl+j);JJ%qGFEZ~}]{ygwRuc8aSq44"H1Y.iV,e*RQ
</syntaxhighlight>
</lang>
 
=={{header|Maple}}==
<syntaxhighlight lang="maple">
<lang Maple>
> do print(SPAM) end;
</syntaxhighlight>
</lang>
 
=={{header|Mathematica}} / {{header|Wolfram Language}}==
<langsyntaxhighlight lang="mathematica">While[True,
Print@"SPAM";
]</langsyntaxhighlight>
 
=={{header|MATLAB}} / {{header|Octave}}==
<langsyntaxhighlight Matlablang="matlab">while true
fprintf('SPAM\n')
end</langsyntaxhighlight>
 
=={{header|Maxima}}==
<langsyntaxhighlight lang="maxima">do(disp("SPAM"));</langsyntaxhighlight>
 
=={{header|MAXScript}}==
<langsyntaxhighlight lang="maxscript">while true do print "SPAM\n"</langsyntaxhighlight>
 
=={{header|MelonBasic}}==
Using <code>Goto:1</code>:
<langsyntaxhighlight MelonBasiclang="melonbasic">Say:"SPAM"
Goto:1</langsyntaxhighlight>
 
Using <code>Goto:start</code>:
<langsyntaxhighlight MelonBasiclang="melonbasic">Say:"SPAM"
Goto:start</langsyntaxhighlight>
 
=={{header|Metafont}}==
 
<langsyntaxhighlight lang="metafont">forever: message "SPAM"; endfor end</langsyntaxhighlight>
 
=={{header|Microsoft Small Basic}}==
With <code>While</code>.
<langsyntaxhighlight lang="microsoftsmallbasic">
While "True"
TextWindow.WriteLine("SPAM")
EndWhile
</syntaxhighlight>
</lang>
With <code>Goto</code>.
<langsyntaxhighlight lang="microsoftsmallbasic">
loopStart:
TextWindow.WriteLine("SPAM")
Goto loopStart
</syntaxhighlight>
</lang>
 
=={{header|min}}==
{{works with|min|0.19.3}}
<langsyntaxhighlight lang="min">(true) ("SPAM" puts!) while</langsyntaxhighlight>
 
=={{header|MIPS Assembly}}==
Thanks to [https://www.chibialiens.com/mips/ Chibialiens.com] for the header/footer, bitmap font, and print routines.
<langsyntaxhighlight lang="mips">.include "\SrcAll\Header.asm"
.include "\SrcAll\BasicMacros.asm"
.include "\SrcPSX\MemoryMap.asm"
Line 1,392 ⟶ 1,542:
.include "..\\SrcAll\monitor.asm"
.include "\SrcN64\Footer.asm"</langsyntaxhighlight>
{{out}}
[https://ibb.co/rpH9bVR Screenshot of Nintendo 64 emulator]
 
=={{header|МК-61/52}}==
<syntaxhighlight lang="text">1 2 3 4 С/П БП 00</langsyntaxhighlight>
 
''Note'': because this device has no text output instead of "SPAM" was used the number (1234).
 
=={{header|Modula-2}}==
<langsyntaxhighlight lang="modula2">LOOP
InOut.WriteString ("SPAM");
InOut.WriteLn
END;</langsyntaxhighlight>
 
=={{header|Modula-3}}==
<langsyntaxhighlight lang="modula3">LOOP
IO.Put("SPAM\n");
END;</langsyntaxhighlight>
 
=={{header|Monte}}==
 
<syntaxhighlight lang="monte">
<lang Monte>
while (true):
traceln("SPAM")
</syntaxhighlight>
</lang>
 
=={{header|MontiLang}}==
<langsyntaxhighlight MontiLanglang="montilang">WHILE TRUE
|SPAM| PRINT .
ENDWHILE</langsyntaxhighlight>
Note that <code>TRUE</code> is simply a variable equal to 1. <code>WHILE 1</code>, any number larger than 0 or any string with a length more than 0 would also work
 
=={{header|MOO}}==
<langsyntaxhighlight lang="moo">while (1)
player:tell("SPAM");
endwhile</langsyntaxhighlight>
 
=={{header|MUMPS}}==
<syntaxhighlight lang="mumps">
<lang MUMPS>
FOR WRITE "SPAM",!
</syntaxhighlight>
</lang>
 
=={{header|Nanoquery}}==
<langsyntaxhighlight Nanoquerylang="nanoquery">while true
println "SPAM"
end</langsyntaxhighlight>
 
=={{header|Nemerle}}==
<langsyntaxhighlight Nemerlelang="nemerle">while (true) WriteLine("SPAM");</langsyntaxhighlight>
Or, using recursion:
<langsyntaxhighlight Nemerlelang="nemerle">def loop() : void
{
WriteLine("SPAM");
loop();
}</langsyntaxhighlight>
 
=={{header|NetRexx}}==
<langsyntaxhighlight NetRexxlang="netrexx">/* NetRexx */
options replace format comments java crossref savelog symbols nobinary
 
Line 1,459 ⟶ 1,609:
say 'SPAM'
end spam
</syntaxhighlight>
</lang>
 
=={{header|NewLISP}}==
<langsyntaxhighlight NewLISPlang="newlisp">(while (println "SPAM"))</langsyntaxhighlight>
 
=={{header|Nim}}==
<langsyntaxhighlight lang="nim">while true:
echo "SPAM"</langsyntaxhighlight>
 
=={{header|NS-HUBASIC}}==
Using <code>FOR</code>:
<langsyntaxhighlight NSlang="ns-HUBASIChubasic">10 FOR I=0 TO 1 STEP 0
20 PRINT "SPAM"
30 NEXT</langsyntaxhighlight>
 
Using <code>GOTO</code>:
<langsyntaxhighlight NSlang="ns-HUBASIChubasic">10 PRINT "SPAM"
20 GOTO 10</langsyntaxhighlight>
 
Using <code>RUN</code>:
<langsyntaxhighlight NSlang="ns-HUBASIChubasic">10 PRINT "SPAM"
20 RUN</langsyntaxhighlight>
 
=={{header|Nu}}==
<syntaxhighlight lang="nu">
while true {print SPAM}
</syntaxhighlight>
 
=={{header|Oberon-2}}==
<langsyntaxhighlight lang="oberon2">
MODULE InfiniteLoop;
IMPORT
Line 1,492 ⟶ 1,647:
END
END InfiniteLoop.
</syntaxhighlight>
</lang>
 
=={{header|Objeck}}==
<langsyntaxhighlight lang="objeck">
while(true) {
"SPAM"->PrintLine();
};
</syntaxhighlight>
</lang>
 
=={{header|OCaml}}==
<langsyntaxhighlight lang="ocaml">while true do
print_endline "SPAM"
done</langsyntaxhighlight>
 
or
 
<langsyntaxhighlight lang="ocaml">let rec inf_loop() =
print_endline "SPAM";
inf_loop()
in
inf_loop()</langsyntaxhighlight>
 
Seen like this it looks like the "too much functional" danger when a "while" loop looks far simpler, but the functional loop may be useful to provide data to the next loop without using mutable variable.
 
=={{header|Occam}}==
<langsyntaxhighlight lang="occam">#USE "course.lib"
PROC main (CHAN BYTE screen!)
WHILE TRUE
out.string("SPAM*c*n", 0, screen)
:</langsyntaxhighlight>
 
=={{header|Octave}}==
<langsyntaxhighlight lang="octave">while(1)
disp("SPAM")
endwhile</langsyntaxhighlight>
 
=={{header|Oforth}}==
 
<langsyntaxhighlight Oforthlang="oforth">begin "SPAM" . again</langsyntaxhighlight>
 
=={{header|Ol}}==
<langsyntaxhighlight lang="scheme">
(let loop ()
(display "SPAM")
(loop))
</syntaxhighlight>
</lang>
 
=={{header|OPL}}==
<langsyntaxhighlight lang="opl">PROC main:
LOCAL loop%
loop%=1
Line 1,546 ⟶ 1,701:
PRINT "SPAM"
ENDWH
ENDP</langsyntaxhighlight>
 
=={{header|Oz}}==
<langsyntaxhighlight lang="oz">for do
{Show 'SPAM'}
end</langsyntaxhighlight>
 
=={{header|PARI/GP}}==
<langsyntaxhighlight lang="parigp">while(1,
print("SPAM")
);</langsyntaxhighlight>
 
For a shorter version, note that <code>print</code> returns <code>gnil</code> which is evaluated as <code>false</code>.
A 'cheating' solution might use <code>print(SPAM)</code> on the hope that the variable SPAM is uninitialized and hence prints as the monomial in itself.
But with the <code>'</code> operator that evaluation can be forced, regardless of the current value (if any) of that variable:
<syntaxhighlight lang ="parigp">until(print('SPAM),)</langsyntaxhighlight>
 
=={{header|Pascal}}==
<langsyntaxhighlight lang="pascal">while true do
writeln('SPAM');</langsyntaxhighlight>
Alternatively:
<langsyntaxhighlight lang="pascal">repeat
writeln('SPAM')
until false;</langsyntaxhighlight>
 
=={{header|Perl}}==
<langsyntaxhighlight lang="perl">while(1){
print "SPAM\n";
}</langsyntaxhighlight>
 
or equivalently
 
<langsyntaxhighlight lang="perl">print "SPAM\n" while 1;</langsyntaxhighlight>
 
=={{header|Phix}}==
<!--<langsyntaxhighlight Phixlang="phix">-->
<span style="color: #008080;">while</span> <span style="color: #004600;">true</span> <span style="color: #008080;">do</span>
<span style="color: #7060A8;">puts</span><span style="color: #0000FF;">(</span><span style="color: #000000;">1</span><span style="color: #0000FF;">,</span><span style="color: #008000;">"SPAM\n"</span><span style="color: #0000FF;">)</span>
<span style="color: #008080;">end</span> <span style="color: #008080;">while</span>
<!--</langsyntaxhighlight>-->
 
=={{header|Phixmonti}}==
<syntaxhighlight lang="Phixmonti">/# Rosetta Code problem: https://rosettacode.org/w/index.php?title=Loops/Infinite
by Galileo, 11/2022 #/
 
true while "SPAM\n" print true endwhile</syntaxhighlight>
 
=={{header|PHP}}==
<langsyntaxhighlight lang="php">while(1)
echo "SPAM\n";</langsyntaxhighlight>
 
=={{header|PicoLisp}}==
<langsyntaxhighlight PicoLisplang="picolisp">(loop (prinl "SPAM"))</langsyntaxhighlight>
 
=={{header|Pike}}==
<langsyntaxhighlight lang="pike">
while(1)
write("SPAM\n");
</syntaxhighlight>
</lang>
 
=={{header|PILOT}}==
<langsyntaxhighlight lang="pilot">*TypeSpam
type:SPAM
jump:*TypeSpam</langsyntaxhighlight>
 
=={{header|Pixilang}}==
<langsyntaxhighlight Pixilanglang="pixilang">start:
fputs("SPAM\n")
go start</langsyntaxhighlight>
 
=={{header|PL/I}}==
<syntaxhighlight lang="pl/i">
<lang PL/I>
do forever;
put list ('SPAM'); put skip;
end;</langsyntaxhighlight>
 
=={{header|PL/M}}==
<syntaxhighlight lang="PL/M">
100H:
BDOS: PROCEDURE (FN, ARG); DECLARE FN BYTE, ARG ADDRESS; GO TO 5; END BDOS;
EXIT: PROCEDURE; CALL BDOS(0,0); END EXIT;
PRINT: PROCEDURE (S); DECLARE S ADDRESS; CALL BDOS(9,S); END PRINT;
 
DECLARE SPAM DATA ('SPAM',0DH,0AH,'$');
 
LOOP: DO;
 
CALL PRINT( .SPAM );
GO TO LOOP;
 
END;
EOF
</syntaxhighlight>
 
=={{header|Plain English}}==
When <code>Repeat.</code> appears by itself, execution proceeds from the beginning of the routine. Normally you would include a conditional statement to break or exit when a condition is met, but not in this case.
<langsyntaxhighlight lang="plainenglish">To run:
Start up.
Write SPAM forever.
Line 1,625 ⟶ 1,804:
To write SPAM forever:
Write "SPAM" to the console.
Repeat.</langsyntaxhighlight>
 
=={{header|plainTeX}}==
Compile in console mode, with, e.g. "pdftex <file name>".
<langsyntaxhighlight lang="tex">\newlinechar`\^^J
\def\spam{\message{SPAM^^J}\spam}%
\spam</langsyntaxhighlight>
 
=={{header|Pop11}}==
<langsyntaxhighlight lang="pop11">while true do
printf('SPAM', '%p\n');
endwhile;</langsyntaxhighlight>
 
=={{header|PostScript}}==
simple infinite loop:
<syntaxhighlight lang ="postscript">{}loop</langsyntaxhighlight>
 
A bit more complex infinite loop:
<langsyntaxhighlight lang="postscript">/go {
/spam
{ (SPAM\n) print flush }
Line 1,653 ⟶ 1,832:
 
%start spamming!
go</langsyntaxhighlight>
 
=={{header|PowerShell}}==
<langsyntaxhighlight lang="powershell">for () {
"SPAM"
}</langsyntaxhighlight>
 
=={{header|Prolog}}==
<langsyntaxhighlight lang="prolog">repeat, write('SPAM'), nl, fail.</langsyntaxhighlight>
 
=={{header|Pure Data}}==
Line 1,667 ⟶ 1,846:
Screenshot: https://i.imgur.com/IrwaafZ.png
 
<langsyntaxhighlight Purelang="pure Datadata">#N canvas 426 88 450 300 10;
#X obj 17 75 print;
#X msg 17 55 SPAM;
Line 1,674 ⟶ 1,853:
#X connect 1 0 0 0;
#X connect 2 0 1 0;
#X connect 3 0 2 0;</langsyntaxhighlight>
 
Notes: the loop is started by clicking the |1(, a [loadbang] could additionally be used. An [until] object, sent a bang, will loop forever, but will hang Pure Data, whereas a high-speed metro will function perfectly.
Line 1,680 ⟶ 1,859:
=={{header|PureBasic}}==
===Repeat/Forever===
<langsyntaxhighlight PureBasiclang="purebasic">Repeat
PrintN("SPAM")
ForEver</langsyntaxhighlight>
 
===Goto===
<langsyntaxhighlight PureBasiclang="purebasic">PrintIt:
PrintN("SPAM")
Goto PrintIt</langsyntaxhighlight>
 
=={{header|Python}}==
In Python 2:
<langsyntaxhighlight lang="python">while 1:
print "SPAM"</langsyntaxhighlight>
 
In python 3:
<langsyntaxhighlight lang="python">while 1:
print("SPAM")</langsyntaxhighlight>
 
Note: one can also use: "True" or any other non-false value.
Line 1,705 ⟶ 1,884:
=={{header|Quackery}}==
 
<langsyntaxhighlight Quackerylang="quackery">[ say "SPAM" cr again ]</langsyntaxhighlight>
 
=={{header|R}}==
Line 1,711 ⟶ 1,890:
To see this run either run in terminal mode, right click on the GUI window and deselect "Buffered Output" prior to execution, or add a call to flush.console() in the loop.
 
<langsyntaxhighlight Rlang="r">repeat print("SPAM")</langsyntaxhighlight>
 
=={{header|Racket}}==
 
<langsyntaxhighlight lang="racket">
#lang racket
 
Line 1,728 ⟶ 1,907:
(for ([i (in-naturals)])
(displayln "SPAM"))
</syntaxhighlight>
</lang>
 
=={{header|Raku}}==
Line 1,734 ⟶ 1,913:
{{works with|Rakudo Star|2010.08}}
 
<syntaxhighlight lang="raku" perl6line>loop {
say 'SPAM';
}</langsyntaxhighlight>
In addition, there are various ways of writing lazy, infinite lists in Raku:
<syntaxhighlight lang="raku" perl6line>print "SPAM\n" xx *; # repetition operator
print "SPAM\n", ~* ... *; # sequence operator
map {say "SPAM"}, ^Inf; # upto operator</langsyntaxhighlight>
 
=={{header|Rapira}}==
<langsyntaxhighlight Rapiralang="rapira">while 1 do
output: "SPAM"
od</langsyntaxhighlight>
 
=={{header|RATFOR}}==
<syntaxhighlight lang="RATFOR">
program loop
 
while (1==1)
write(*,101)"SPAM"
101 format(A)
 
end
</syntaxhighlight>
 
=={{header|REBOL}}==
<langsyntaxhighlight REBOLlang="rebol">forever [print "SPAM"]</langsyntaxhighlight>
 
=={{header|Red}}==
<langsyntaxhighlight Redlang="red">forever [
print "SPAM"
]</langsyntaxhighlight>
 
=={{header|ReScript}}==
<langsyntaxhighlight ReScriptlang="rescript">while true {
Js.log("SPAM")
}</langsyntaxhighlight>
 
or
 
<langsyntaxhighlight ReScriptlang="rescript">let rec inf_loop = () => {
Js.log("SPAM")
inf_loop()
}</langsyntaxhighlight>
 
=={{header|Retro}}==
<langsyntaxhighlight Retrolang="retro">[ "SPAM\n" puts -1 ] while</langsyntaxhighlight>
 
=={{header|REXX}}==
===simple===
<langsyntaxhighlight lang="rexx">/*REXX program displays the word SPAM forever. */
 
do forever
Line 1,778 ⟶ 1,968:
end /*DO forever*/
/*control will never reach here. */
/*don't stick a fork in it. */</langsyntaxhighlight>
 
===esoteric===
<langsyntaxhighlight lang="rexx">/*REXX program displays the word SPAM forever. */
 
do while 1==1 /*esoteric "forever" clause. */
Line 1,787 ⟶ 1,977:
end /*DO while 1==1*/
/*control will never reach here. */
/*don't stick a fork in it. */</langsyntaxhighlight>
 
===GO TO version===
<langsyntaxhighlight lang="rexx">/*REXX program displays the word SPAM forever. */
 
tell_it: say 'SPAM'
Line 1,796 ⟶ 1,986:
 
/*control will never reach here. */
/*don't stick a fork in it. */</langsyntaxhighlight>
===too clever by half===
<langsyntaxhighlight lang="rexx">/*REXX program displays the word SPAM forever. */
 
do until 0>1 /*too-clever-by-half forever loop*/
Line 1,804 ⟶ 1,994:
end /*DO until 0>1*/
/*control will never reach here. */
/*don't stick a fork in it. */</langsyntaxhighlight>
 
=={{header|Ring}}==
<langsyntaxhighlight lang="ring">
while true
see "Spam"
end
</syntaxhighlight>
</lang>
 
=={{header|Robotic}}==
This will display the word '''SPAM''' at the bottom of the screen indefinitely:
<langsyntaxhighlight lang="robotic">
: "infinite_loop"
* "SPAM"
goto "infinite_loop"
</syntaxhighlight>
</lang>
 
=={{header|RPL}}==
Usually in RPL, "printing" an object in RPL means putting it on top of the stack.
In the present case, the loop would not be infinite since sooner or later the stack will overflow.
But if the printer has an infinite paper roll, this will never stop:
≪ "SPAM" '''WHILE''' 1 '''REPEAT''' PR1 '''END''' ≫ EVAL
 
=={{header|Ruby}}==
<langsyntaxhighlight lang="ruby">loop {puts "SPAM"}
</syntaxhighlight>
</lang>
 
=={{header|Run BASIC}}==
<langsyntaxhighlight lang="runbasic">[loop] print "Spam" :goto [loop]
 
while 1
print "Spam"
wend</langsyntaxhighlight>
 
=={{header|Rust}}==
<langsyntaxhighlight lang="rust">fn main() {
loop {
println!("SPAM");
}
}</langsyntaxhighlight>
 
=={{header|S-lang}}==
<langsyntaxhighlight Slang="s-lang">forever print("SPAM");</langsyntaxhighlight>
 
=={{header|Salmon}}==
<langsyntaxhighlight Salmonlang="salmon">while (true)
"SPAM"!;</langsyntaxhighlight>
 
=={{header|Sather}}==
<langsyntaxhighlight lang="sather">class MAIN is
main is
loop
Line 1,853 ⟶ 2,049:
end;
end;
end;</langsyntaxhighlight>
 
=={{header|Scala}}==
<langsyntaxhighlight lang="scala">while (true)
println("SPAM")</langsyntaxhighlight>
 
=={{header|Scheme}}==
<langsyntaxhighlight lang="scheme">((lambda (x) (display "SPAM") (newline) (x x))
(lambda (x) (display "SPAM") (newline) (x x)))
</syntaxhighlight>
</lang>
 
or, less Schemishly but with less redundancy:
 
<langsyntaxhighlight lang="scheme">(do () (#f) (display "SPAM") (newline))</langsyntaxhighlight>
 
=={{header|Scilab}}==
{{works with|Scilab|5.5.1}}
<syntaxhighlight lang="text">while %T
printf("SPAM\n")
end</langsyntaxhighlight>
{{out}}
<pre>SPAM
Line 1,881 ⟶ 2,077:
 
=={{header|sed}}==
<langsyntaxhighlight lang="sed">:loop
s/.*/SPAM/
p
t loop</langsyntaxhighlight>
Sed requires at least one line of input to execute, so run as follows:
<pre>echo | sed ':loop;s/.*/SPAM/;p;t loop'</pre>
 
=={{header|Seed7}}==
<langsyntaxhighlight lang="seed7">$ include "seed7_05.s7i";
 
const proc: main is func
Line 1,896 ⟶ 2,092:
writeln("SPAM");
end while;
end func;</langsyntaxhighlight>
 
=={{header|Self}}==
<syntaxhighlight lang ="self">['SPAM' printLine] loop</langsyntaxhighlight>
 
=={{header|Sidef}}==
<langsyntaxhighlight lang="ruby">loop { say "SPAM!" };</langsyntaxhighlight>
 
=={{header|Slate}}==
<syntaxhighlight lang ="slate">[inform: 'SPAM'] loop</langsyntaxhighlight>
 
=={{header|Smalltalk}}==
<langsyntaxhighlight lang="smalltalk">[
Transcript showCR:'boring stuff'.
] loop
Line 1,922 ⟶ 2,118:
[
Transcript showCR:'please press CTRL-c!'.
] doWhile:[true]</langsyntaxhighlight>
 
=={{header|SNOBOL4}}==
<langsyntaxhighlight lang="snobol">loop output = "SPAM" :(loop)
end</langsyntaxhighlight>
 
=={{header|SNUSP}}==
<langsyntaxhighlight lang="snusp">@\>@\>@\>@\>++++++++++===!/ < < < < \
| | | \M=@@@@+@+++++# \.>.>.>.>./
| | \A=@@+@@@@+++#
| \P=@@+@@+@@+++#
\S=@@+@+@@@+++#</langsyntaxhighlight>
 
=={{header|Sparkling}}==
<langsyntaxhighlight lang="sparkling">while true {
print("SPAM");
}</langsyntaxhighlight>
 
or
 
<langsyntaxhighlight lang="sparkling">do {
print("SPAM");
} while true;</langsyntaxhighlight>
 
or
 
<langsyntaxhighlight lang="sparkling">for var b = true; b; b = true {
printf("SPAM\n");
}</langsyntaxhighlight>
 
etc.
Line 1,959 ⟶ 2,155:
{{works with|HomeSpun}}
{{works with|OpenSpin}}
<langsyntaxhighlight lang="spin">con
_clkmode = xtal1 + pll16x
_clkfreq = 80_000_000
Line 1,974 ⟶ 2,170:
waitcnt(_clkfreq + cnt)
ser.stop
cogstop(0)</langsyntaxhighlight>
 
=={{header|SPL}}==
<langsyntaxhighlight lang="spl">>
#.output("SPAM")
<</langsyntaxhighlight>
 
=={{header|SQL PL}}==
{{works with|Db2 LUW}} version 9.7 or higher.
With SQL PL:
<langsyntaxhighlight lang="sql pl">
--#SET TERMINATOR @
 
Line 1,995 ⟶ 2,191:
END WHILE;
END @
</syntaxhighlight>
</lang>
Output:
<pre>
Line 2,017 ⟶ 2,213:
 
=={{header|Standard ML}}==
<langsyntaxhighlight lang="sml">while true do
print "SPAM\n";</langsyntaxhighlight>
 
or
 
<langsyntaxhighlight lang="sml">let
fun inf_loop () = (
print "SPAM\n";
Line 2,029 ⟶ 2,225:
in
inf_loop ()
end</langsyntaxhighlight>
 
Seen like this it looks like the "too much functional" danger when a "while" loop looks far simpler, but the functional loop may be useful to provide data to the next loop without using mutable variable.
Line 2,035 ⟶ 2,231:
=={{header|Stata}}==
 
<langsyntaxhighlight lang="stata">while 1 {
display "SPAM"
}</langsyntaxhighlight>
 
=== Mata ===
<langsyntaxhighlight lang="stata">while (1) printf("SPAM\n")</langsyntaxhighlight>
 
Also possible with a '''[https://www.stata.com/help.cgi?m2_for for]''' loop, but unlike C, the middle expression is not optional:
 
<langsyntaxhighlight lang="stata">for (;1;) printf("SPAM\n")</langsyntaxhighlight>
 
=={{header|Swift}}==
<langsyntaxhighlight lang="swift">while true {
println("SPAM")
}</langsyntaxhighlight>
 
=={{header|SystemVerilog}}==
 
<langsyntaxhighlight SystemVeriloglang="systemverilog">program main;
initial forever $display("SPAM");
endprogram
</syntaxhighlight>
</lang>
=={{header|TailDot}}==
 
<syntaxhighlight lang="taildot">c,x,SPAM,v,x,j,3</syntaxhighlight>
=={{header|Tailspin}}==
<langsyntaxhighlight lang="tailspin">
1'SPAM$#10;' -> \(
<> 'SPAM$#10;' -> !OUT::write
1$ -> #
\) -> !VOID
</syntaxhighlight>
</lang>
 
=={{header|Tcl}}==
<langsyntaxhighlight lang="tcl">while true {
puts SPAM
}
Line 2,073 ⟶ 2,270:
for {} 1 {} {
puts SPAM
}</langsyntaxhighlight>
 
=={{header|TI-83 BASIC}}==
Line 2,079 ⟶ 2,276:
There are a few ways to achieve this in TI-83 BASIC
 
<langsyntaxhighlight lang="ti83b">
:Lbl 1
:Disp "SPAM
:Goto 1
</syntaxhighlight>
</lang>
 
Another way is by using a While loop
 
<langsyntaxhighlight lang="ti83b">
:While 1
:Disp "SPAM
:End
</syntaxhighlight>
</lang>
 
=={{header|TI-89 BASIC}}==
 
<langsyntaxhighlight lang="ti89b">Loop
Disp "SPAM"
EndLoop</langsyntaxhighlight>
 
=={{header|TorqueScript}}==
<langsyntaxhighlight Torquelang="torque">While(1)
echo("SPAM");</langsyntaxhighlight>
 
=={{header|Transact-SQL}}==
 
<langsyntaxhighlight lang="sql">WHILE 1=1 BEGIN
PRINT "SPAM"
END</langsyntaxhighlight>
 
=={{header|Trith}}==
<langsyntaxhighlight lang="trith">["SPAM" print] loop</langsyntaxhighlight>
 
=={{header|TUSCRIPT}}==
TUSCRIPT has no infinite loop. 999999999 loops are the limit.
<langsyntaxhighlight lang="tuscript">
$$ MODE TUSCRIPT
LOOP/999999999
print "spam"
ENDLOOP
</syntaxhighlight>
</lang>
 
=={{header|UNIX Shell}}==
Line 2,125 ⟶ 2,322:
 
Use any of these loops:
<langsyntaxhighlight lang="bash">while :; do echo SPAM; done</langsyntaxhighlight>
 
<langsyntaxhighlight lang="bash">while true; do echo "SPAM"; done</langsyntaxhighlight>
 
<langsyntaxhighlight lang="bash">until false; do echo "SPAM"; done</langsyntaxhighlight>
 
{{works with|bash}}
Line 2,135 ⟶ 2,332:
{{works with|zsh}}
 
<langsyntaxhighlight lang="bash">for ((;;)); do echo "SPAM"; done</langsyntaxhighlight>
 
==={{header|C Shell}}===
<langsyntaxhighlight lang="bash">while (1)
echo SPAM
end</langsyntaxhighlight>
 
==={{header|es}}===
<syntaxhighlight lang ="es">forever {echo SPAM}</langsyntaxhighlight>
 
=={{header|UnixPipes}}==
<syntaxhighlight lang ="bash">yes SPAM</langsyntaxhighlight>
 
=={{header|Unlambda}}==
<langsyntaxhighlight lang="unlambda"> ``ci``s``s`kr``s``s``s``s`k.S`k.P`k.A`k.Mii</langsyntaxhighlight>
 
=={{header|Ursa}}==
{{trans|Python}}
<langsyntaxhighlight lang="ursa">while true
out "SPAM" endl console
end while</langsyntaxhighlight>
=={{header|Uxntal}}==
<syntaxhighlight lang="Uxntal">
|0100
&l ;SPAM <print-str> !&l
 
@<print-str> ( str* -- )
&while ( -- )
LDAk #18 DEO
INC2 LDAk ?&while
POP2 JMP2r
 
@SPAM
"SPAM 0a $1</syntaxhighlight>
 
=={{header|V}}==
<langsyntaxhighlight lang="v">true [
'SPAM' puts
] while</langsyntaxhighlight>
 
=={{header|Vala}}==
<langsyntaxhighlight lang="vala">for(;;) stdout.printf("SPAM\n");</langsyntaxhighlight>
<langsyntaxhighlight lang="vala">while(true) stdout.printf("SPAM\n");</langsyntaxhighlight>
<langsyntaxhighlight lang="vala">do stdout.printf("SPAM\n"); while(true);</langsyntaxhighlight>
 
=={{header|Vale}}==
{{works with|Vale|0.2.0}}
<syntaxhighlight lang="vale">
import stdlib.*;
 
exported func main() {
while true {
println("SPAM");
}
}
</syntaxhighlight>
 
=={{header|VAX Assembly}}==
<langsyntaxhighlight VAXlang="vax Assemblyassembly"> 0000 0000 1 .entry main,0
4D415053 8F DD 0002 2 pushl #^a"SPAM" ;string on stack
5E DD 0008 3 pushl sp ;reference to string
Line 2,177 ⟶ 2,399:
F5 11 0015 8 brb loop ;forever
0017 9
0017 10 .end main</langsyntaxhighlight>
 
=={{header|VBA}}==
<langsyntaxhighlight lang="vb">Do
Debug.Print "SPAM"
Loop</langsyntaxhighlight>
 
=={{header|VBScript}}==
<langsyntaxhighlight lang="vb">Do
WScript.Echo("SPAM")
Loop</langsyntaxhighlight>
 
=={{header|Vedit macro language}}==
<langsyntaxhighlight lang="vedit">while (1) {
Message("Spam\n")
}</langsyntaxhighlight>
or:
<langsyntaxhighlight lang="vedit">do {
Message("Spam\n")
} while (1)</langsyntaxhighlight>
or:
<langsyntaxhighlight lang="vedit">for (;1;) {
Message("Spam\n")
}</langsyntaxhighlight>
"Nearly infinite" loop can be done by using constant ALL (=1073741824) as repeat count:
<langsyntaxhighlight lang="vedit">Repeat (ALL) {
Message("Spam\n")
}</langsyntaxhighlight>
 
=={{header|Visual Basic}}==
<langsyntaxhighlight lang="vb">Do
Debug.Print("SPAM")
Loop</langsyntaxhighlight>
 
=={{header|Visual Basic .NET}}==
'''Platform:''' [[.NET]]
{{works with|Visual Basic .NET|9.0+}}
<langsyntaxhighlight lang="vbnet">Do
Console.WriteLine("SPAM")
Loop</langsyntaxhighlight>
 
=={{header|V (Vlang)}}==
<syntaxhighlight lang="v (vlang)">fn main() {
for {
print("SPAM\n")
}
}</langsyntaxhighlight>
 
=={{header|Wart}}==
<langsyntaxhighlight lang="wart">repeat :forever
prn "spam"</langsyntaxhighlight>
 
=={{header|Wee Basic}}==
<langsyntaxhighlight Weelang="wee Basicbasic">let loop=1
while loop=1
print 1 "SPAM"
wend
end</langsyntaxhighlight>
 
 
=={{header|Whenever}}==
<langsyntaxhighlight lang="whenever">
1 print("SPAM");
1;
</syntaxhighlight>
</lang>
 
 
=={{header|Wren}}==
<langsyntaxhighlight ecmascriptlang="wren">while (true) System.print("SPAM")</langsyntaxhighlight>
 
=={{header|X86 Assembly}}==
{{works with|NASM|Linux}}
<langsyntaxhighlight lang="asm">
section .text
global _start
Line 2,264 ⟶ 2,486:
msg db "SPAM",0xa
len equ $-msg
</syntaxhighlight>
</lang>
 
=={{header|XLISP}}==
It is of course possible to use a <code>WHILE</code> loop with a condition that will always evaluate to true:
<langsyntaxhighlight lang="lisp">(defun keep-printing-spam ()
(while t
(display "SPAM")
(newline) ) )</langsyntaxhighlight>
Although this idiom is very common (in many programming languages), however, it feels a bit like a misuse of a looping construct that is meant to be conditional. If an unconditional jump is really what we want, then that is what we have <tt>goto</tt> for; or rather, in XLISP we do not have <tt>goto</tt> (in so many words) but we can achieve the effect of it using tail recursion.
<langsyntaxhighlight lang="lisp">(defun keep-printing-spam ()
(display "SPAM")
(newline)
(keep-printing-spam) )</langsyntaxhighlight>
 
=={{header|XPL0}}==
<langsyntaxhighlight XPL0lang="xpl0">code Text=12;
loop Text(0, "SPAM
")</langsyntaxhighlight>
 
=={{header|Z80 Assembly}}==
Line 2,287 ⟶ 2,509:
Using the Amstrad CPC firmware:
 
<langsyntaxhighlight lang="z80">org $4000
 
txt_output: equ $bb5a
Line 2,300 ⟶ 2,522:
jr print
 
spam: defm "SPAM\r\n\0"</langsyntaxhighlight>
 
=={{header|Zig}}==
<syntaxhighlight lang="zig">
<lang Zig>
const std = @import("std");
pub fn main() !void {
Line 2,309 ⟶ 2,531:
while (true) try stdout_wr.writeAll("SPAM\n");
}
</syntaxhighlight>
</lang>
=={{header|zkl}}==
<langsyntaxhighlight lang="zkl">while(1) { println("SPAM") }
while(True){ println("SPAM") }
foreach _ in ([0..]){ println("SPAM") }
[0..].pump(Console.println,T(Void,"SPAM"));
[0..].pump(fcn{ println("SPAM") });
fcn{ println("SPAM"); return(self.fcn()) }(); // tail recursive lambda</langsyntaxhighlight>
 
{{omit from|GUISS}}
Line 2,322 ⟶ 2,544:
=={{header|Zoomscript}}==
For typing:
<langsyntaxhighlight Zoomscriptlang="zoomscript">var loop
loop = 1
while ne loop 0
print "SPAM"
println
endwhile</langsyntaxhighlight>
For importing: