1 /* $NetBSD: print.c,v 1.5 2000/08/29 15:10:20 takemura Exp $ */
4 * Copyright (c) 1999 Shin Takemura.
7 * This software is part of the PocketBSD.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software developed by the PocketBSD project
20 * and its contributors.
21 * 4. Neither the name of the project nor the names of its contributors
22 * may be used to endorse or promote products derived from this software
23 * without specific prior written permission.
25 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
39 #include <res/resource.h> /* for IDC_STATUS, status area ID */
41 static HANDLE debug_log
= INVALID_HANDLE_VALUE
;
44 debug_printf(LPWSTR lpszFmt
, ...)
51 va_start(ap
, lpszFmt
);
52 count
= wvsprintf(buffer
, lpszFmt
, ap
);
56 OutputDebugStringW(buffer
);
58 if (debug_log
!= INVALID_HANDLE_VALUE
) {
59 /* convert wide char string into multibyte
61 n
= wcstombs(ascbuf
, buffer
, sizeof(ascbuf
));
62 /* convert into DOS style new line code */
63 if (ascbuf
[n
- 1] == 0x0a) {
69 WriteFile(debug_log
, ascbuf
, n
, &n
, NULL
);
76 msg_printf(UINT type
, LPWSTR caption
, LPWSTR lpszFmt
, ...)
82 va_start(ap
, lpszFmt
);
83 count
= wvsprintf(buffer
, lpszFmt
, ap
);
85 return MessageBox(hDlgMain
, buffer
, caption
, type
);
89 stat_printf(LPWSTR lpszFmt
, ...)
95 va_start(ap
, lpszFmt
);
96 count
= wvsprintf(buffer
, lpszFmt
, ap
);
99 SetDlgItemText(hDlgMain
, IDC_STATUS
, buffer
);
105 set_debug_log(TCHAR
* filename
)
109 * Logging into file is dangerous. It may cause file system clash,
110 * because it try to write file until the last moment to boot and
111 * Windows can't flush file cache properly.
112 * And therefore the logging will be disanable unless you put a
113 * dummy log file on a directory.
115 debug_log
= CreateFile(
116 filename
, /* file name */
117 GENERIC_READ
, /* access (read-write) mode */
118 FILE_SHARE_READ
,/* share mode */
119 NULL
, /* pointer to security attributes */
120 OPEN_EXISTING
, /* how to create */
121 FILE_ATTRIBUTE_NORMAL
, /* file attributes*/
122 NULL
/* handle to file with attributes to */
124 if (debug_log
== INVALID_HANDLE_VALUE
) {
127 CloseHandle(debug_log
);
129 debug_log
= CreateFile(
130 filename
, /* file name */
131 GENERIC_WRITE
, /* access (read-write) mode */
132 FILE_SHARE_WRITE
,/* share mode */
133 NULL
, /* pointer to security attributes */
134 CREATE_ALWAYS
, /* how to create */
135 FILE_ATTRIBUTE_NORMAL
, /* file attributes*/
136 NULL
/* handle to file with attributes to */
139 if (debug_log
== INVALID_HANDLE_VALUE
) {
147 close_debug_log(void)
149 if (debug_log
!= INVALID_HANDLE_VALUE
) {
150 CloseHandle(debug_log
);
151 debug_log
= INVALID_HANDLE_VALUE
;
153 * I hope Windows flush file buffer properly...