Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
351106f5
Commit
351106f5
authored
May 12, 2006
by
Detlef Riekenberg
Committed by
Alexandre Julliard
May 17, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winspool: Do not fail in OpenPrinter on pDefault / local print server.
parent
b7a62e56
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
58 additions
and
36 deletions
+58
-36
info.c
dlls/winspool/info.c
+58
-36
No files found.
dlls/winspool/info.c
View file @
351106f5
...
@@ -132,6 +132,12 @@ static const WCHAR MonitorsW[] = { 'S','y','s','t','e','m','\\',
...
@@ -132,6 +132,12 @@ static const WCHAR MonitorsW[] = { 'S','y','s','t','e','m','\\',
'P'
,
'r'
,
'i'
,
'n'
,
't'
,
'\\'
,
'P'
,
'r'
,
'i'
,
'n'
,
't'
,
'\\'
,
'M'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
's'
,
0
};
'M'
,
'o'
,
'n'
,
'i'
,
't'
,
'o'
,
'r'
,
's'
,
0
};
static
const
WCHAR
PrintersW
[]
=
{
'S'
,
'y'
,
's'
,
't'
,
'e'
,
'm'
,
'\\'
,
'C'
,
'u'
,
'r'
,
'r'
,
'e'
,
'n'
,
't'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'S'
,
'e'
,
't'
,
'\\'
,
'C'
,
'o'
,
'n'
,
't'
,
'r'
,
'o'
,
'l'
,
'\\'
,
'P'
,
'r'
,
'i'
,
'n'
,
't'
,
'\\'
,
'P'
,
'r'
,
'i'
,
'n'
,
't'
,
'e'
,
'r'
,
's'
,
0
};
static
const
WCHAR
LocalPortW
[]
=
{
'L'
,
'o'
,
'c'
,
'a'
,
'l'
,
' '
,
'P'
,
'o'
,
'r'
,
't'
,
0
};
static
const
WCHAR
LocalPortW
[]
=
{
'L'
,
'o'
,
'c'
,
'a'
,
'l'
,
' '
,
'P'
,
'o'
,
'r'
,
't'
,
0
};
static
const
WCHAR
user_default_reg_key
[]
=
{
'S'
,
'o'
,
'f'
,
't'
,
'w'
,
'a'
,
'r'
,
'e'
,
'\\'
,
static
const
WCHAR
user_default_reg_key
[]
=
{
'S'
,
'o'
,
'f'
,
't'
,
'w'
,
'a'
,
'r'
,
'e'
,
'\\'
,
...
@@ -776,12 +782,15 @@ static DWORD get_local_monitors(DWORD level, LPBYTE pMonitors, DWORD cbBuf, LPDW
...
@@ -776,12 +782,15 @@ static DWORD get_local_monitors(DWORD level, LPBYTE pMonitors, DWORD cbBuf, LPDW
/******************************************************************
/******************************************************************
* get_opened_printer_entry
* get_opened_printer_entry
* Get the first place empty in the opened printer table
* Get the first place empty in the opened printer table
*
* ToDo:
* - pDefault is ignored
*/
*/
static
HANDLE
get_opened_printer_entry
(
LPCWSTR
name
)
static
HANDLE
get_opened_printer_entry
(
LPCWSTR
name
,
LPPRINTER_DEFAULTSW
pDefault
)
{
{
UINT_PTR
handle
=
nb_printer_handles
,
i
;
UINT_PTR
handle
=
nb_printer_handles
,
i
;
jobqueue_t
*
queue
=
NULL
;
jobqueue_t
*
queue
=
NULL
;
opened_printer_t
*
printer
;
opened_printer_t
*
printer
=
NULL
;
EnterCriticalSection
(
&
printer_handles_cs
);
EnterCriticalSection
(
&
printer_handles_cs
);
...
@@ -792,9 +801,12 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
...
@@ -792,9 +801,12 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
if
(
handle
==
nb_printer_handles
)
if
(
handle
==
nb_printer_handles
)
handle
=
i
;
handle
=
i
;
}
}
else
if
(
!
queue
&&
!
strcmpW
(
name
,
printer_handles
[
i
]
->
name
))
else
{
if
(
!
queue
&&
(
name
)
&&
!
lstrcmpW
(
name
,
printer_handles
[
i
]
->
name
))
queue
=
printer_handles
[
i
]
->
queue
;
queue
=
printer_handles
[
i
]
->
queue
;
}
}
}
if
(
handle
>=
nb_printer_handles
)
if
(
handle
>=
nb_printer_handles
)
{
{
...
@@ -815,29 +827,45 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
...
@@ -815,29 +827,45 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
nb_printer_handles
+=
16
;
nb_printer_handles
+=
16
;
}
}
if
(
!
(
printer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
printer
))))
if
(
!
(
printer
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
*
printer
))))
{
{
handle
=
0
;
handle
=
0
;
goto
end
;
goto
end
;
}
}
if
(
name
)
{
printer
->
name
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
));
printer
->
name
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
));
if
(
!
printer
->
name
)
{
handle
=
0
;
goto
end
;
}
strcpyW
(
printer
->
name
,
name
);
strcpyW
(
printer
->
name
,
name
);
}
if
(
queue
)
if
(
queue
)
printer
->
queue
=
queue
;
printer
->
queue
=
queue
;
else
else
{
{
printer
->
queue
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
queue
));
printer
->
queue
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
queue
));
if
(
!
printer
->
queue
)
{
handle
=
0
;
goto
end
;
}
list_init
(
&
printer
->
queue
->
jobs
);
list_init
(
&
printer
->
queue
->
jobs
);
printer
->
queue
->
ref
=
0
;
printer
->
queue
->
ref
=
0
;
}
}
InterlockedIncrement
(
&
printer
->
queue
->
ref
);
InterlockedIncrement
(
&
printer
->
queue
->
ref
);
printer
->
doc
=
NULL
;
printer_handles
[
handle
]
=
printer
;
printer_handles
[
handle
]
=
printer
;
handle
++
;
handle
++
;
end:
end:
LeaveCriticalSection
(
&
printer_handles_cs
);
LeaveCriticalSection
(
&
printer_handles_cs
);
if
(
!
handle
&&
printer
)
{
/* Something Failed: Free the Buffers */
HeapFree
(
GetProcessHeap
(),
0
,
printer
->
name
);
if
(
!
queue
)
HeapFree
(
GetProcessHeap
(),
0
,
printer
->
queue
);
HeapFree
(
GetProcessHeap
(),
0
,
printer
);
}
return
(
HANDLE
)
handle
;
return
(
HANDLE
)
handle
;
}
}
...
@@ -1258,57 +1286,51 @@ BOOL WINAPI OpenPrinterA(LPSTR lpPrinterName,HANDLE *phPrinter,
...
@@ -1258,57 +1286,51 @@ BOOL WINAPI OpenPrinterA(LPSTR lpPrinterName,HANDLE *phPrinter,
*| XcvPort: "Servername,XcvPort PortName"
*| XcvPort: "Servername,XcvPort PortName"
*
*
* BUGS
* BUGS
*| Printserver not supported
*| Printer-Object not supported
*| Printer-Object not supported
*| XcvMonitor not supported
*| XcvMonitor not supported
*| XcvPort not supported
*| XcvPort not supported
*| pDefaults
not support
ed
*| pDefaults
is ignor
ed
*
*
*/
*/
BOOL
WINAPI
OpenPrinterW
(
LPWSTR
lpPrinterName
,
HANDLE
*
phPrinter
,
BOOL
WINAPI
OpenPrinterW
(
LPWSTR
lpPrinterName
,
HANDLE
*
phPrinter
,
LPPRINTER_DEFAULTSW
pDefault
)
LPPRINTER_DEFAULTSW
pDefault
)
{
{
HKEY
hkeyPrinters
,
hkeyPrinter
;
HKEY
hkeyPrinters
=
NULL
;
HKEY
hkeyPrinter
=
NULL
;
if
(
!
lpPrinterName
)
{
TRACE
(
"(%s, %p, %p)
\n
"
,
debugstr_w
(
lpPrinterName
),
phPrinter
,
pDefault
);
FIXME
(
"(printerName: NULL, pDefault %p Ret: False
\n
"
,
pDefault
);
if
(
pDefault
)
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
FIXME
(
"PRINTER_DEFAULTS ignored => %s,%p,0x%08lx
\n
"
,
return
FALSE
;
debugstr_w
(
pDefault
->
pDatatype
),
pDefault
->
pDevMode
,
pDefault
->
DesiredAccess
)
;
}
}
TRACE
(
"(printerName: %s, pDefault %p)
\n
"
,
debugstr_w
(
lpPrinterName
),
if
(
lpPrinterName
!=
NULL
)
pDefault
);
{
/* Check any Printer exists */
/* Check Printer exists */
if
(
RegCreateKeyW
(
HKEY_LOCAL_MACHINE
,
PrintersW
,
&
hkeyPrinters
)
!=
ERROR_SUCCESS
)
{
if
(
RegCreateKeyA
(
HKEY_LOCAL_MACHINE
,
Printers
,
&
hkeyPrinters
)
!=
ERROR_SUCCESS
)
{
ERR
(
"Can't create Printers key
\n
"
);
ERR
(
"Can't create Printers key
\n
"
);
SetLastError
(
ERROR_FILE_NOT_FOUND
);
/* ?? */
SetLastError
(
ERROR_FILE_NOT_FOUND
);
return
FALSE
;
return
FALSE
;
}
}
if
((
lpPrinterName
[
0
]
==
'\0'
)
||
/* explicitly exclude "" */
(
RegOpenKeyW
(
hkeyPrinters
,
lpPrinterName
,
&
hkeyPrinter
)
!=
ERROR_SUCCESS
))
{
if
(
lpPrinterName
[
0
]
==
'\0'
||
/* explicitly exclude "" */
WARN
(
"Printer not found in Registry: '%s'
\n
"
,
debugstr_w
(
lpPrinterName
));
RegOpenKeyW
(
hkeyPrinters
,
lpPrinterName
,
&
hkeyPrinter
)
!=
ERROR_SUCCESS
)
{
TRACE
(
"Can't find printer %s in registry
\n
"
,
debugstr_w
(
lpPrinterName
));
RegCloseKey
(
hkeyPrinters
);
RegCloseKey
(
hkeyPrinters
);
SetLastError
(
ERROR_INVALID_PRINTER_NAME
);
SetLastError
(
ERROR_INVALID_PRINTER_NAME
);
return
FALSE
;
return
FALSE
;
}
}
RegCloseKey
(
hkeyPrinter
);
RegCloseKey
(
hkeyPrinter
);
RegCloseKey
(
hkeyPrinters
);
RegCloseKey
(
hkeyPrinters
);
}
if
(
!
phPrinter
)
{
/* NT: FALSE with ERROR_INVALID_PARAMETER, 9x: TRUE */
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
FALSE
;
}
if
(
!
phPrinter
)
/* This seems to be what win95 does anyway */
/* Get the unique handle of the printer or Printserver */
return
TRUE
;
*
phPrinter
=
get_opened_printer_entry
(
lpPrinterName
,
pDefault
);
return
(
*
phPrinter
!=
0
);
/* Get the unique handle of the printer*/
*
phPrinter
=
get_opened_printer_entry
(
lpPrinterName
);
if
(
pDefault
!=
NULL
)
FIXME
(
"Not handling pDefault
\n
"
);
return
TRUE
;
}
}
/******************************************************************
/******************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment