123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674 |
- .386P
- .model FLAT
- externdef _d_zistepu:dword
- externdef _d_pzbuffer:dword
- externdef _d_zistepv:dword
- externdef _d_zrowbytes:dword
- externdef _d_ziorigin:dword
- externdef _r_turb_s:dword
- externdef _r_turb_t:dword
- externdef _r_turb_pdest:dword
- externdef _r_turb_spancount:dword
- externdef _r_turb_turb:dword
- externdef _r_turb_pbase:dword
- externdef _r_turb_sstep:dword
- externdef _r_turb_tstep:dword
- externdef _r_bmodelactive:dword
- externdef _d_sdivzstepu:dword
- externdef _d_tdivzstepu:dword
- externdef _d_sdivzstepv:dword
- externdef _d_tdivzstepv:dword
- externdef _d_sdivzorigin:dword
- externdef _d_tdivzorigin:dword
- externdef _sadjust:dword
- externdef _tadjust:dword
- externdef _bbextents:dword
- externdef _bbextentt:dword
- externdef _cacheblock:dword
- externdef _d_viewbuffer:dword
- externdef _cachewidth:dword
- externdef _d_pzbuffer:dword
- externdef _d_zrowbytes:dword
- externdef _d_zwidth:dword
- externdef _d_scantable:dword
- externdef _r_lightptr:dword
- externdef _r_numvblocks:dword
- externdef _prowdestbase:dword
- externdef _pbasesource:dword
- externdef _r_lightwidth:dword
- externdef _lightright:dword
- externdef _lightrightstep:dword
- externdef _lightdeltastep:dword
- externdef _lightdelta:dword
- externdef _lightright:dword
- externdef _lightdelta:dword
- externdef _sourcetstep:dword
- externdef _surfrowbytes:dword
- externdef _lightrightstep:dword
- externdef _lightdeltastep:dword
- externdef _r_sourcemax:dword
- externdef _r_stepback:dword
- externdef _colormap:dword
- externdef _blocksize:dword
- externdef _sourcesstep:dword
- externdef _lightleft:dword
- externdef _blockdivshift:dword
- externdef _blockdivmask:dword
- externdef _lightleftstep:dword
- externdef _r_origin:dword
- externdef _r_ppn:dword
- externdef _r_pup:dword
- externdef _r_pright:dword
- externdef _ycenter:dword
- externdef _xcenter:dword
- externdef _d_vrectbottom_particle:dword
- externdef _d_vrectright_particle:dword
- externdef _d_vrecty:dword
- externdef _d_vrectx:dword
- externdef _d_pix_shift:dword
- externdef _d_pix_min:dword
- externdef _d_pix_max:dword
- externdef _d_y_aspect_shift:dword
- externdef _screenwidth:dword
- externdef _vright:dword
- externdef _vup:dword
- externdef _vpn:dword
- externdef _BOPS_Error:dword
- externdef _snd_scaletable:dword
- externdef _paintbuffer:dword
- externdef _snd_linear_count:dword
- externdef _snd_p:dword
- externdef _snd_vol:dword
- externdef _snd_out:dword
- externdef _r_leftclipped:dword
- externdef _r_leftenter:dword
- externdef _r_rightclipped:dword
- externdef _r_rightenter:dword
- externdef _modelorg:dword
- externdef _xscale:dword
- externdef _r_refdef:dword
- externdef _yscale:dword
- externdef _r_leftexit:dword
- externdef _r_rightexit:dword
- externdef _r_lastvertvalid:dword
- externdef _cacheoffset:dword
- externdef _newedges:dword
- externdef _removeedges:dword
- externdef _r_pedge:dword
- externdef _r_framecount:dword
- externdef _r_u1:dword
- externdef _r_emitted:dword
- externdef _edge_p:dword
- externdef _surface_p:dword
- externdef _surfaces:dword
- externdef _r_lzi1:dword
- externdef _r_v1:dword
- externdef _r_ceilv1:dword
- externdef _r_nearzi:dword
- externdef _r_nearzionly:dword
- externdef _edge_aftertail:dword
- externdef _edge_tail:dword
- externdef _current_iv:dword
- externdef _edge_head_u_shift20:dword
- externdef _span_p:dword
- externdef _edge_head:dword
- externdef _fv:dword
- externdef _edge_tail_u_shift20:dword
- externdef _r_apverts:dword
- externdef _r_anumverts:dword
- externdef _aliastransform:dword
- externdef _r_avertexnormals:dword
- externdef _r_plightvec:dword
- externdef _r_ambientlight:dword
- externdef _r_shadelight:dword
- externdef _aliasxcenter:dword
- externdef _aliasycenter:dword
- externdef _a_sstepxfrac:dword
- externdef _r_affinetridesc:dword
- externdef _acolormap:dword
- externdef _d_pcolormap:dword
- externdef _r_affinetridesc:dword
- externdef _d_sfrac:dword
- externdef _d_ptex:dword
- externdef _d_pedgespanpackage:dword
- externdef _d_tfrac:dword
- externdef _d_light:dword
- externdef _d_zi:dword
- externdef _d_pdest:dword
- externdef _d_pz:dword
- externdef _d_aspancount:dword
- externdef _erroradjustup:dword
- externdef _errorterm:dword
- externdef _d_xdenom:dword
- externdef _r_p0:dword
- externdef _r_p1:dword
- externdef _r_p2:dword
- externdef _a_tstepxfrac:dword
- externdef _r_sstepx:dword
- externdef _r_tstepx:dword
- externdef _a_ststepxwhole:dword
- externdef _zspantable:dword
- externdef _skintable:dword
- externdef _r_zistepx:dword
- externdef _erroradjustdown:dword
- externdef _d_countextrastep:dword
- externdef _ubasestep:dword
- externdef _a_ststepxwhole:dword
- externdef _a_tstepxfrac:dword
- externdef _r_lstepx:dword
- externdef _a_spans:dword
- externdef _erroradjustdown:dword
- externdef _d_pdestextrastep:dword
- externdef _d_pzextrastep:dword
- externdef _d_sfracextrastep:dword
- externdef _d_ptexextrastep:dword
- externdef _d_countextrastep:dword
- externdef _d_tfracextrastep:dword
- externdef _d_lightextrastep:dword
- externdef _d_ziextrastep:dword
- externdef _d_pdestbasestep:dword
- externdef _d_pzbasestep:dword
- externdef _d_sfracbasestep:dword
- externdef _d_ptexbasestep:dword
- externdef _ubasestep:dword
- externdef _d_tfracbasestep:dword
- externdef _d_lightbasestep:dword
- externdef _d_zibasestep:dword
- externdef _zspantable:dword
- externdef _r_lstepy:dword
- externdef _r_sstepy:dword
- externdef _r_tstepy:dword
- externdef _r_zistepy:dword
- externdef _D_PolysetSetEdgeTable:dword
- externdef _D_RasterizeAliasPolySmooth:dword
- externdef float_point5:dword
- externdef Float2ToThe31nd:dword
- externdef izistep:dword
- externdef izi:dword
- externdef FloatMinus2ToThe31nd:dword
- externdef float_1:dword
- externdef float_particle_z_clip:dword
- externdef float_minus_1:dword
- externdef float_0:dword
- externdef fp_16:dword
- externdef fp_64k:dword
- externdef fp_1m:dword
- externdef fp_1m_minus_1:dword
- externdef fp_8:dword
- externdef entryvec_table:dword
- externdef advancetable:dword
- externdef sstep:dword
- externdef tstep:dword
- externdef pspantemp:dword
- externdef counttemp:dword
- externdef jumptemp:dword
- externdef reciprocal_table:dword
- externdef DP_Count:dword
- externdef DP_u:dword
- externdef DP_v:dword
- externdef DP_32768:dword
- externdef DP_Color:dword
- externdef DP_Pix:dword
- externdef DP_EntryTable:dword
- externdef pbase:dword
- externdef s:dword
- externdef t:dword
- externdef sfracf:dword
- externdef tfracf:dword
- externdef snext:dword
- externdef tnext:dword
- externdef spancountminus1:dword
- externdef zi16stepu:dword
- externdef sdivz16stepu:dword
- externdef tdivz16stepu:dword
- externdef zi8stepu:dword
- externdef sdivz8stepu:dword
- externdef tdivz8stepu:dword
- externdef reciprocal_table_16:dword
- externdef entryvec_table_16:dword
- externdef ceil_cw:dword
- externdef single_cw:dword
- externdef fp_64kx64k:dword
- externdef pz:dword
- externdef spr8entryvec_table:dword
- _DATA SEGMENT
- Ld0 dd 0.0
- Ld1 dd 0.0
- Lstack dd 0
- Lfp_near_clip dd 0.01
- Lceilv0 dd 0
- Lv dd 0
- Lu0 dd 0
- Lv0 dd 0
- Lzi0 dd 0
- _DATA ENDS
- _TEXT SEGMENT
- align 4
- public _R_ClipEdge
- _R_ClipEdge:
- push esi
- push edi
- push ebx
- mov ds:dword ptr[Lstack],esp
- mov ebx,ds:dword ptr[12+12+esp]
- mov esi,ds:dword ptr[4+12+esp]
- mov edx,ds:dword ptr[8+12+esp]
- test ebx,ebx
- jz Lemit
- Lcliploop:
- fld ds:dword ptr[0+0+esi]
- fmul ds:dword ptr[0+0+ebx]
- fld ds:dword ptr[0+4+esi]
- fmul ds:dword ptr[0+4+ebx]
- fld ds:dword ptr[0+8+esi]
- fmul ds:dword ptr[0+8+ebx]
- fxch st(1)
- faddp st(2),st(0)
- fld ds:dword ptr[0+0+edx]
- fmul ds:dword ptr[0+0+ebx]
- fld ds:dword ptr[0+4+edx]
- fmul ds:dword ptr[0+4+ebx]
- fld ds:dword ptr[0+8+edx]
- fmul ds:dword ptr[0+8+ebx]
- fxch st(1)
- faddp st(2),st(0)
- fxch st(3)
- faddp st(2),st(0)
- faddp st(2),st(0)
- fsub ds:dword ptr[12+ebx]
- fxch st(1)
- fsub ds:dword ptr[12+ebx]
- fxch st(1)
- fstp ds:dword ptr[Ld0]
- fstp ds:dword ptr[Ld1]
- mov eax,ds:dword ptr[Ld0]
- mov ecx,ds:dword ptr[Ld1]
- or ecx,eax
- js Lp2
- Lcontinue:
- mov ebx,ds:dword ptr[16+ebx]
- test ebx,ebx
- jnz Lcliploop
- Lemit:
- fldcw ds:word ptr[ceil_cw]
- cmp ds:dword ptr[_r_lastvertvalid],0
- jz LCalcFirst
- mov eax,ds:dword ptr[_r_lzi1]
- mov ecx,ds:dword ptr[_r_u1]
- mov ds:dword ptr[Lzi0],eax
- mov ds:dword ptr[Lu0],ecx
- mov ecx,ds:dword ptr[_r_v1]
- mov eax,ds:dword ptr[_r_ceilv1]
- mov ds:dword ptr[Lv0],ecx
- mov ds:dword ptr[Lceilv0],eax
- jmp LCalcSecond
- LCalcFirst:
- call near ptr LTransformAndProject
- fst ds:dword ptr[Lv0]
- fxch st(2)
- fstp ds:dword ptr[Lu0]
- fstp ds:dword ptr[Lzi0]
- fistp ds:dword ptr[Lceilv0]
- LCalcSecond:
- mov esi,edx
- call near ptr LTransformAndProject
- fld ds:dword ptr[Lu0]
- fxch st(3)
- fld ds:dword ptr[Lzi0]
- fxch st(3)
- fld ds:dword ptr[Lv0]
- fxch st(3)
- fist ds:dword ptr[_r_ceilv1]
- fldcw ds:word ptr[single_cw]
- fst ds:dword ptr[_r_v1]
- fxch st(4)
- fcom st(1)
- fnstsw ax
- test ah,1
- jz LP0
- fstp st(0)
- fld st(0)
- LP0:
- fxch st(1)
- fstp ds:dword ptr[_r_lzi1]
- fxch st(1)
- fst ds:dword ptr[_r_u1]
- fxch st(1)
- fcom ds:dword ptr[_r_nearzi]
- fnstsw ax
- test ah,045h
- jnz LP1
- fst ds:dword ptr[_r_nearzi]
- LP1:
- mov eax,ds:dword ptr[_r_nearzionly]
- test eax,eax
- jz LP2
- LPop5AndDone:
- mov eax,ds:dword ptr[_cacheoffset]
- mov edx,ds:dword ptr[_r_framecount]
- cmp eax,07FFFFFFFh
- jz LDoPop
- and edx,07FFFFFFFh
- or edx,080000000h
- mov ds:dword ptr[_cacheoffset],edx
- LDoPop:
- fstp st(0)
- fstp st(0)
- fstp st(0)
- fstp st(0)
- fstp st(0)
- jmp Ldone
- LP2:
- mov ebx,ds:dword ptr[Lceilv0]
- mov edi,ds:dword ptr[_edge_p]
- mov ecx,ds:dword ptr[_r_ceilv1]
- mov edx,edi
- mov esi,ds:dword ptr[_r_pedge]
- add edx,32
- cmp ebx,ecx
- jz LPop5AndDone
- mov eax,ds:dword ptr[_r_pedge]
- mov ds:dword ptr[28+edi],eax
- fstp ds:dword ptr[24+edi]
- jc LSide0
- LSide1:
- fsubp st(3),st(0)
- fsub st(0),st(1)
- fdivp st(2),st(0)
- mov ds:dword ptr[_r_emitted],1
- mov ds:dword ptr[_edge_p],edx
- mov eax,ds:dword ptr[edx]
- mov eax,ecx
- lea ecx,ds:dword ptr[-1+ebx]
- mov ebx,eax
- mov eax,ds:dword ptr[_surface_p]
- mov esi,ds:dword ptr[_surfaces]
- sub edx,edx
- sub eax,esi
- shr eax,6
- mov ds:dword ptr[16+edi],edx
- mov ds:dword ptr[16+2+edi],eax
- sub esi,esi
- mov ds:dword ptr[Lv],ebx
- fild ds:dword ptr[Lv]
- fsubrp st(1),st(0)
- fmul st(0),st(1)
- fadd ds:dword ptr[_r_u1]
- jmp LSideDone
- LSide0:
- fsub st(0),st(3)
- fxch st(2)
- fsub st(0),st(1)
- fdivp st(2),st(0)
- mov ds:dword ptr[_r_emitted],1
- mov ds:dword ptr[_edge_p],edx
- mov eax,ds:dword ptr[edx]
- dec ecx
- mov eax,ds:dword ptr[_surface_p]
- mov esi,ds:dword ptr[_surfaces]
- sub edx,edx
- sub eax,esi
- shr eax,6
- mov ds:dword ptr[16+2+edi],edx
- mov ds:dword ptr[16+edi],eax
- mov esi,1
- mov ds:dword ptr[Lv],ebx
- fild ds:dword ptr[Lv]
- fsubrp st(1),st(0)
- fmul st(0),st(1)
- faddp st(2),st(0)
- fxch st(1)
- LSideDone:
- fmul ds:dword ptr[fp_1m]
- fxch st(1)
- fmul ds:dword ptr[fp_1m]
- fxch st(1)
- fadd ds:dword ptr[fp_1m_minus_1]
- fxch st(1)
- fistp ds:dword ptr[4+edi]
- fistp ds:dword ptr[0+edi]
- mov eax,ds:dword ptr[0+edi]
- mov edx,ds:dword ptr[_r_refdef+76]
- cmp eax,edx
- jl LP4
- mov edx,ds:dword ptr[_r_refdef+80]
- cmp eax,edx
- jng LP5
- LP4:
- mov ds:dword ptr[0+edi],edx
- mov eax,edx
- LP5:
- add eax,esi
- mov esi,ds:dword ptr[_newedges+ebx*4]
- test esi,esi
- jz LDoFirst
- cmp ds:dword ptr[0+esi],eax
- jl LNotFirst
- LDoFirst:
- mov ds:dword ptr[12+edi],esi
- mov ds:dword ptr[_newedges+ebx*4],edi
- jmp LSetRemove
- LNotFirst:
- LFindInsertLoop:
- mov edx,esi
- mov esi,ds:dword ptr[12+esi]
- test esi,esi
- jz LInsertFound
- cmp ds:dword ptr[0+esi],eax
- jl LFindInsertLoop
- LInsertFound:
- mov ds:dword ptr[12+edi],esi
- mov ds:dword ptr[12+edx],edi
- LSetRemove:
- mov eax,ds:dword ptr[_removeedges+ecx*4]
- mov ds:dword ptr[_removeedges+ecx*4],edi
- mov ds:dword ptr[20+edi],eax
- Ldone:
- mov esp,ds:dword ptr[Lstack]
- pop ebx
- pop edi
- pop esi
- ret
- Lp2:
- test eax,eax
- jns Lp1
- mov eax,ds:dword ptr[Ld1]
- test eax,eax
- jns Lp3
- mov eax,ds:dword ptr[_r_leftclipped]
- mov ecx,ds:dword ptr[_r_pedge]
- test eax,eax
- jnz Ldone
- mov eax,ds:dword ptr[_r_framecount]
- and eax,07FFFFFFFh
- or eax,080000000h
- mov ds:dword ptr[_cacheoffset],eax
- jmp Ldone
- Lp1:
- fld ds:dword ptr[Ld0]
- fld ds:dword ptr[Ld1]
- fsubr st(0),st(1)
- mov ds:dword ptr[_cacheoffset],07FFFFFFFh
- fdivp st(1),st(0)
- sub esp,12
- fld ds:dword ptr[0+8+edx]
- fsub ds:dword ptr[0+8+esi]
- fld ds:dword ptr[0+4+edx]
- fsub ds:dword ptr[0+4+esi]
- fld ds:dword ptr[0+0+edx]
- fsub ds:dword ptr[0+0+esi]
- mov edx,esp
- mov eax,ds:dword ptr[20+ebx]
- test al,al
- fmul st(0),st(3)
- fxch st(1)
- fmul st(0),st(3)
- fxch st(2)
- fmulp st(3),st(0)
- fadd ds:dword ptr[0+0+esi]
- fxch st(1)
- fadd ds:dword ptr[0+4+esi]
- fxch st(2)
- fadd ds:dword ptr[0+8+esi]
- fxch st(1)
- fstp ds:dword ptr[0+0+esp]
- fstp ds:dword ptr[0+8+esp]
- fstp ds:dword ptr[0+4+esp]
- jz Ltestright
- mov ds:dword ptr[_r_leftclipped],1
- mov eax,ds:dword ptr[0+0+esp]
- mov ds:dword ptr[_r_leftexit+0+0],eax
- mov eax,ds:dword ptr[0+4+esp]
- mov ds:dword ptr[_r_leftexit+0+4],eax
- mov eax,ds:dword ptr[0+8+esp]
- mov ds:dword ptr[_r_leftexit+0+8],eax
- jmp Lcontinue
- Ltestright:
- test ah,ah
- jz Lcontinue
- mov ds:dword ptr[_r_rightclipped],1
- mov eax,ds:dword ptr[0+0+esp]
- mov ds:dword ptr[_r_rightexit+0+0],eax
- mov eax,ds:dword ptr[0+4+esp]
- mov ds:dword ptr[_r_rightexit+0+4],eax
- mov eax,ds:dword ptr[0+8+esp]
- mov ds:dword ptr[_r_rightexit+0+8],eax
- jmp Lcontinue
- Lp3:
- mov ds:dword ptr[_r_lastvertvalid],0
- fld ds:dword ptr[Ld0]
- fld ds:dword ptr[Ld1]
- fsubr st(0),st(1)
- mov ds:dword ptr[_cacheoffset],07FFFFFFFh
- fdivp st(1),st(0)
- sub esp,12
- fld ds:dword ptr[0+8+edx]
- fsub ds:dword ptr[0+8+esi]
- fld ds:dword ptr[0+4+edx]
- fsub ds:dword ptr[0+4+esi]
- fld ds:dword ptr[0+0+edx]
- fsub ds:dword ptr[0+0+esi]
- mov eax,ds:dword ptr[20+ebx]
- test al,al
- fmul st(0),st(3)
- fxch st(1)
- fmul st(0),st(3)
- fxch st(2)
- fmulp st(3),st(0)
- fadd ds:dword ptr[0+0+esi]
- fxch st(1)
- fadd ds:dword ptr[0+4+esi]
- fxch st(2)
- fadd ds:dword ptr[0+8+esi]
- fxch st(1)
- fstp ds:dword ptr[0+0+esp]
- fstp ds:dword ptr[0+8+esp]
- fstp ds:dword ptr[0+4+esp]
- mov esi,esp
- jz Ltestright2
- mov ds:dword ptr[_r_leftclipped],1
- mov eax,ds:dword ptr[0+0+esp]
- mov ds:dword ptr[_r_leftenter+0+0],eax
- mov eax,ds:dword ptr[0+4+esp]
- mov ds:dword ptr[_r_leftenter+0+4],eax
- mov eax,ds:dword ptr[0+8+esp]
- mov ds:dword ptr[_r_leftenter+0+8],eax
- jmp Lcontinue
- Ltestright2:
- test ah,ah
- jz Lcontinue
- mov ds:dword ptr[_r_rightclipped],1
- mov eax,ds:dword ptr[0+0+esp]
- mov ds:dword ptr[_r_rightenter+0+0],eax
- mov eax,ds:dword ptr[0+4+esp]
- mov ds:dword ptr[_r_rightenter+0+4],eax
- mov eax,ds:dword ptr[0+8+esp]
- mov ds:dword ptr[_r_rightenter+0+8],eax
- jmp Lcontinue
- LTransformAndProject:
- fld ds:dword ptr[0+0+esi]
- fsub ds:dword ptr[_modelorg+0]
- fld ds:dword ptr[0+4+esi]
- fsub ds:dword ptr[_modelorg+4]
- fld ds:dword ptr[0+8+esi]
- fsub ds:dword ptr[_modelorg+8]
- fxch st(2)
- fld st(0)
- fmul ds:dword ptr[_vpn+0]
- fld st(1)
- fmul ds:dword ptr[_vright+0]
- fxch st(2)
- fmul ds:dword ptr[_vup+0]
- fld st(3)
- fmul ds:dword ptr[_vpn+4]
- fld st(4)
- fmul ds:dword ptr[_vright+4]
- fxch st(5)
- fmul ds:dword ptr[_vup+4]
- fxch st(1)
- faddp st(3),st(0)
- fxch st(3)
- faddp st(4),st(0)
- faddp st(2),st(0)
- fld st(3)
- fmul ds:dword ptr[_vpn+8]
- fld st(4)
- fmul ds:dword ptr[_vright+8]
- fxch st(5)
- fmul ds:dword ptr[_vup+8]
- fxch st(1)
- faddp st(2),st(0)
- fxch st(4)
- faddp st(3),st(0)
- fxch st(1)
- faddp st(3),st(0)
- fcom ds:dword ptr[Lfp_near_clip]
- fnstsw ax
- test ah,1
- jz LNoClip
- fstp st(0)
- fld ds:dword ptr[Lfp_near_clip]
- LNoClip:
- fdivr ds:dword ptr[float_1]
- fxch st(1)
- fld ds:dword ptr[_xscale]
- fmul st(0),st(2)
- fmulp st(1),st(0)
- fadd ds:dword ptr[_xcenter]
- fcom ds:dword ptr[_r_refdef+68]
- fnstsw ax
- test ah,1
- jz LClampP0
- fstp st(0)
- fld ds:dword ptr[_r_refdef+68]
- LClampP0:
- fcom ds:dword ptr[_r_refdef+84]
- fnstsw ax
- test ah,045h
- jnz LClampP1
- fstp st(0)
- fld ds:dword ptr[_r_refdef+84]
- LClampP1:
- fld st(1)
- fmul ds:dword ptr[_yscale]
- fmulp st(3),st(0)
- fxch st(2)
- fsubr ds:dword ptr[_ycenter]
- fcom ds:dword ptr[_r_refdef+72]
- fnstsw ax
- test ah,1
- jz LClampP2
- fstp st(0)
- fld ds:dword ptr[_r_refdef+72]
- LClampP2:
- fcom ds:dword ptr[_r_refdef+88]
- fnstsw ax
- test ah,045h
- jnz LClampP3
- fstp st(0)
- fld ds:dword ptr[_r_refdef+88]
- LClampP3:
- ret
- _TEXT ENDS
- END
|