cast.real.inc

Переключить прокрутку окна
Загрузить этот исходный код

;
  ; Реализация среды исполнения языка программирования
  ; Объектно-ориентированный продвинутый векторный транслятор
  ;
  ; Copyright © 2021, 2024 Малик Разработчик
  ;
  ; Это свободная программа: вы можете перераспространять ее и/или изменять
  ; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
  ; в каком она была опубликована Фондом свободного программного обеспечения;
  ; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
  ;
  ; Эта программа распространяется в надежде, что она будет полезной,
  ; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
  ; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
  ; общественной лицензии GNU.
  ;
  ; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
  ; вместе с этой программой. Если это не так, см.
  ; <https://www.gnu.org/licenses/>.
;

; <fold приведение значения типа real к другим типам>
    if(used inst$castetoi) ; <fold returns int>
                    fast        inst$castetoi
                    floc        value, int
                    fenter
                    ficom       dword [cons$int.max]
                    fnstsw      wsc0
                    pushfq
                    mov         byte  [rsp+$00], ah
                    popfq
                    jp          .L.0000
                    ja          .L.0001
                    jmp         .L.0002
        .L.0000:    ffree       esc0
                    fincstp
                    xor         dsc0, dsc0
                    jmp         .L.0003
        .L.0001:    ffree       esc0
                    fincstp
                    mov         dsc0, $7fffffff
                    jmp         .L.0003
        .L.0002:    fisttp      dword [.value]
                    mov         dsc0, [.value]
        .L.0003:    fleave
    end if ; </fold>

    if(used inst$castetol) ; <fold returns long>
                    fast        inst$castetol
                    floc        value, long
                    fenter
                    fild        qword [cons$long.max]
                    fcomp
                    fnstsw      wsc0
                    pushfq
                    mov         byte  [rsp+$00], ah
                    popfq
                    jp          .L.0000
                    jbe         .L.0001
                    jmp         .L.0002
        .L.0000:    ffree       esc0
                    fincstp
                    xor         qsc0, qsc0
                    jmp         .L.0003
        .L.0001:    ffree       esc0
                    fincstp
                    mov         qsc0, [cons$long.max]
                    jmp         .L.0003
        .L.0002:    fisttp      qword [.value]
                    mov         qsc0, [.value]
        .L.0003:    fleave
    end if ; </fold>
; </fold>