forked from mtuomi/SecondReality
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDOLINE.BBK
executable file
·119 lines (113 loc) · 2.01 KB
/
DOLINE.BBK
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// create code for line blitter
#include <stdio.h>
#include <string.h>
char *vram=(char *)0xa0000000L;
FILE *out;
int isor;
void line(int x1,int y1,int x2,int y2)
{
int xd=x2-x1;
int yd=y2-y1;
int a,d,c,x,y;
memset(vram,0,16*320);
if(xd>yd)
{
d=-xd/2;
while(x1<x2 || y1<y2)
{
vram[x1+y1*320]=2;
x1++;
d+=yd;
if(d>0)
{
d-=xd;
y1++;
}
}
}
else
{
d=-yd/2;
while(x1<x2 || y1<y2)
{
vram[x1+y1*320]=2;
y1++;
d+=xd;
if(d>0)
{
d-=yd;
x1++;
}
}
}
//vram[x2+y2*320]=1;
fprintf(out,"lblt_%ia%i:\n",x2,y2);
c=0;
for(y=0;y<16;y++) for(x=0;x<16;x++) if(vram[x+y*320])
{
if(c==1) fprintf(out,"lblt_%ib%i:\n",x2,y2);
if(vram[x+y*320+1])
{
fprintf(out,"mov ax,gs:[di+%i]\n",x+y*320);
if(isor) fprintf(out,"or ax,dx\n");
else fprintf(out,"xor ax,dx\n");
fprintf(out,"mov gs:[di+%i],ax\n",x+y*320);
fprintf(out,"mov es:[di+%i],ax\n",x+y*320);
vram[x+y*320]=vram[x+y*320+1]=0;
}
else
{
fprintf(out,"mov al,gs:[di+%i]\n",x+y*320);
if(isor) fprintf(out,"or al,dl\n");
else fprintf(out,"xor al,dl\n");
fprintf(out,"mov gs:[di+%i],al\n",x+y*320);
fprintf(out,"mov es:[di+%i],al\n",x+y*320);
vram[x+y*320]=0;
}
c++;
}
if(c<=1) fprintf(out,"lblt_%ib%i:\n",x2,y2);
}
main()
{
int x,y;
_asm mov ax,13h
_asm int 10h
out=fopen("lineblit.inc","wt");
fprintf(out,";LineBlitter core - created by doline.c\n");
fprintf(out,"lblt_table LABEL WORD\n");
for(isor=0;isor>=0;isor--)
{
for(y=0;y<12;y++)
{
for(x=0;x<12;x++)
{
fprintf(out,"dw OFFSET lblt_%i%a%i\n",x,y);
}
}
}
for(isor=0;isor>=0;isor--)
{
for(y=0;y<12;y++)
{
for(x=0;x<12;x++)
{
fprintf(out,"dw OFFSET lblt_%i%b%i\n",x,y);
}
}
}
for(isor=0;isor>=0;isor--)
{
for(y=0;y<12;y++)
{
for(x=0;x<12;x++)
{
line(0,0,x,y);
fprintf(out,"ret\n",x,y);
}
}
}
fclose(out);
_asm mov ax,3h
_asm int 10h
}