2021-10-26 19:12:52 +03:00
|
|
|
#!/usr/bin/perl -w
|
|
|
|
|
|
|
|
use warnings;
|
|
|
|
use strict;
|
|
|
|
use File::Basename;
|
2021-10-27 02:00:06 +03:00
|
|
|
use Cwd qw(abs_path);
|
|
|
|
|
|
|
|
my $wikipath = undef;
|
|
|
|
foreach (@ARGV) {
|
|
|
|
$wikipath = abs_path($_), next if not defined $wikipath;
|
|
|
|
}
|
2021-10-26 19:12:52 +03:00
|
|
|
|
|
|
|
chdir(dirname(__FILE__));
|
|
|
|
chdir('..');
|
|
|
|
|
|
|
|
my @unsorted_releases = ();
|
|
|
|
open(PIPEFH, '-|', 'git tag -l') or die "Failed to read git release tags: $!\n";
|
|
|
|
|
|
|
|
while (<PIPEFH>) {
|
|
|
|
chomp;
|
|
|
|
if (/\Arelease\-(.*?)\Z/) {
|
2022-11-23 01:39:38 +03:00
|
|
|
# Ignore anything that isn't a x.y.0 release.
|
|
|
|
# Make sure new APIs are assigned to the next minor version and ignore the patch versions.
|
2022-10-25 21:03:32 +03:00
|
|
|
my $ver = $1;
|
|
|
|
my @versplit = split /\./, $ver;
|
2022-11-23 01:39:38 +03:00
|
|
|
next if (scalar(@versplit) < 1) || ($versplit[0] != 3); # Ignore anything that isn't an SDL3 release.
|
|
|
|
next if (scalar(@versplit) < 3) || ($versplit[2] != 0);
|
2022-10-25 21:03:32 +03:00
|
|
|
|
|
|
|
# Consider this release version.
|
|
|
|
push @unsorted_releases, $ver;
|
2021-10-26 19:12:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
close(PIPEFH);
|
|
|
|
|
|
|
|
#print("\n\nUNSORTED\n");
|
|
|
|
#foreach (@unsorted_releases) {
|
|
|
|
# print "$_\n";
|
|
|
|
#}
|
|
|
|
|
|
|
|
my @releases = sort {
|
|
|
|
my @asplit = split /\./, $a;
|
|
|
|
my @bsplit = split /\./, $b;
|
|
|
|
my $rc;
|
|
|
|
for (my $i = 0; $i < scalar(@asplit); $i++) {
|
|
|
|
return 1 if (scalar(@bsplit) <= $i); # a is "2.0.1" and b is "2.0", or whatever.
|
|
|
|
my $aseg = $asplit[$i];
|
|
|
|
my $bseg = $bsplit[$i];
|
|
|
|
$rc = int($aseg) <=> int($bseg);
|
|
|
|
return $rc if ($rc != 0); # found the difference.
|
|
|
|
}
|
|
|
|
return 0; # still here? They matched completely?!
|
|
|
|
} @unsorted_releases;
|
|
|
|
|
2022-11-23 01:39:38 +03:00
|
|
|
my $current_release = 'in-development';
|
|
|
|
my $next_release = '3.0.0'; # valid until we actually ship something. :)
|
|
|
|
if (scalar(@releases) > 0) {
|
|
|
|
# this happens to work for how SDL versions things at the moment.
|
|
|
|
$current_release = $releases[-1];
|
2022-05-16 06:50:08 +03:00
|
|
|
|
|
|
|
my @current_release_segments = split /\./, $current_release;
|
|
|
|
@current_release_segments[1] = '' . ($current_release_segments[1] + 2);
|
|
|
|
$next_release = join('.', @current_release_segments);
|
|
|
|
}
|
2021-11-10 23:40:27 +03:00
|
|
|
|
2021-10-26 19:12:52 +03:00
|
|
|
#print("\n\nSORTED\n");
|
|
|
|
#foreach (@releases) {
|
|
|
|
# print "$_\n";
|
|
|
|
#}
|
2021-11-10 23:40:27 +03:00
|
|
|
#print("\nCURRENT RELEASE: $current_release\n");
|
|
|
|
#print("NEXT RELEASE: $next_release\n\n");
|
2021-10-26 19:12:52 +03:00
|
|
|
|
|
|
|
push @releases, 'HEAD';
|
|
|
|
|
|
|
|
my %funcs = ();
|
|
|
|
foreach my $release (@releases) {
|
|
|
|
#print("Checking $release...\n");
|
|
|
|
my $tag = ($release eq 'HEAD') ? $release : "release-$release";
|
|
|
|
my $blobname = "$tag:src/dynapi/SDL_dynapi_overrides.h";
|
|
|
|
open(PIPEFH, '-|', "git show '$blobname'") or die "Failed to read git blob '$blobname': $!\n";
|
|
|
|
while (<PIPEFH>) {
|
|
|
|
chomp;
|
|
|
|
if (/\A\#define\s+(SDL_.*?)\s+SDL_.*?_REAL\Z/) {
|
|
|
|
my $fn = $1;
|
2022-11-23 01:39:38 +03:00
|
|
|
$funcs{$fn} = $release if not defined $funcs{$fn};
|
2021-10-26 19:12:52 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
close(PIPEFH);
|
|
|
|
}
|
|
|
|
|
2022-11-23 21:41:43 +03:00
|
|
|
# these are incorrect in the dynapi header, because we forgot to add them
|
|
|
|
# until a later release, but are available in the older release.
|
|
|
|
$funcs{'SDL_WinRTGetFSPathUNICODE'} = '2.0.3';
|
|
|
|
$funcs{'SDL_WinRTGetFSPathUTF8'} = '2.0.3';
|
|
|
|
|
2021-10-27 04:01:05 +03:00
|
|
|
if (not defined $wikipath) {
|
|
|
|
foreach my $release (@releases) {
|
|
|
|
foreach my $fn (sort keys %funcs) {
|
|
|
|
print("$fn: $funcs{$fn}\n") if $funcs{$fn} eq $release;
|
|
|
|
}
|
2021-10-26 19:12:52 +03:00
|
|
|
}
|
2021-10-27 04:01:05 +03:00
|
|
|
} else {
|
|
|
|
if (defined $wikipath) {
|
|
|
|
chdir($wikipath);
|
|
|
|
foreach my $fn (keys %funcs) {
|
|
|
|
my $revision = $funcs{$fn};
|
2021-11-10 23:40:27 +03:00
|
|
|
$revision = $next_release if $revision eq 'HEAD';
|
2021-10-27 04:01:05 +03:00
|
|
|
my $fname = "$fn.mediawiki";
|
|
|
|
if ( ! -f $fname ) {
|
|
|
|
#print STDERR "No such file: $fname\n";
|
|
|
|
next;
|
|
|
|
}
|
2021-10-26 19:12:52 +03:00
|
|
|
|
2021-10-27 04:01:05 +03:00
|
|
|
my @lines = ();
|
|
|
|
open(FH, '<', $fname) or die("Can't open $fname for read: $!\n");
|
|
|
|
my $added = 0;
|
|
|
|
while (<FH>) {
|
|
|
|
chomp;
|
|
|
|
if ((/\A\-\-\-\-/) && (!$added)) {
|
|
|
|
push @lines, "== Version ==";
|
|
|
|
push @lines, "";
|
|
|
|
push @lines, "This function is available since SDL $revision.";
|
|
|
|
push @lines, "";
|
|
|
|
$added = 1;
|
|
|
|
}
|
|
|
|
push @lines, $_;
|
|
|
|
next if not /\A\=\=\s+Version\s+\=\=/;
|
|
|
|
$added = 1;
|
|
|
|
push @lines, "";
|
|
|
|
push @lines, "This function is available since SDL $revision.";
|
|
|
|
push @lines, "";
|
|
|
|
while (<FH>) {
|
|
|
|
chomp;
|
|
|
|
next if not (/\A\=\=\s+/ || /\A\-\-\-\-/);
|
|
|
|
push @lines, $_;
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
close(FH);
|
2021-10-27 02:00:06 +03:00
|
|
|
|
2021-10-27 04:01:05 +03:00
|
|
|
if (!$added) {
|
2021-10-27 02:00:06 +03:00
|
|
|
push @lines, "== Version ==";
|
|
|
|
push @lines, "";
|
|
|
|
push @lines, "This function is available since SDL $revision.";
|
|
|
|
push @lines, "";
|
|
|
|
}
|
|
|
|
|
2021-10-27 04:01:05 +03:00
|
|
|
open(FH, '>', $fname) or die("Can't open $fname for write: $!\n");
|
|
|
|
foreach (@lines) {
|
|
|
|
print FH "$_\n";
|
|
|
|
}
|
|
|
|
close(FH);
|
2021-10-27 02:00:06 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|