Codice macchina ARM, 18 byte
Dump esadecimale (little endian):
3803 d105 6808 ebc0 2010 b280 f2a0 1001 4770
Questa è una funzione che accetta una lunghezza, una coppia di puntatori per la stringa. L'output è in stile bash, genera 0 per true e un valore diverso da zero per false. In C la funzione verrebbe dichiarata in oneTwoThree (size_t lunghezza, char * stringa). La codifica delle istruzioni è thumb-2, che ha istruzioni a 2 e 4 byte. Testato su un Raspberry Pi 3.
Assemblea non golfata:
.syntax unified
.text
.global oneTwoThree
.thumb_func
oneTwoThree:
@Input: r0 - the number of characters in the string
@r1 - A pointer to the (not necessarily NUL-terminated)
@string representation of the number (char*)
@Output: r1 - 0 if the number is in 123,234,...,789, else non-zero (bash-style)
subs r0,r0,#3
bne end @Return non-zero if r0!=3
ldr r0,[r1] @Remember that this is little endian
@So the first digit is the most siginificant byte
@I.e. if the input was 123 then r0 contains 0xXY010203 where XY is garbage
rsb r0,r0,r0,lsr #8 @r0=(r0>>8)-r0 (rsb is reverse subtract)
uxth r0,r0 @r0&=((1<<16)-1) (mask off top half)
@Now r0 is 0x0101 iff we have a matching number
sub r0,r0,#0x101
@Now r0 is 0 iff the string fit the specification
end:
bx lr @return
Script di test (anche assembly):
.syntax unified
.text
.global main
.thumb_func
main:
push {r4,lr}
ldr r4,[r1,#4] @r0=argv[1]
mov r0,r4
bl strlen
@Now r0 is the length of the string argv[1]
mov r1,r4
bl oneTwoThree @oneTwoThree(strlen(argv[1]),argv[1])
cmp r0,#0
it ne
movne r0,#1 @Output through return code, 1 if false
pop {r4,pc}