- sync up with latest OpenGL specifications

- some fixes in make_opengl to support the new types
This commit is contained in:
Lionel Ulmer 2004-03-02 20:54:17 +00:00 committed by Alexandre Julliard
parent f7ed056a43
commit 0e999e3c31
3 changed files with 790 additions and 16 deletions

View File

@ -83,6 +83,12 @@ $gen_traces = 1;
"1_1" => 1 ); "1_1" => 1 );
%cat_1_2 = ( %cat_1_1, %cat_1_2 = ( %cat_1_1,
"VERSION_1_2" => 1 ); "VERSION_1_2" => 1 );
%cat_1_3 = ( %cat_1_2,
"VERSION_1_3" => 1 );
%cat_1_4 = ( %cat_1_3,
"VERSION_1_4" => 1 );
%cat_1_5 = ( %cat_1_4,
"VERSION_1_5" => 1 );
%norm_categories = (); %norm_categories = ();
@ -109,6 +115,10 @@ $gen_traces = 1;
"GLhalfNV" => "%d", "GLhalfNV" => "%d",
"GLintptrARB" => "%d", "GLintptrARB" => "%d",
"GLsizeiptrARB" => "%d", "GLsizeiptrARB" => "%d",
"GLintptr" => "%d",
"GLsizeiptr" => "%d",
"GLhandleARB" => "%d",
"GLcharARB" => "%c",
"GLvoid" => "(void)", "GLvoid" => "(void)",
"_GLfuncptr" => "%p"); "_GLfuncptr" => "%p");
@ -135,6 +145,10 @@ $gen_traces = 1;
"GLhalfNV" => [ "long", 4 ], "GLhalfNV" => [ "long", 4 ],
"GLintptrARB" => [ "long", 4 ], "GLintptrARB" => [ "long", 4 ],
"GLsizeiptrARB" => [ "long", 4 ], "GLsizeiptrARB" => [ "long", 4 ],
"GLhandleARB" => [ "long", 4 ],
"GLcharARB" => [ "long", 4 ],
"GLintptr" => [ "long", 4 ],
"GLsizeiptr" => [ "long", 4 ],
"GLvoid" => [ "void", 4 ], "GLvoid" => [ "void", 4 ],
"_GLfuncptr" => [ "ptr", 4 ]); "_GLfuncptr" => [ "ptr", 4 ]);
@ -147,6 +161,10 @@ sub ConvertType {
%hash = ( "GLstring" => "const GLubyte *", %hash = ( "GLstring" => "const GLubyte *",
"GLintptrARB" => "ptrdiff_t", "GLintptrARB" => "ptrdiff_t",
"GLsizeiptrARB" => "ptrdiff_t", "GLsizeiptrARB" => "ptrdiff_t",
"GLintptr" => "ptrdiff_t",
"GLsizeiptr" => "ptrdiff_t",
"GLhandleARB" => "unsigned int",
"GLcharARB" => "char",
"GLhalfNV" => "unsigned short" ); "GLhalfNV" => "unsigned short" );
foreach $org (keys %hash) { foreach $org (keys %hash) {
@ -158,6 +176,24 @@ sub ConvertType {
return $type; return $type;
} }
#
# Used to convert some variable names
#
sub ConvertVarName {
my ($type) = @_;
%hash = ( "near" => "nearParam",
"far" => "farParam" );
foreach $org (keys %hash) {
if ($type =~ /$org/) {
($before, $after) = ($type =~ /^(.*)$org(.*)$/);
return "$before$hash{$org}$after";
}
}
return $type;
}
# #
# This functions generates the thunk for a given function. # This functions generates the thunk for a given function.
# #
@ -176,8 +212,10 @@ sub GenerateThunk {
} }
$ret = $ret . ConvertType($func_ref->[1]) . " WINAPI wine_" . $func_ref->[0] . "( "; $ret = $ret . ConvertType($func_ref->[1]) . " WINAPI wine_" . $func_ref->[0] . "( ";
for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) { for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) {
## Quick debug code :-)
## print $func_ref->[2]->[$i]->[1] . "\n";
$type = $func_ref->[2]->[$i]->[0]; $type = $func_ref->[2]->[$i]->[0];
$name = $func_ref->[2]->[$i]->[1]; $name = ConvertVarName($func_ref->[2]->[$i]->[1]);
$ret = $ret . ConvertType($type) . " $name"; $ret = $ret . ConvertType($type) . " $name";
$call_arg = $call_arg . "$name"; $call_arg = $call_arg . "$name";
if ($type =~ /\*/) { if ($type =~ /\*/) {
@ -239,8 +277,14 @@ if ($version eq "1.0") {
%norm_categories = %cat_1_1; %norm_categories = %cat_1_1;
} elsif ($version eq "1.2") { } elsif ($version eq "1.2") {
%norm_categories = %cat_1_2; %norm_categories = %cat_1_2;
} elsif ($version eq "1.3") {
%norm_categories = %cat_1_3;
} elsif ($version eq "1.4") {
%norm_categories = %cat_1_4;
} elsif ($version eq "1.5") {
%norm_categories = %cat_1_5;
} else { } else {
die "OpenGL version incorrect. Should be one of '1.0', '1.1' or '1.2'.\n"; die "Incorrect OpenGL version.\n";
} }
# #
@ -620,7 +664,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(opengl);
# First, generate the function pointers # First, generate the function pointers
foreach (sort keys %ext_functions) { foreach (sort keys %ext_functions) {
$func_ref = $ext_functions{$_}; $func_ref = $ext_functions{$_};
print EXT $func_ref->[1] . " (*" . $ext_prefix . $func_ref->[0] . ")( "; print EXT ConvertType($func_ref->[1]) . " (*" . $ext_prefix . $func_ref->[0] . ")( ";
for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) { for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) {
$type = ConvertType($func_ref->[2]->[$i]->[0]); $type = ConvertType($func_ref->[2]->[$i]->[0]);
print EXT "$type"; print EXT "$type";
@ -637,7 +681,7 @@ foreach (sort keys %ext_functions) {
print EXT "\n\n/* The function prototypes */\n"; print EXT "\n\n/* The function prototypes */\n";
foreach (sort keys %ext_functions) { foreach (sort keys %ext_functions) {
$func_ref = $ext_functions{$_}; $func_ref = $ext_functions{$_};
print EXT $func_ref->[1] . " WINAPI " . "wine_" . $func_ref->[0] . "( "; print EXT ConvertType($func_ref->[1]) . " WINAPI " . "wine_" . $func_ref->[0] . "( ";
for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) { for ($i = 0; $i <= $#{@{$func_ref->[2]}}; $i++) {
$type = ConvertType($func_ref->[2]->[$i]->[0]); $type = ConvertType($func_ref->[2]->[$i]->[0]);
print EXT "$type"; print EXT "$type";

File diff suppressed because it is too large Load Diff

View File

@ -802,10 +802,10 @@ void WINAPI wine_glDepthMask( GLboolean flag ) {
/*********************************************************************** /***********************************************************************
* glDepthRange (OPENGL32.@) * glDepthRange (OPENGL32.@)
*/ */
void WINAPI wine_glDepthRange( GLclampd nearParm, GLclampd farParm ) { void WINAPI wine_glDepthRange( GLclampd nearParam, GLclampd farParam ) {
TRACE("(%f, %f)\n", nearParm, farParm ); TRACE("(%f, %f)\n", nearParam, farParam );
ENTER_GL(); ENTER_GL();
glDepthRange( nearParm, farParm ); glDepthRange( nearParam, farParam );
LEAVE_GL(); LEAVE_GL();
} }