2013-03-25 12:04:10 +00:00
|
|
|
#!/usr/bin/perl
|
2015-12-31 12:44:51 +00:00
|
|
|
# Copyright 2005-2016 ECMWF.
|
2013-03-25 14:23:07 +00:00
|
|
|
#
|
|
|
|
# This software is licensed under the terms of the Apache Licence Version 2.0
|
|
|
|
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
#
|
|
|
|
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
|
|
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
|
|
#
|
2013-03-25 12:04:10 +00:00
|
|
|
use Data::Dumper;
|
|
|
|
|
|
|
|
use strict; use warnings;
|
|
|
|
|
|
|
|
my $internal = get_internal_errors();
|
|
|
|
my $public = get_public_errors();
|
|
|
|
|
|
|
|
write_public($public);
|
|
|
|
#write_internal($internal);
|
|
|
|
write_C_errors($public,$internal);
|
|
|
|
write_F90_errors($public);
|
|
|
|
write_python_errors($public);
|
|
|
|
|
|
|
|
sub write_python_errors {
|
|
|
|
my $errdict = shift;
|
|
|
|
|
|
|
|
open(H,">grib_errors.h.new") or die "grib_errors.h.new: $!";
|
|
|
|
open(IN,"<grib_api.h.in") or die "grib_api.h.in: $!";
|
|
|
|
|
|
|
|
foreach (<IN>) {
|
|
|
|
if (/^!ERRORS/) {
|
|
|
|
foreach my $code (reverse sort {$a<=>$b} keys %{$errdict}) {
|
|
|
|
my $desc = $errdict->{$code};
|
|
|
|
print H "/** $desc->{text} */\n";
|
|
|
|
print H "#define $desc->{name}\t\t$code\n";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print H;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
close(H);
|
|
|
|
close(IN);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub write_F90_errors {
|
|
|
|
my $errdict = shift;
|
|
|
|
|
2016-10-26 17:42:32 +00:00
|
|
|
open(F1,">grib_api_constants.h.new") or die "grib_api_constants.h.new: $!";
|
|
|
|
open(F2,">eccodes_constants.h.new") or die "eccodes_constants.h.new: $!";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
foreach (sort {$a<=>$b} keys %{$errdict}){
|
2016-10-26 17:42:32 +00:00
|
|
|
my $name = $errdict->{$_}{name};
|
|
|
|
printf F1 " integer, parameter,public :: %-50s = %d\n", $name,$_;
|
|
|
|
(my $eccodes_name = $name) =~ s/GRIB_/CODES_/;
|
|
|
|
printf F2 " integer, parameter,public :: %-50s = %d\n", $eccodes_name,$_;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
2016-10-26 17:42:32 +00:00
|
|
|
printf F1 " integer, parameter,public :: %-50s = %d\n","GRIB_NULL",-1;
|
|
|
|
printf F2 " integer, parameter,public :: %-50s = %d\n","CODES_NULL",-1;
|
|
|
|
close(F1);
|
|
|
|
close(F2);
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub write_C_errors {
|
|
|
|
my ($public,$internal) = @_;
|
|
|
|
|
|
|
|
open(C,">grib_errors.c.new") or die "grib_errors.c.new: $!";
|
|
|
|
open(IN,"<grib_errors.c.in") or die "grib_errors.c.in: $!";
|
|
|
|
|
|
|
|
foreach (<IN>) {
|
|
|
|
if (/^!ERRORS/) {
|
|
|
|
foreach (reverse sort {$a<=>$b} keys %{$public}) {
|
|
|
|
my $desc = $public->{$_};
|
|
|
|
print C "\"$desc->{text}\",\t\t/* $_ $desc->{name} */\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach (sort {$a<=>$b} keys %{$internal}) {
|
|
|
|
my $desc = $internal->{$_};
|
|
|
|
print C "\"$desc->{text}\",\t\t/* $_ $desc->{name} */\n";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print C;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
close(C);
|
|
|
|
close(IN);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub write_public {
|
|
|
|
my $errdict = shift;
|
|
|
|
|
|
|
|
open(GAH,"<grib_api.h") or die "grib_api.h: $!";
|
|
|
|
open(H,">grib_api.h.new") or die "grib_api.h.new: $!";
|
|
|
|
open(IN,"<grib_api.h.in") or die "grib_api.h.in: $!";
|
|
|
|
|
|
|
|
foreach (<GAH>) {
|
|
|
|
last if /This part is automatically generated/;
|
|
|
|
print H;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach (<IN>) {
|
|
|
|
if (/^!ERRORS/) {
|
|
|
|
foreach my $code (reverse sort {$a<=>$b} keys %{$errdict}) {
|
|
|
|
my $desc = $errdict->{$code};
|
|
|
|
print H "/** $desc->{text} */\n";
|
|
|
|
print H "#define $desc->{name}\t\t$code\n";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print H;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
close(GAH);
|
|
|
|
close(H);
|
|
|
|
close(IN);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub write_internal {
|
|
|
|
my $errdict = shift;
|
|
|
|
|
|
|
|
open(GAH,"<grib_api_internal.h") or die "grib_api_internal.h: $!";
|
|
|
|
open(H,">grib_api_internal.h.new") or die "grib_api_internal.h.new: $!";
|
|
|
|
open(IN,"<grib_api_internal.h.in") or die "grib_api_internal.h.in: $!";
|
|
|
|
|
|
|
|
foreach (<GAH>) {
|
|
|
|
last if /This part is automatically generated/;
|
|
|
|
print H;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach (<IN>) {
|
|
|
|
if (/^!ERRORS/) {
|
|
|
|
foreach my $code (sort {$a<=>$b} keys %{$errdict}) {
|
|
|
|
my $desc = $errdict->{$code};
|
|
|
|
print H "/** $desc->{text} */\n";
|
|
|
|
print H "#define $desc->{name}\t\t$code\n";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
print H;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
close(GAH);
|
|
|
|
close(H);
|
|
|
|
close(IN);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub get_public_errors {
|
|
|
|
open(IN,"<grib_errors.txt") or die "grib_errors.txt: $!";
|
|
|
|
my %temp = ();
|
|
|
|
my $code = 0;
|
|
|
|
while (<IN>) {
|
|
|
|
next unless(/^GRIB_/);
|
|
|
|
chomp;
|
|
|
|
my ($name,$text) = split(" ",$_,2);
|
|
|
|
$temp{$code}{name} = $name;
|
|
|
|
$temp{$code}{text} = $text;
|
|
|
|
$code--;
|
|
|
|
}
|
|
|
|
close(IN);
|
|
|
|
return \%temp;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub get_internal_errors {
|
|
|
|
open(INI,"<grib_errors_internal.txt") or die "grib_errors_internal.txt: $!";
|
|
|
|
my %temp = ();
|
|
|
|
my $code = 1;
|
|
|
|
while (<INI>) {
|
|
|
|
next unless(/^GRIB_/);
|
|
|
|
chomp;
|
|
|
|
my ($name,$text) = split(" ",$_,2);
|
|
|
|
$temp{$code}{name} = $name;
|
|
|
|
$temp{$code}{text} = $text;
|
|
|
|
$code++;
|
|
|
|
}
|
|
|
|
close(INI);
|
|
|
|
return \%temp;
|
|
|
|
}
|