/*----------------------------------------------------------------------*/

/*              Debug for embeded board, 2008-2-26, Rain.               */

/*----------------------------------------------------------------------*/

#define  PRINT_DEBUG    1

#define  UNDERLINE              "\033[4m"

#define  BLACK                  "\033[30m"

#define  RED                    "\033[31m"

#define  GREEN                  "\033[32m"

#define  YELLOW                 "\033[33m"

#define  BLUE                   "\033[34m"

#define  PURPLE                 "\033[35m"

#define  DARKGREEN              "\033[36m"

#define  WHITE                  "\033[37m"

#define  BG_BLACK               "\033[40m"

#define  BG_RED                 "\033[41m"

#define  BG_GREEN               "\033[42m"

#define  BG_YELLOW              "\033[43m"

#define  BG_BLUE                "\033[44m"

#define  BG_PURPLE              "\033[45m"

#define  BG_DARKGREEN           "\033[46m"

#define  BG_WHITE               "\033[47m"

#define  CLOSE                  "\033[0m"

#define cprintf(fmt, args...) do            \

{                                               \

    FILE *fp1 = fopen("/dev/tty", "a"); \

    FILE *fp2 = fopen("/tmp/dbg.txt", "a"); \

    int  flag = 0;                          \

    if (fp1 && (flag == 0 || flag == 2)) {  \

        fprintf(fp1, fmt, ## args);     \

        fclose(fp1);                    \

    }                                       \

    if (fp2 && (flag == 1 || flag == 2)) {  \

        fprintf(fp2, fmt, ## args);     \

        fclose(fp2);                    \

    } \

} while (0)



#ifdef  PRINT_DEBUG

#define dbg(fmt, args...)    \

    cprintf("==> CGI_DEBUG %s | %s %d | " fmt CLOSE, __FILE__, __FUNCTION__, __LINE__, ##args)

#else

#define dbg(fmt, args...)

#endif

/*----------------------------------------------------------------------*/



/*----------------------------------------------------------------------*/

/*              Debug for SSH terminal, 2008-2-26, Rain.                */

/*----------------------------------------------------------------------*/

#define  PRINT_DEBUG    1

#define  UNDERLINE              "\033[4m"

#define  BLACK                  "\033[30m"

#define  RED                    "\033[31m"

#define  GREEN                  "\033[32m"

#define  YELLOW                 "\033[33m"

#define  BLUE                   "\033[34m"

#define  PURPLE                 "\033[35m"

#define  DARKGREEN              "\033[36m"

#define  WHITE                  "\033[37m"

#define  BG_BLACK               "\033[40m"

#define  BG_RED                 "\033[41m"

#define  BG_GREEN               "\033[42m"

#define  BG_YELLOW              "\033[43m"

#define  BG_BLUE                "\033[44m"

#define  BG_PURPLE              "\033[45m"

#define  BG_DARKGREEN           "\033[46m"

#define  BG_WHITE               "\033[47m"

#define  CLOSE                  "\033[0m"

#define cprintf(fmt, args...) do            \

{                                               \

    char *dev = getenv("SSH_TTY");          \

    FILE *fp1 = fopen(dev, "a");            \

    FILE *fp2 = fopen("/tmp/dbg.txt", "a"); \

    int  flag = 0;                          \

    if (fp1 && (flag == 0 || flag == 2)) {  \

        fprintf(fp1, fmt, ## args);     \

        fclose(fp1);                    \

    }                                       \

    if (fp2 && (flag == 1 || flag == 2)) {  \

        fprintf(fp2, fmt, ## args);     \

        fclose(fp2);                    \

    } \

} while (0)



#ifdef  PRINT_DEBUG

#define dbg(fmt, args...)    \

    cprintf("==> CGI_DEBUG %s | %s %d | " fmt CLOSE, __FILE__, __FUNCTION__, __LINE__, ##args)

#else

#define dbg(fmt, args...)

#endif

/*----------------------------------------------------------------------*/

print to console or file的更多相关文章

  1. Log4J是Apache组织的开源一个开源项目,通过Log4J,可以指定日志信息输出的目的地,如console、file等。Log4J采用日志级别机制,请按照输出级别由低到高的顺序写出日志输出级别。

    Log4J是Apache组织的开源一个开源项目,通过Log4J,可以指定日志信息输出的目的地,如console.file等.Log4J采用日志级别机制,请按照输出级别由低到高的顺序写出日志输出级别. ...

  2. Python3 print()函数sep,end,file参数用法练习

    来自builtins.py:def print(self, *args, sep=' ', end='\n', file=None): # known special case of print &q ...

  3. Perl Print Win32 Console Windows 控制台 print Unicode 问题

    参考资料: https://stackoverflow.com/questions/15224400/perl-on-windows-problems-with-encoding https://te ...

  4. SVNKit学习——基于Repository的操作之print repository tree、file content、repository history(四)

    此篇文章同样是参考SVNKit在wiki的官方文档做的demo,每个类都可以单独运行.具体的细节都写到注释里了~ 开发背景: SVNKit版本:1.7.14 附上官网下载链接:https://www. ...

  5. (转)Python标准库:内置函数print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

    原文:https://blog.csdn.net/caimouse/article/details/44133241 https://www.cnblogs.com/owasp/p/5372476.h ...

  6. Disabling default console handler in Java Logger by codes

    The open source packages usu. relies on log4j or Java Logger to print logs, by default the console h ...

  7. python print及格式化

    print(value,sep=' ',end='\n',file=sys.stdout, flush=False) sep=' '默认空格 print('hello','world') #hello ...

  8. html之file标签 --- 图片上传前预览 -- FileReader

    记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...

  9. 操作文件方法简单总结(File,Directory,StreamReader,StreamWrite )

    对于文件夹,文档的操作一直处于一知半解状态,有时间闲下来了,好好练习了一把,对文档,文件的操作有了一个基本的认知, 若要深入了解,还是得通过实际的项目才行了,好了废话不多说,上酸菜!! 注:红色标题为 ...

随机推荐

  1. GDB调试工具总结

    程序调试的基本思想是“分析现象->假设错误原因->产生新的现象去验证假设”这样一个循环过程,根据现象如何假设错误原因,以及如何设计新的现象去验证假设,需要非常严密的分析和思考.程序中除了一 ...

  2. python - 增强的格式化字符串format函数

    语法 它通过{}和:来代替%. “映射”示例 通过位置 In [1]: '{0},{1}'.format('kzc',18) Out[1]: 'kzc,18' In [2]: '{},{}'.form ...

  3. 以AVL树为例理解二叉树的旋转(Rotate)操作

    树旋转是在二叉树中的一种子树调整操作, 每一次旋转并不影响对该二叉树进行中序遍历的结果. 树旋转通常应用于需要调整树的局部平衡性的场合. 树旋转包括两个不同的方式, 分别是左旋转和右旋转. 两种旋转呈 ...

  4. Java--解压缩zip包

    Test.java import java.io.IOException; public class Test { public static void main(String[] args) thr ...

  5. 在myeclipse中写sql语句的细节问题

    注意类型,varchar 和int  在java中表示为sql语句中的细微区别!! 下面的REGISEAT_NUM为int 类型       custid为varchar类型 String sql1= ...

  6. 老三星手机i9001刷机记录

    家里的老的三星i9001,准备给我妈用,打算刷机,但又实在头疼那些复杂的刷机技术,昨天研究了一下,用比较简单的方法完成刷机,记录如下: 用卡刷比较简单,线刷不考虑 进入恢复模式的方法:1.电源+音量加 ...

  7. 在不重装系统的情况下撤底删除oracle数据库及oralce的相关软件

    先从控制面板删除oracle的相关应用及数据库, 删除系统变量 ORACLE_OEM_CLASSPATH=%JAVA_HOME%\lib\ext\access-bridge-64.jar;%JAVA_ ...

  8. X86-64寄存器和栈帧

    简介 通用寄存器可用于传送和暂存数据,也可参与算术逻辑运算,并保存运算结果.除此之外,它们还各自具有一些特殊功能.通用寄存器的长度取决于机器字长,汇编语言程序员必须熟悉每个寄存器的一般用途和特殊用途, ...

  9. [Javascript]2. Improve you speed! Script Execution

    Let's take a closer look at how a browser retrieves and acts on scripts.modern browser can parallel ...

  10. (算法)位图BitMap

    题目: 给定一数组,大小为M,数组中的数字范围为1-N,如果某带宽有限,无法传输该大小的数组,该怎么办? 思路: 通过位图BitMap来压缩数组,将数组中每个数字在bit位上标志,这样就可以将数组大小 ...