当前位置: 首页 > web >正文

【Linux】轻量级命令解释器minishell

Minishell

一、项目背景

在linux操作系统中,用户对操作系统进行的一系列操作都不能直接操作内核,而是通过shell间接对内核进行操作。

Shell 是操作系统中的一种程序,它为用户提供了一种与操作系统内核和计算机硬件进行交互的界面。用户可以通过 Shell 输入命令来执行各种任务,如文件管理、程序执行和系统配置等。

此次目标是自己编写一个minishell程序,可以完成shell的的基础功能。                    

二、项目实现

  1. 完成minishell界面设计
  2. 从终端接收用户输入的命令
  3. 调用函数实现用户命令

三、代码

terminal.c

#include"terminal.h"
#include <unistd.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include <sys/types.h>
#include <sys/wait.h>void show_usr_term_line()
{char buff[512] = {0};char path[128] = {0};getcwd(path,sizeof(path)); //获取当前工作目录的绝对路径sprintf(buff,"linux@Ubuntu:%s$ ",path);printf("%s",buff);return;
}int get_usr_cmd(char *buff,int len)//读取用户命令
{/*fgets(buff,sizeof(buff),stdin);形参是实参的拷贝,这里的buff是个指针,占8个字节*/fgets(buff,len,stdin);buff[strlen(buff) - 1] = '\0';return 0;
}int parse_usr_cmd(char * cmd_buf, char *arg[])//解析用户命令
{int i = 0;arg[i] = strtok(cmd_buf," ");while(arg[i] != NULL){i++;arg[i] = strtok(NULL," ");}return i;
}void exec_usr_cmd(char *arg[],int cmd_cnt)//执行用户命令
{pid_t pid = fork();if(pid > 0){wait(NULL);}else if (0 == pid){execvp(arg[0],arg);printf("fail exec");        }else{printf("fail fork");}
}

main.c

#include<stdio.h>
#include"terminal.h"
#include<string.h>
#include <unistd.h>
int main(int argc, char const *argv[])
{char cmd_buff[CMD_MAX_LEN] = {0};char *arg[CMD_MAX_CNT] = {NULL};int cmd_cnt = 0;while(1){show_usr_term_line();get_usr_cmd(cmd_buff,CMD_MAX_LEN);cmd_cnt = parse_usr_cmd(cmd_buff,arg);if(!strcmp(arg[0],"exit"))//退出minishell{break;}else if (!strcmp(arg[0],"cd"))//execvp不包含cd命令{chdir(arg[1]);//更改工作路径continue;}exec_usr_cmd(arg,cmd_cnt);}return 0;
}

terminal.h

#ifndef __TERMINAL_H__
#define __TERMINAL_H__#define CMD_MAX_LEN 512
#define CMD_MAX_CNT 10//用户命令字段
extern void show_usr_term_line();
extern int get_usr_cmd();
extern int parse_usr_cmd(char * cmd_buf, char *arg[]);
extern void exec_usr_cmd(char *arg[],int cmd_cnt);#endif

使用makefile管理工程文件

Makefile

DST=app
SRC=main.c terminal.c
CC=gcc$(DST):$(SRC)$(CC) $^ -o $@clean:rm $(DST)

http://www.xdnf.cn/news/852.html

相关文章:

  • 计算机组成原理笔记(十九)——4.4定点乘法运算
  • CentOS 7进入救援模式——VirtualBox虚拟机
  • 深入解析Vue3响应式系统:从Proxy实现到依赖收集的核心原理
  • Kubernetes 创建 Jenkins 实现 CICD 配置指南
  • 目标检测中的损失函数(二) | BIoU RIoU α-IoU
  • k8s之 kube-prometheus监控
  • 6N60-ASEMI机器人功率器件专用6N60
  • RabbitMQ
  • 进程控制(linux)
  • Tailwind 武林奇谈:bg-blue-400 失效,如何重拾蓝衣神功?
  • CSS零基础入门笔记:狂神版
  • http 文件下载和上传服务
  • Android RK356X TVSettings USB调试开关
  • LabVIEW数据采集与传感系统
  • 【项目管理】成本类计算 笔记
  • 离线安装rabbitmq全流程
  • postman乘法计算,变量赋值
  • EXCEL学习
  • JavaScript性能优化实战(1):性能优化基础与性能分析工具
  • 精益数据分析(11/126):辨别虚荣指标,挖掘数据真价值
  • NoSQL数据库
  • 泰迪智能科技大模型应用平台功能特色优势
  • KUKA机器人不同的安装方式的设置
  • leetcode0130. 被围绕的区域- medium
  • Electron Demo 的快速编译与启动
  • 【Django】设置让局域网内的人访问
  • Spring Batch
  • 重构便携钢琴专业边界丨特伦斯便携钢琴V30Pro定义新一代便携电钢琴
  • StarRocks:一款开源的高性能分析型数据仓库
  • 【PCB绘制】信号完整性准则