c语言编写简单shell解释器

Posted sysu_zjl

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言编写简单shell解释器相关的知识,希望对你有一定的参考价值。

在windows开发环境下写一个简单shell解释器
1、输入一个exe可执行文件路径或命令后能启动该程序
2、输入txt文本文件的路径,能打开该文本文件中所指定的若干exe程序路径及命令打开程序

首先要弄清shell解释器其实就是一个exe文件,在这个程序输入正确
命令,就有相应操作执行。

接着启动程序其实就是在系统中创建进程,
用win32的api CreateaProcess()函数借口实现。
该函数原型如下

CreateProcess(

LPCWSTR lpszImageName, //指向可执行的模块的指针

LPCWSTR lpszCmdLine, //指向可执行命令行字符串的指针

LPSECURITY_ATTRIBUTES lpsaProcess, //CE 不支持

LPSECURITY_ATTRIBUTES lpsaThread, //CE 不支持

BOOL fInheritHandles, //CE 不支持

DWORD fdwCreate, //创建标志

LPVOID lpvEnvironment, //CE 不支持

LPWSTR lpszCurDir, //CE 不支持

LPSTARTUPINFOW lpsiStartInfo, //CE 不支持

LPPROCESS_INFORMATION lppiProcInfo //指向进程信息结构体的指针

);

该函数最重要的两个参数是lpszImageName和lpszCmdLine。
lpszImageName代表应用名
可以直接设为null,只需设定lpszCmdLine为正确的命令行参数即可(即在cmd上运行该程序时需要的命令)。

当输入字符串后
该min_shell.exe首先判断是否是直接打开exe可执行文件,还是需通过txt文本内容打开程序,接着创建程序就好。

#include <windows.h>
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
//判断输入字符串为txt还是执行exe命令
int check(char *s, int len) 
    int j = 0, flag = 0;
    for (int i = 0; i < len; i++) 
        if (s[i] == '.' && len - i > 3 && s[i + 1] == 'e' && s[i + 2] == 'x' && s[i + 3] == 'e')
            flag = 1;
    
    return flag;

//创建程序
void CreateProc(char* s) 
    STARTUPINFO si;
    PROCESS_INFORMATION pi;
    ZeroMemory(&si, sizeof(si));
    si.cb = sizeof(si);
    ZeroMemory(&pi, sizeof(pi));
    if (!CreateProcess(NULL, s, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) 
        fprintf(stderr, "creat Process Failed.\\n");
    
    else 
        fprintf(stderr, "Successfully created.\\n");
    
    WaitForSingleObject(pi.hProcess, 0);

//读取txt文本内容,并创建程序
void ReadTxt(char * argv) 
    // get file
    FILE * pFile;
    fopen_s( &pFile, argv,"rb");
    if (pFile == NULL) 
        fputs("File error", stderr);
        exit(1);
    

    // obtain file size:
    fseek(pFile, 0, SEEK_END);
    long lSize = ftell(pFile);
    rewind(pFile);

    // allocate memory to contain the whole file:
    char *buffer = (char*)malloc(sizeof(char)*lSize);
    if (buffer == NULL) 
        fputs("Memory error", stderr);
        exit(2);
    

    // copy the file into the buffer:
    size_t result = fread(buffer, 1, lSize, pFile);
    if (result != lSize) 
        fputs("Reading error", stderr);
        exit(3);
    

    char *pBegin = buffer;
    char *pEnd = strchr(pBegin, '\\r');//每行都以\\r\\n结尾
    pBegin = pBegin + 3;
    int lens = 0;
    while (pEnd) 
        char s[2010];
        lens = 0;
        while (pBegin != pEnd) 
            s[lens++] = *pBegin;
            pBegin++;
        
        s[lens++] = '\\0';
        CreateProc(s);
        pBegin = pEnd + 2;//每行都以\\r\\n结尾所以+2
        pEnd = strchr(pBegin, '\\r');
    

int main() 
    while (true) 
        printf("$min_shell>");
        char s[2010];
        gets_s(s);
        int len = strlen(s);
        int flag = check(s, len);//判断输入字符串为txt 还是exe
        if (flag == 1) 
            CreateProc(s);
        
        else 
            ReadTxt(s);
        
    

以上是关于c语言编写简单shell解释器的主要内容,如果未能解决你的问题,请参考以下文章

shell 简单脚本编程

python介绍和基础(待补充)

Shell入门资料

linux:shell

shell 之解释器变量字符串数组

脚本概述