Програма емуляції роботи командного процесора операційної системи
Курсовой проект - Компьютеры, программирование
Другие курсовые по предмету Компьютеры, программирование
?вня програмування Асемблера. Використання різних методів та ресурсів програмування дозволило створити невелику за обємом та швидкодіючу програму емуляції роботи командного процесора ОС.
ЛІТЕРАТУРА
1. Баженова І. Ю. Visual C++ 6.0 Уроки програмування. Київ: Фоліо, 1997
2. Б. Керниган, Д. Ричи. Язык программирования С. Москва: Видавництво 1996
3. Белецкий Я. И. Turbo C++. М. : Видавництво Машиностроение 1994.
4. Прокофьев Б. П. Turbo C и Turbo C++. - Москва: СП Ланит, 1992
5. Бъерн Страуструп. Язык программирования С. Москва: Видавництво 1998
6. Джес Либерти. Освой самостоятельно С++ за 21 день. Москва:
Вільямс, 2001
7. Тед Фейсон Borland C. Обьектно ориентированое прорамирование. Москва: SAMS, 1996
8. Зубков С. В. Assembler для DOS, Windows и Unix ., Москва: ДМК, 2005
9. С. Бочков. Д. Субботин. Язык программирования Си для персонального компьютера. М: Радио и связь, 1990
10. Стенли Б. Язык программирования С++. - Москва: SAMS, 2000
11. Страуструп Б.В. Язык программирования С++. - М. : Радио и связь, 1991.
ДОДАТОК А
Лістинг головної програми та команд мовою С++
#pragma option -ms
#include
#include
#include
#include
#include
#define maxarg 10
extern "C" void joinhelp(void);
extern "C" void joinexec(unsigned,char **);
typedef void(* exec)(unsigned ,char **);
typedef void(* help)(void);
struct CLIST{
char* cmdname;
exec execu;
help hlp;
};
unsigned argc;
char* args[maxarg];
unsigned cmdnum,cmd;
void Help(unsigned, char**){
printf("\n\nGladkyj A.V. - 4ok2\nVar. 14\nCom: Ar, Split, Edit, Join\n\n");
}
void arexec(unsigned ,char **argv){
int res;
if(argv[1][0]==a){
res=spawnl(P_WAIT,"rar.exe","","a",argv[2],argv[3],NULL);
if(res!=-1) printf("Done archive creation\n");
}
if(argv[1][0]==e){
res=spawnl(P_WAIT,"rar.exe","","e",argv[2],NULL);
if(res!=-1) printf("Done archive unpacking\n");
}
if(res==-1){
printf("Error executing application\n");
}
}
void arhelp(void){
printf("Usage:\n"
"\tar a arc file - Create an archive\n"
"\tar e arc - Unpack archive\n");
}
#define min(a,b) ((a)<(b))?(a):(b)
#define bufsz 512
void splitexec(unsigned argc,char** args){
FILE *fi,*fo;
char buf[bufsz];
if(argc!=4){
printf("Illegal parameter count\nType \"split /?\" for help\n");
return;
}
fi=fopen(args[1],"rb");
if(!fi){
printf("Fatal error: cannot open source file\n");
return;
}
fseek(fi,0,SEEK_END);
fpos_t fsize=ftell(fi);
if(fsize==0){
printf("Cannot split empty file\n");
fclose(fi);
return;
}
fpos_t sz1=fsize/2, sz2=fsize-sz1;
fseek(fi,0,SEEK_SET);
fo=fopen(args[2],"wb");
if(!fo){
printf("Fatal error: cannot open destantion file\n");
fclose(fi);
return;
}
while(sz1){
fpos_t i;
fpos_t toread;
toread=min(bufsz,sz1);
i=fread(buf,1,toread,fi);
if((i==0)&&(sz1!=0)){
printf("Error reading source file\n");
fclose(fi);
fclose(fo);
return;
}
sz1-=i;
if(fwrite(buf,1,i,fo)!=i){
printf("Error writing destantion file\n");
fclose(fi);
fclose(fo);
return;
}
}
fflush(fo);
fclose(fo);
fo=fopen(args[3],"wb");
if(!fo){
printf("Fatal error: cannot open destantion file\n");
fclose(fi);
return;
}
while(sz2){
fpos_t i;
fpos_t toread;
toread=min(bufsz,sz2);
i=fread(buf,1,toread,fi);
if((i==0)&&(sz2!=0)){
printf("Error reading source file\n");
fclose(fi);
fclose(fo);
return;
}
sz2-=i;
if(fwrite(buf,1,i,fo)!=i){
printf("Error writing destantion file\n");
fclose(fi);
fclose(fo);
}
}
fflush(fo);
fclose(fo);
printf("File %s is splited to files %s and %s.\n", args[1],args[2],args[3]);
}
void splithelp(void){
printf("Usage: split source dest1 dest2\n"
"\tsource Name of source file\n"
"\tdest1, dest2 Names of files to split in\n");
}
void editexec(unsigned argc,char **argv){
if(argc!=2){
printf("Invalid artgument count\n");
return;
}
if(_creat(argv[1],FA_NORMAL)==-1){
printf("Error creating file\n");
}
}
void edithelp(void){
printf("Usage: edit \nCreate file\n");
}
CLIST clist[]={{"",NULL,NULL}, {"exit",NULL,NULL}, {"help",Help,NULL},
{"split",splitexec,splithelp}, {"ar",arexec,arhelp},
{"edit",editexec,edithelp}, {"join",joinexec,joinhelp}};
void main(void){
char cmdline[100];
cmdnum=6;
while(1){
printf("***KOM*** > ");
gets(cmdline);
if(!strlen(cmdline)) continue;
args[0]=strtok(cmdline," ");
argc=1;
while(args[argc]=strtok(NULL," ")) argc++;
cmd=0;
for(int i=1;i<=cmdnum;i++)
if(!strcmpi(args[0],clist[i].cmdname)){
cmd=i;
break;
}
if(cmd==0){
printf("Unknown command\n");
continue;
}
if(cmd==1) return;
if(cmd==2){
clist[2].execu(0,NULL);
continue;
}
if(!strcmp(args[1],"/?")){
clist[cmd].hlp();
continue;
}
clist[cmd].execu(argc,args);
}
}
ДОДАТОК Б
Лістинг команди мовою Assembler
model small
public C joinhelp,C joinexec
.code
help db "Usage: join ",10,13,"Join given 2 files to one",10,13,"$"
errormsg db "Error.",10,13,"$"
joinexec proc
arg argc:word,argv:word ;char**
push bp
mov bp,sp
mov si,argv;Load address of pointers array
mov dx,[si+2];Load address of second argument(argv[1])
mov ah,3ah
int 21h ;rmdir
jnc fin
push ds
push cs
pop ds
mov ah,9
mov dx,offset errormsg
int 21h
transerr:
mov ah,9
mov dx,offset transfermsg
int 21h
mov bx,file1
call fclose ;close src
mov bx,file2
call fclose ;close dst
pop ds
jmp fin
opensrc1err:
push ds
push cs
pop ds
mov ah,9
mov dx,offset erropen1
int 21h
pop ds
jmp fin
opendst2err:
push ds
push cs
pop ds
mov ah,9
mov dx,offset erropen2
int 21h
mov bx,file1
call fclose ;close src
pop ds
jmp fin
fin:pop bp
ret
pop ds
fin:pop bp
ret
joinexec endp
opensrc proc
mov ax,3d00h
mov dx,[si+2];Open src. file argv[1]
int 21h
ret
opensrc endp
fclose proc
mov ah,3eh
int 21h ;Close source
ret
fclose endp
createdst proc
mov ah,3ch
xor cx,cx
mov dx,[si+4];Open dst. file argv[2]
int 21h
ret
createdst endp
joinhelp proc
push ds
push cs
pop ds
mov ah,9
mov dx,offset help
int 21h
pop ds
ret
joinhelp endp
end
ДОДАТОК В
Алгоритм головної програми