




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#include <>#include <>#include <>#include <>#include<stack>using namespace std;#define BLKSIZE 512.n");printf("WARNING:ALL DATA ON THIS FILESYSTEM WILL BE LOST!n");printf("Proceed with Format(Y/N)");scanf("%c", &choice); getchar();
2、 if(choice = 'y') | (choice = 'Y') if(fp=fopen(image_name, "w+b") = NULL) printf("Can't create file %sn", image_name); exit(-1); for(i = 0; i < BLKSIZE; i+) fputc('0', fp); = 0; strcpy, "/"); = 'd' strcpy, "/"); = 0; = 0;
3、 0 = -1; 1 = -1; fwrite(&inode, sizeof(Inode), 1, fp); = -1; for(i = 0; i < 31; i+) fwrite(&inode, sizeof(Inode), 1, fp); for(i = 0; i < BLKNUM*BLKSIZE; i+) fputc('0', fp); fclose(fp); n", file_name); printf("This filesystem not exist, it will be create!n"); form
4、at(); login(); while(!feof(fp) fread(&user, sizeof(User), 1, fp); n"); flag = 1; fclose(fp); break; if(flag = 0) break;while(flag);n", image_name); exit(-1);num = -1;n"); exit(-1);bitmapi = '1'if(fp=fopen(image_name, "r+b") = NULL) printf("Can't open fil
5、e %sn", image_name); exit(-1);fseek(fp, i, SEEK_SET);fputc('1', fp);fclose(fp);return i;ength;add0 = inode_arraynum.address0;if(len > 512) add1 = inode_arraynum.address1;if(fp = fopen(image_name, "r+b") = NULL) printf("Can't open file %s.n", image_name); exit(
6、-1);fseek(fp, BLKSIZE+INODESIZE*INODENUM +add0*BLKSIZE, SEEK_SET);ch = fgetc(fp);for(i=0; (i < len) && (ch != '0') && (i < 512); i+) tempi = ch; ch = fgetc(fp);if(i >= 512) fseek(fp,BLKSIZE+INODESIZE*INODENUM+add1*BLKSIZE, SEEK_SET); ch = fgetc(fp); for(; (i < len
7、) && (ch != '0'); i+) tempi = ch; ch = fgetc(fp); tempi = '0'fclose(fp);ddress0;len = inode_arraynum.length;if(fp = fopen(image_name, "r+b") = NULL) printf("Can't open file %s.n", image_name); exit(-1);fseek(fp, BLKSIZE+INODESIZE*INODENUM+add0*BLKSIZE,
8、 SEEK_SET);for(i=0; (i<len)&&(tempi!='0')&&(i < 512); i+) fputc(tempi, fp);if(i = 512) add1 = inode_arraynum.address1; fseek(fp, BLKSIZE+INODESIZE*INODENUM+add1*BLKSIZE, SEEK_SET); for(; (i < len) && (tempi != '0'); i+) fputc(tempi, fp);fputc('0
9、39;, fp);fclose(fp);num = 0) strcpy(path,;else strcpy(path,; m=0; n=inum_cur; while(m != inum_cur) while(inode_arrayn.iparent != m) n = inode_arrayn.iparent; strcat(path,"/"); strcat(path,inode_arrayn.file_name); m = n; n = inum_cur; printf("%s$",path); 或者 cd dir1)void cd(void)in
10、t i;if(argc != 2) printf("Command cd must have two args. n"); return ;if(!strcmp(argv1, ".") inum_cur = inode_arrayinum_cur.iparent;else for(i = 0; i < INODENUM; i+) if(inode_arrayi.inum>0)&& (inode_arrayi.type='d')&& (inode_arrayi.iparent=inum_cur)&
11、amp;& !strcmp(inode_arrayi.file_name,argv1)&& !strcmp(inode_arrayi.user_name,) break; if(i = INODENUM) printf("This directory isn't exsited.n"); else inum_cur = i;n"); return ;num> 0) && (inode_arrayi.iparent = inum_cur)&& !strcmp(inode_arrayi.user_n
12、ame,) if(inode_arrayi.type = 'd') dcount+; printf("%-20s<DIR>n", inode_arrayi.file_name); else fcount+; bcount+=inode_arrayi.length; printf("%-20s%12d bytesn", inode_arrayi.file_name,inode_arrayi.length); printf("n %d file(s)%11d bytesn",fcount,bcount);pri
13、ntf(" %d dir(s) %11d bytes FreeSpacen",dcount,1024*1024-bcount);n");return ;num < 0) break; if(i = INODENUM) printf("Inode is full.n"); exit(-1);inode_arrayi.inum = i;strcpy(inode_arrayi.file_name, argv1);inode_arrayi.type = 'd'strcpy(inode_arrayi.user_name,;inode
14、_arrayi.iparent = inum_cur;inode_arrayi.length = 0;save_inode(i);n"); return ;for(i = 0; i < INODENUM; i+) if(inode_arrayi.inum > 0) && (inode_arrayi.type = 'f') && !strcmp(inode_arrayi.file_name, argv1) printf("This file is exsit.n"); return ; for(i = 0;
15、 i < INODENUM; i+) if(inode_arrayi.inum < 0) break;if(i = INODENUM) printf("Inode is full.n"); exit(-1);inode_arrayi.inum = i;strcpy(inode_arrayi.file_name, argv1);inode_arrayi.type = 'f'strcpy(inode_arrayi.user_name, ;inode_arrayi.iparent = inum_cur;inode_arrayi.length = 0;s
16、ave_inode(i);n"); return ;for(i = 0; i < INODENUM; i+) if(inode_arrayi.inum > 0) && (inode_arrayi.type = 'f') && !strcmp(inode_arrayi.file_name,argv1)&& !strcmp(inode_arrayi.user_name,) break;if(i = INODENUM) printf("The file you want to open doesn'
17、;t exsited.n"); return ;inum = i;printf("Please input open mode:(1: read, 2: write, 3: read and write):");scanf("%d", &mode);getchar();if(mode < 1) | (mode > 3) printf("Open mode is wrong.n"); return;for(i = 0; i < FILENUM; i+) if(file_arrayi.inum <
18、 0) break;if(i = FILENUM) printf("The file table is full, please close some file.n"); return ;filenum = i;file_arrayfilenum.inum = inum; strcpy(file_arrayfilenum.file_name, inode_arrayinum.file_name);file_arrayfilenum.mode = mode; printf("Open file %s by ", file_arrayfilenum.file
19、_name);if(mode = 1) printf("read only.n");else if(mode = 2) printf("write only.n");else printf("read and write.n");n"); return;for(i = 0; i < FILENUM; i+) if(file_arrayi.inum > 0) && !strcmp(file_arrayi.file_name,argv1) break;if(i = FILENUM) printf(&q
20、uot;Open %s first.n", argv1); return ;else if(file_arrayi.mode = 2) printf("Can't read %s.n", argv1); return ;inum = file_arrayi.inum;printf("The length of %s:%d.n", argv1, inode_arrayinum.length);if(inode_arrayinum.length > 0) read_blk(inum); for(i = 0; (i < inode
21、_arrayinum.length) && (tempi != '0'); i+) printf("%c", tempi);n"); return ;for(i = 0; i < FILENUM; i+) if(file_arrayi.inum>0)&& !strcmp(file_arrayi.file_name,argv1) break; if(i = FILENUM) printf("Open %s first.n", argv1); return ;else if(file_ar
22、rayi.mode = 1) printf("Can't write %s.n", argv1); return ;inum = file_arrayi.inum;printf("The length of %s:%dn", inode_arrayinum.file_name, inode_arrayinum.length);if(inode_arrayinum.length = 0) i=0; inode_arrayinum.address0 = get_blknum(); printf("Input the data(CTRL+Z
23、to end):n"); while(i<1023&&(tempi=getchar()!=EOF) i+; tempi='0' length=strlen(temp)+1; inode_arrayinum.length=length; if(length > 512) inode_arrayinum.address1 = get_blknum(); save_inode(inum); write_blk(inum);else printf("This file can't be written.n");n&quo
24、t;); return ;for(i = 0; i < FILENUM; i+) if(file_arrayi.inum > 0) && !strcmp(file_arrayi.file_name, argv1) break;if(i = FILENUM) printf("This file doesn't be opened.n"); return ;else file_arrayi.inum = -1; printf("Close %s success!n", argv1);num = -1;if(inode_ar
25、rayi.length > 0) release_blk(inode_arrayi.address0); if(inode_arrayi.length >= 512) release_blk(inode_arrayi.address1);save_inode(i);n"); return ;int n,t,i;stack<int> istk; for(i = 0; i < INODENUM; i+)num >=0) && (inode_arrayi.iparent = inum_cur)&& (!strcmp(ino
26、de_arrayi.file_name,argv1)&& (!strcmp(inode_arrayi.user_name,) n=inode_arrayi.inum;break; if(i=INODENUM) puts("Directory ERROR"); else (n); while(!() t=(); (); del(t); for(i = 0; i < INODENUM; i+) if(inode_arrayi.inum >=0) &&(inode_arrayi.iparent = t) (i); / 功能: 退出当前用
27、户(logout)void logout()printf("Do you want to exit this user(y/n)");scanf("%c", &choice); getchar();if(choice = 'y') | (choice = 'Y') printf("nCurrent user has exited!n"); login();return ;/ 功能: 退出文件系统(quit)void quit()printf("Do you want to exist(y/n):");scanf("%c", &choice);getchar(); if(choice = 'y') | (choice = 'Y')exit(0);/ 功能: 显示错误void errcmd()printf("Command Error!n");/清空内存中存在的用户名v
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030运营支持系统(OSS)行业市场现状供需分析及重点企业投资评估规划分析研究报告
- 2025-2030沥青玛蹄脂行业市场现状供需分析及重点企业投资评估规划分析研究报告
- 2025-2030年中国马保健行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国顺丁橡胶行业市场深度分析及前景趋势与投资研究报告
- 2025-2030年中国降解塑料制品行业市场深度发展趋势与前景展望战略研究报告
- 2025-2030年中国跳蚤及蜱类产品行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国茶饮料行业市场深度调研及竞争格局与投资策略研究报告
- 2025-2030年中国耕耘点行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国立体车库行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国碘克沙醇注射液行业市场现状供需分析及投资评估规划分析研究报告
- 机械原理课程设计摇摆式输送机设计说明书
- 重型自卸车货箱与举升装置设计(含CAD图纸)
- 内蒙古煤矿竖井地质勘察施工技术
- 高中化学课程标准(2020版)
- 周1530安全教育记录(2021至2022)
- 西方音乐史智慧树知到答案章节测试2023年山东师范大学
- 初中英语-Module 12 Unit 2 Repeat these three words dailyreduce,reuse and recycle.教学课件设计
- 传输与控制大屏ds-d2046nl lcd显示单元用户手册
- 草原生态保护补助奖励机制资金管理办法
- WS/T 431-2013护理分级
- GB/T 25685.1-2010土方机械监视镜和后视镜的视野第1部分:试验方法
评论
0/150
提交评论