RT-Thread finsh源码分析: finsh_error.c

/*
 *  error number for finsh shell.
 *
 * COPYRIGHT (C) 2013, Shanghai Real-Thread Technology Co., Ltd
 *
 *  This file is part of RT-Thread (http://www.rt-thread.org)
 *  Maintainer: bernard.xiong <bernard.xiong at gmail.com>
 *
 *  All rights reserved.
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License along
 *  with this program; if not, write to the Free Software Foundation, Inc.,
 *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Change Logs:
 * Date           Author       Notes
 * 2010-03-22     Bernard      first version
 */
#include "finsh_error.h"

u_char global_errno;  //静态全局变量,错误码

//错误类型对应的字符串
static const char * finsh_error_string_table[] =
{
    "No error",
    "Invalid token",
    "Expect a type",
    "Unknown type",
    "Variable exist",
    "Expect a operater",
    "Memory full",
    "Unknown operator",
    "Unknown node",
    "Expect a character",
    "Unexpect end",
    "Unknown token",
    "Float not supported",
    "Unknown symbol",
    "Null node"
};

//错误码初始化
int finsh_error_init()
{
    global_errno = FINSH_ERROR_OK;

    return 0;
}

//设置错误码
int finsh_error_set(u_char type)
{
    global_errno = type;

    return 0;
}

//获取错误码
u_char finsh_errno()
{
    return global_errno;
}

//通过错误码返回错误字符串
const char* finsh_error_string(u_char type)
{
    return finsh_error_string_table[type];
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值