php-src/phpdbg_utils.h

75 lines
3.4 KiB
C
Raw Normal View History

2013-11-12 02:19:43 +00:00
/*
+----------------------------------------------------------------------+
| PHP Version 5 |
+----------------------------------------------------------------------+
| Copyright (c) 1997-2013 The PHP Group |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
| Authors: Felipe Pena <felipe@php.net> |
| Authors: Joe Watkins <joe.watkins@live.co.uk> |
+----------------------------------------------------------------------+
*/
#ifndef PHPDBG_UTILS_H
#define PHPDBG_UTILS_H
2013-11-12 13:44:36 +00:00
/**
* Input scan functions
*/
2013-11-12 02:50:15 +00:00
int phpdbg_is_numeric(const char*);
int phpdbg_is_empty(const char*);
int phpdbg_is_addr(const char*);
2013-11-12 13:33:51 +00:00
int phpdbg_is_class_method(const char*, size_t, char**, char**);
2013-11-13 23:13:41 +00:00
const char *phpdbg_current_file(TSRMLS_D);
2013-11-13 23:36:02 +00:00
char *phpdbg_resolve_path(const char* TSRMLS_DC);
2013-11-19 21:26:40 +00:00
char *phpdbg_trim(const char*, size_t, size_t*);
2013-11-13 23:13:41 +00:00
/**
* Error/notice/formatting helper
*/
enum {
2013-11-13 21:15:45 +00:00
P_ERROR = 1,
P_NOTICE,
P_WRITELN,
P_WRITE,
P_LOG
};
int phpdbg_print(int TSRMLS_DC, FILE*, const char*, ...);
2013-11-22 16:15:24 +00:00
#define phpdbg_error(fmt, ...) phpdbg_print(P_ERROR TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDOUT], fmt, ##__VA_ARGS__)
#define phpdbg_notice(fmt, ...) phpdbg_print(P_NOTICE TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDOUT], fmt, ##__VA_ARGS__)
#define phpdbg_writeln(fmt, ...) phpdbg_print(P_WRITELN TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDOUT], fmt, ##__VA_ARGS__)
#define phpdbg_write(fmt, ...) phpdbg_print(P_WRITE TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDOUT], fmt, ##__VA_ARGS__)
#define phpdbg_log(fmt, ...) phpdbg_print(P_LOG TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDOUT], fmt, ##__VA_ARGS__)
#define phpdbg_error_ex(out, fmt, ...) phpdbg_print(P_ERROR TSRMLS_CC, out, fmt, ##__VA_ARGS__)
#define phpdbg_notice_ex(out, fmt, ...) phpdbg_print(P_NOTICE TSRMLS_CC, out, fmt, ##__VA_ARGS__)
#define phpdbg_writeln_ex(out, fmt, ...) phpdbg_print(P_WRITELN TSRMLS_CC, out, fmt, ##__VA_ARGS__)
#define phpdbg_write_ex(out, fmt, ...) phpdbg_print(P_WRITE TSRMLS_CC, out, fmt, ##__VA_ARGS__)
#define phpdbg_log_ex(out, fmt, ...) phpdbg_print(P_LOG TSRMLS_CC, out, fmt, ##__VA_ARGS__)
#if PHPDBG_DEBUG
2013-11-22 16:15:24 +00:00
# define phpdbg_debug(fmt, ...) phpdbg_print(P_LOG TSRMLS_CC, PHPDBG_G(io)[PHPDBG_STDERR], fmt, ##__VA_ARGS__)
#else
2013-11-16 11:34:23 +00:00
# define phpdbg_debug(fmt, ...)
#endif
2013-11-12 23:17:37 +00:00
/* {{{ For writing blank lines */
#define EMPTY "" /* }}} */
2013-11-12 23:31:46 +00:00
/* {{{ For prompt lines */
#define PROMPT ((PHPDBG_G(flags) & PHPDBG_IS_COLOURED) ? "\033[1;64mphpdbg>\033[0m " : "phpdbg> ") /* }}} */
2013-11-12 23:54:41 +00:00
/* {{{ For separation */
#define SEPARATE "------------------------------------------------" /* }}} */
2013-11-12 02:19:43 +00:00
#endif /* PHPDBG_UTILS_H */