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
7c3a522d
Commit
7c3a522d
authored
Apr 03, 2012
by
Huw Davies
Committed by
Alexandre Julliard
Apr 03, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wineps: Store the unicode version of the printer name and call the unicode version of OpenPrinter.
parent
a1526669
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
44 additions
and
31 deletions
+44
-31
driver.c
dlls/wineps.drv/driver.c
+14
-2
escape.c
dlls/wineps.drv/escape.c
+2
-2
init.c
dlls/wineps.drv/init.c
+26
-25
psdrv.h
dlls/wineps.drv/psdrv.h
+2
-2
No files found.
dlls/wineps.drv/driver.c
View file @
7c3a522d
...
...
@@ -291,6 +291,18 @@ static void (WINAPI *pInitCommonControls) (void);
static
HPROPSHEETPAGE
(
WINAPI
*
pCreatePropertySheetPage
)
(
LPCPROPSHEETPAGEW
);
static
int
(
WINAPI
*
pPropertySheet
)
(
LPCPROPSHEETHEADERW
);
static
PRINTERINFO
*
PSDRV_FindPrinterInfoA
(
LPCSTR
name
)
{
int
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
name
,
-
1
,
NULL
,
0
);
WCHAR
*
nameW
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
*
sizeof
(
WCHAR
)
);
PRINTERINFO
*
pi
;
MultiByteToWideChar
(
CP_ACP
,
0
,
name
,
-
1
,
nameW
,
len
);
pi
=
PSDRV_FindPrinterInfo
(
nameW
);
HeapFree
(
GetProcessHeap
(),
0
,
nameW
);
return
pi
;
}
/******************************************************************
* PSDRV_ExtDeviceMode
...
...
@@ -326,7 +338,7 @@ INT PSDRV_ExtDeviceMode(LPSTR lpszDriver, HWND hwnd, LPDEVMODEA lpdmOutput,
LPSTR
lpszDevice
,
LPSTR
lpszPort
,
LPDEVMODEA
lpdmInput
,
LPSTR
lpszProfile
,
DWORD
dwMode
)
{
PRINTERINFO
*
pi
=
PSDRV_FindPrinterInfo
(
lpszDevice
);
PRINTERINFO
*
pi
=
PSDRV_FindPrinterInfo
A
(
lpszDevice
);
if
(
!
pi
)
return
-
1
;
TRACE
(
"(Driver=%s, hwnd=%p, devOut=%p, Device='%s', Port='%s', devIn=%p, Profile='%s', Mode=%04x)
\n
"
,
...
...
@@ -419,7 +431,7 @@ DWORD PSDRV_DeviceCapabilities(LPSTR lpszDriver, LPCSTR lpszDevice, LPCSTR lpszP
PRINTERINFO
*
pi
;
DEVMODEA
*
lpdm
;
DWORD
ret
;
pi
=
PSDRV_FindPrinterInfo
(
lpszDevice
);
pi
=
PSDRV_FindPrinterInfo
A
(
lpszDevice
);
TRACE
(
"%s %s %s, %u, %p, %p
\n
"
,
debugstr_a
(
lpszDriver
),
debugstr_a
(
lpszDevice
),
debugstr_a
(
lpszPort
),
fwCapability
,
lpszOutput
,
lpDevMode
);
...
...
dlls/wineps.drv/escape.c
View file @
7c3a522d
...
...
@@ -425,9 +425,9 @@ INT PSDRV_StartDoc( PHYSDEV dev, const DOCINFOW *doc )
}
/* FIXME: use PRINTER_DEFAULTS here */
if
(
!
OpenPrinter
A
(
physDev
->
pi
->
FriendlyName
,
&
physDev
->
job
.
hprinter
,
NULL
))
{
if
(
!
OpenPrinter
W
(
physDev
->
pi
->
friendly_name
,
&
physDev
->
job
.
hprinter
,
NULL
))
{
WARN
(
"OpenPrinter(%s, ...) failed: %d
\n
"
,
debugstr_
a
(
physDev
->
pi
->
FriendlyN
ame
),
GetLastError
());
debugstr_
w
(
physDev
->
pi
->
friendly_n
ame
),
GetLastError
());
return
0
;
}
...
...
dlls/wineps.drv/init.c
View file @
7c3a522d
...
...
@@ -327,18 +327,12 @@ static BOOL PSDRV_CreateDC( PHYSDEV *pdev, LPCWSTR driver, LPCWSTR device,
{
PSDRV_PDEVICE
*
physDev
;
PRINTERINFO
*
pi
;
DWORD
len
;
char
*
deviceA
;
TRACE
(
"(%s %s %s %p)
\n
"
,
debugstr_w
(
driver
),
debugstr_w
(
device
),
debugstr_w
(
output
),
initData
);
if
(
!
device
)
return
FALSE
;
len
=
WideCharToMultiByte
(
CP_ACP
,
0
,
device
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
deviceA
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
);
WideCharToMultiByte
(
CP_ACP
,
0
,
device
,
-
1
,
deviceA
,
len
,
NULL
,
NULL
);
pi
=
PSDRV_FindPrinterInfo
(
deviceA
);
HeapFree
(
GetProcessHeap
(),
0
,
deviceA
);
pi
=
PSDRV_FindPrinterInfo
(
device
);
if
(
!
pi
)
return
FALSE
;
if
(
!
pi
->
Fonts
)
{
...
...
@@ -376,7 +370,7 @@ static BOOL PSDRV_CreateCompatibleDC( PHYSDEV orig, PHYSDEV *pdev )
{
HDC
hdc
=
(
*
pdev
)
->
hdc
;
PSDRV_PDEVICE
*
physDev
,
*
orig_dev
=
get_psdrv_dev
(
orig
);
PRINTERINFO
*
pi
=
PSDRV_FindPrinterInfo
(
orig_dev
->
pi
->
FriendlyN
ame
);
PRINTERINFO
*
pi
=
PSDRV_FindPrinterInfo
(
orig_dev
->
pi
->
friendly_n
ame
);
if
(
!
pi
)
return
FALSE
;
if
(
!
(
physDev
=
create_psdrv_physdev
(
pi
)))
return
FALSE
;
...
...
@@ -540,7 +534,7 @@ static INT PSDRV_GetDeviceCaps( PHYSDEV dev, INT cap )
/**********************************************************************
* PSDRV_FindPrinterInfo
*/
PRINTERINFO
*
PSDRV_FindPrinterInfo
(
LPCSTR
name
)
PRINTERINFO
*
PSDRV_FindPrinterInfo
(
LPC
W
STR
name
)
{
static
PRINTERINFO
*
PSDRV_PrinterList
;
DWORD
type
=
REG_BINARY
,
needed
,
res
,
dwPaperSize
;
...
...
@@ -550,32 +544,37 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
HANDLE
hPrinter
=
0
;
const
char
*
ppd
=
NULL
;
DWORD
ppdType
;
char
*
ppdFileName
=
NULL
;
char
*
ppdFileName
=
NULL
,
*
nameA
=
NULL
;
HKEY
hkey
;
BOOL
using_default_devmode
=
FALSE
;
int
len
;
TRACE
(
"'%s'
\n
"
,
name
);
TRACE
(
"'%s'
\n
"
,
debugstr_w
(
name
)
);
/*
* If this loop completes, last will point to the 'next' element of the
* final PRINTERINFO in the list
*/
for
(
;
pi
;
last
=
&
pi
->
next
,
pi
=
pi
->
next
)
if
(
!
strcmp
(
pi
->
FriendlyN
ame
,
name
))
if
(
!
strcmp
W
(
pi
->
friendly_n
ame
,
name
))
return
pi
;
pi
=
*
last
=
HeapAlloc
(
PSDRV_Heap
,
HEAP_ZERO_MEMORY
,
sizeof
(
*
pi
)
);
if
(
pi
==
NULL
)
return
NULL
;
if
(
!
(
pi
->
FriendlyName
=
HeapAlloc
(
PSDRV_Heap
,
0
,
strlen
(
name
)
+
1
)))
goto
fail
;
strcpy
(
pi
->
FriendlyN
ame
,
name
);
if
(
!
(
pi
->
friendly_name
=
HeapAlloc
(
PSDRV_Heap
,
0
,
(
strlenW
(
name
)
+
1
)
*
sizeof
(
WCHAR
)
)))
goto
fail
;
strcpy
W
(
pi
->
friendly_n
ame
,
name
);
if
(
OpenPrinter
A
(
pi
->
FriendlyName
,
&
hPrinter
,
NULL
)
==
0
)
{
ERR
(
"OpenPrinter
A
failed with code %i
\n
"
,
GetLastError
());
if
(
OpenPrinter
W
(
pi
->
friendly_name
,
&
hPrinter
,
NULL
)
==
0
)
{
ERR
(
"OpenPrinter failed with code %i
\n
"
,
GetLastError
());
goto
cleanup
;
}
len
=
WideCharToMultiByte
(
CP_ACP
,
0
,
name
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
nameA
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
);
WideCharToMultiByte
(
CP_ACP
,
0
,
name
,
-
1
,
nameA
,
len
,
NULL
,
NULL
);
needed
=
0
;
res
=
GetPrinterDataExA
(
hPrinter
,
NULL
,
default_devmodeA
,
&
type
,
NULL
,
0
,
&
needed
);
...
...
@@ -585,7 +584,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
goto
closeprinter
;
*
pi
->
Devmode
=
DefaultDevmode
;
lstrcpynA
((
LPSTR
)
pi
->
Devmode
->
dmPublic
.
dmDeviceName
,
name
,
CCHDEVICENAME
);
lstrcpynA
((
LPSTR
)
pi
->
Devmode
->
dmPublic
.
dmDeviceName
,
nameA
,
CCHDEVICENAME
);
using_default_devmode
=
TRUE
;
}
else
{
...
...
@@ -604,7 +603,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
pcupsGetPPD
=
wine_dlsym
(
cupshandle
,
"cupsGetPPD"
,
NULL
,
0
);
if
(
pcupsGetPPD
)
{
ppd
=
pcupsGetPPD
(
name
);
ppd
=
pcupsGetPPD
(
nameA
);
if
(
ppd
)
{
needed
=
strlen
(
ppd
)
+
1
;
...
...
@@ -615,7 +614,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
/* we should unlink() that file later */
}
else
{
res
=
ERROR_FILE_NOT_FOUND
;
WARN
(
"Did not find ppd for %s
\n
"
,
name
);
WARN
(
"Did not find ppd for %s
\n
"
,
debugstr_w
(
name
)
);
}
}
}
...
...
@@ -636,8 +635,8 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
{
const
char
*
value_name
;
if
(
RegQueryValueExA
(
hkey
,
name
,
0
,
NULL
,
NULL
,
&
needed
)
==
ERROR_SUCCESS
)
{
value_name
=
name
;
if
(
RegQueryValueExA
(
hkey
,
name
A
,
0
,
NULL
,
NULL
,
&
needed
)
==
ERROR_SUCCESS
)
{
value_name
=
name
A
;
}
else
if
(
RegQueryValueExA
(
hkey
,
"generic"
,
0
,
NULL
,
NULL
,
&
needed
)
==
ERROR_SUCCESS
)
{
value_name
=
"generic"
;
}
else
{
...
...
@@ -660,7 +659,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
else
{
res
=
ERROR_FILE_NOT_FOUND
;
ERR
(
"Error %i getting PPD file name for printer '%s'
\n
"
,
res
,
name
);
ERR
(
"Error %i getting PPD file name for printer '%s'
\n
"
,
res
,
debugstr_w
(
name
)
);
goto
closeprinter
;
}
ppdFileName
=
HeapAlloc
(
PSDRV_Heap
,
0
,
strlen
(
data_dir
)
+
strlen
(
filename
)
+
1
);
...
...
@@ -726,7 +725,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
if
(
res
==
ERROR_SUCCESS
)
pi
->
Devmode
->
dmPublic
.
u1
.
s1
.
dmPaperSize
=
(
SHORT
)
dwPaperSize
;
else
if
(
res
==
ERROR_FILE_NOT_FOUND
)
TRACE
(
"No 'Paper Size' for printer '%s'
\n
"
,
name
);
TRACE
(
"No 'Paper Size' for printer '%s'
\n
"
,
debugstr_w
(
name
)
);
else
{
ERR
(
"GetPrinterDataA returned %i
\n
"
,
res
);
goto
closeprinter
;
...
...
@@ -749,7 +748,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
res
=
EnumPrinterDataExA
(
hPrinter
,
"PrinterDriverData
\\
FontSubTable"
,
NULL
,
0
,
&
needed
,
&
pi
->
FontSubTableSize
);
if
(
res
==
ERROR_SUCCESS
||
res
==
ERROR_FILE_NOT_FOUND
)
{
TRACE
(
"No 'FontSubTable' for printer '%s'
\n
"
,
name
);
TRACE
(
"No 'FontSubTable' for printer '%s'
\n
"
,
debugstr_w
(
name
)
);
}
else
if
(
res
==
ERROR_MORE_DATA
)
{
pi
->
FontSubTable
=
HeapAlloc
(
PSDRV_Heap
,
0
,
needed
);
...
...
@@ -794,6 +793,7 @@ PRINTERINFO *PSDRV_FindPrinterInfo(LPCSTR name)
}
}
HeapFree
(
GetProcessHeap
(),
0
,
nameA
);
if
(
ppd
)
unlink
(
ppd
);
return
pi
;
...
...
@@ -802,10 +802,11 @@ closeprinter:
cleanup:
HeapFree
(
PSDRV_Heap
,
0
,
ppdFileName
);
HeapFree
(
PSDRV_Heap
,
0
,
pi
->
FontSubTable
);
HeapFree
(
PSDRV_Heap
,
0
,
pi
->
FriendlyN
ame
);
HeapFree
(
PSDRV_Heap
,
0
,
pi
->
friendly_n
ame
);
HeapFree
(
PSDRV_Heap
,
0
,
pi
->
Devmode
);
fail:
HeapFree
(
PSDRV_Heap
,
0
,
pi
);
HeapFree
(
GetProcessHeap
(),
0
,
nameA
);
if
(
ppd
)
unlink
(
ppd
);
*
last
=
NULL
;
return
NULL
;
...
...
dlls/wineps.drv/psdrv.h
View file @
7c3a522d
...
...
@@ -242,7 +242,7 @@ numInstalledOptions of OPTIONs
}
PSDRV_DEVMODEA
;
typedef
struct
_tagPI
{
char
*
FriendlyN
ame
;
WCHAR
*
friendly_n
ame
;
PPD
*
ppd
;
PSDRV_DEVMODEA
*
Devmode
;
FONTFAMILY
*
Fonts
;
...
...
@@ -471,7 +471,7 @@ extern void PSDRV_MergeDevmodes(PSDRV_DEVMODEA *dm1, PSDRV_DEVMODEA *dm2,
PRINTERINFO
*
pi
)
DECLSPEC_HIDDEN
;
extern
BOOL
PSDRV_GetFontMetrics
(
void
)
DECLSPEC_HIDDEN
;
extern
PPD
*
PSDRV_ParsePPD
(
char
*
fname
)
DECLSPEC_HIDDEN
;
extern
PRINTERINFO
*
PSDRV_FindPrinterInfo
(
LPCSTR
name
)
DECLSPEC_HIDDEN
;
extern
PRINTERINFO
*
PSDRV_FindPrinterInfo
(
LPC
W
STR
name
)
DECLSPEC_HIDDEN
;
extern
const
AFM
*
PSDRV_FindAFMinList
(
FONTFAMILY
*
head
,
LPCSTR
name
)
DECLSPEC_HIDDEN
;
extern
BOOL
PSDRV_AddAFMtoList
(
FONTFAMILY
**
head
,
const
AFM
*
afm
,
BOOL
*
p_added
)
DECLSPEC_HIDDEN
;
...
...
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