VirtualBox

source: vbox/trunk/include/iprt/message.h@ 27134

Last change on this file since 27134 was 27128, checked in by vboxsync, 15 years ago

IPRT: Added RTMsgWarning[V] and RTMsgInfo[V].

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.9 KB
Line 
1/** @file
2 * IPRT - Message Formatting.
3 */
4
5/*
6 * Copyright (C) 2009 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 *
25 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
26 * Clara, CA 95054 USA or visit http://www.sun.com if you need
27 * additional information or have any questions.
28 */
29
30#ifndef ___iprt_msg_h
31#define ___iprt_msg_h
32
33#include <iprt/cdefs.h>
34#include <iprt/types.h>
35#include <iprt/stdarg.h>
36
37RT_C_DECLS_BEGIN
38
39/** @defgroup grp_rt_msg RTMsg - Message Formatting
40 * @ingroup grp_rt
41 * @{
42 */
43
44/**
45 * Print error message to standard error.
46 *
47 * The message will be prefixed with the file name part of process image name
48 * (i.e. no path) and "error: ". If the message doesn't end with a new line,
49 * one will be added. The caller should call this with an empty string if
50 * unsure whether the cursor is currently position at the start of a new line.
51 *
52 * @returns IPRT status code.
53 * @param pszFormat The message format string.
54 * @param ... Format arguments.
55 */
56RTDECL(int) RTMsgError(const char *pszFormat, ...);
57
58/**
59 * Print error message to standard error.
60 *
61 * The message will be prefixed with the file name part of process image name
62 * (i.e. no path) and "error: ". If the message doesn't end with a new line,
63 * one will be added. The caller should call this with an empty string if
64 * unsure whether the cursor is currently position at the start of a new line.
65 *
66 * @returns IPRT status code.
67 * @param pszFormat The message format string.
68 * @param va Format arguments.
69 */
70RTDECL(int) RTMsgErrorV(const char *pszFormat, va_list va);
71
72/**
73 * Same as RTMsgError() except for the return value.
74 *
75 * @returns @a enmExitCode
76 * @param enmExitCode What to exit code to return. This is mainly for
77 * saving some vertical space in the source file.
78 * @param pszFormat The message format string.
79 * @param ... Format arguments.
80 */
81RTDECL(RTEXITCODE) RTMsgErrorExit(RTEXITCODE enmExitcode, const char *pszFormat, ...);
82
83/**
84 * Same as RTMsgErrorV() except for the return value.
85 *
86 * @returns @a enmExitCode
87 * @param enmExitCode What to exit code to return. This is mainly for
88 * saving some vertical space in the source file.
89 * @param pszFormat The message format string.
90 * @param va Format arguments.
91 */
92RTDECL(RTEXITCODE) RTMsgErrorExitV(RTEXITCODE enmExitCode, const char *pszFormat, va_list va);
93
94/**
95 * Print an error message for a RTR3Init failure and suggest an exit code.
96 *
97 * @code
98 *
99 * int rc = RTR3Init();
100 * if (RT_FAILURE(rc))
101 * return RTMsgInitFailure(rc);
102 *
103 * @endcode
104 *
105 * @returns Appropriate exit code.
106 * @param rcRTR3Init The status code returned by RTR3Init.
107 */
108RTDECL(RTEXITCODE) RTMsgInitFailure(int rcRTR3Init);
109
110/**
111 * Print informational message to standard error.
112 *
113 * The message will be prefixed with the file name part of process image name
114 * (i.e. no path) and "warning: ". If the message doesn't end with a new line,
115 * one will be added. The caller should call this with an empty string if
116 * unsure whether the cursor is currently position at the start of a new line.
117 *
118 * @returns IPRT status code.
119 * @param pszFormat The message format string.
120 * @param ... Format arguments.
121 */
122RTDECL(int) RTMsgWarning(const char *pszFormat, ...);
123
124/**
125 * Print informational message to standard error.
126 *
127 * The message will be prefixed with the file name part of process image name
128 * (i.e. no path) and "warning: ". If the message doesn't end with a new line,
129 * one will be added. The caller should call this with an empty string if
130 * unsure whether the cursor is currently position at the start of a new line.
131 *
132 * @returns IPRT status code.
133 * @param pszFormat The message format string.
134 * @param va Format arguments.
135 */
136RTDECL(int) RTMsgWarningV(const char *pszFormat, va_list va);
137
138/**
139 * Print informational message to standard output.
140 *
141 * The message will be prefixed with the file name part of process image name
142 * (i.e. no path) and "info: ". If the message doesn't end with a new line,
143 * one will be added. The caller should call this with an empty string if
144 * unsure whether the cursor is currently position at the start of a new line.
145 *
146 * @returns IPRT status code.
147 * @param pszFormat The message format string.
148 * @param ... Format arguments.
149 */
150RTDECL(int) RTMsgInfo(const char *pszFormat, ...);
151
152/**
153 * Print informational message to standard output.
154 *
155 * The message will be prefixed with the file name part of process image name
156 * (i.e. no path) and "info: ". If the message doesn't end with a new line,
157 * one will be added. The caller should call this with an empty string if
158 * unsure whether the cursor is currently position at the start of a new line.
159 *
160 * @returns IPRT status code.
161 * @param pszFormat The message format string.
162 * @param va Format arguments.
163 */
164RTDECL(int) RTMsgInfoV(const char *pszFormat, va_list va);
165
166/** @} */
167
168RT_C_DECLS_END
169
170#endif
171
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette