ARM 머신 코드, 18 바이트
16 진 덤프 (little endian) :
3803 d105 6808 ebc0 2010 b280 f2a0 1001 4770
문자열의 길이, 포인터 쌍을 취하는 함수입니다. 출력은 bash 스타일이며, 0은 true이고 0이 아닌 값은 false입니다. C에서 함수는 int oneTwoThree (size_t length, char * string)로 선언됩니다. 명령어 인코딩은 thumb-2이며 2와 4 바이트 명령어가 있습니다. 라즈베리 파이 3에서 테스트되었습니다.
언 골프 조립 :
.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
테스트 스크립트 (또한 어셈블리) :
.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}