;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold скалярный остаток от деления>
if(used inst$sreme) ; <fold returns real>
proc inst$sreme
.L.0000: fprem
fnstsw wsc0
test wsc0, $0400
jnz .L.0000
fstp esc1
ret
end_proc
end if ; </fold>
if(used inst$sremd) ; <fold returns double>
fast inst$sremd
floc operand0, float, \
operand1, float
fenter
vmovdqa xword [.operand1], xmm1
vmovdqa xword [.operand0], xmm0
fld qword [.operand1]
fld qword [.operand0]
.L.0000: fprem
fnstsw wsc0
test wsc0, $0400
jnz .L.0000
fstp esc1
fstp qword [.operand0]
vmovdqa xmm0, [.operand0]
fleave
end if ; </fold>
if(used inst$sremf) ; <fold returns float>
fast inst$sremf
floc operand0, float, \
operand1, float
fenter
vmovdqa xword [.operand1], xmm1
vmovdqa xword [.operand0], xmm0
fld dword [.operand1]
fld dword [.operand0]
.L.0000: fprem
fnstsw wsc0
test wsc0, $0400
jnz .L.0000
fstp esc1
fstp dword [.operand0]
vmovdqa xmm0, [.operand0]
fleave
end if ; </fold>
if(used inst$sremi) ; <fold returns int>
fast inst$sremi
fenter
test dsc1, dsc1
jnz .L.0000
fthrow ArithmeticException
.L.0000: cmp dsc0, -$80000000
jne .L.0001
cmp dsc1, -$00000001
je .L.0002
.L.0001: cdq
idiv dsc1
mov dsc0, dsc2
freturn
.L.0002: xor dsc0, dsc0
fleave
end if ; </fold>
if(used inst$sreml) ; <fold returns long>
fast inst$sreml
fenter
test qsc1, qsc1
jnz .L.0000
fthrow ArithmeticException
.L.0000: cmp qsc0, [cons$long.min]
jne .L.0001
cmp qsc1, [cons$long.m1]
je .L.0002
.L.0001: cqo
idiv qsc1
mov qsc0, qsc2
freturn
.L.0002: xor qsc0, qsc0
fleave
end if ; </fold>
; </fold>