2022-08-12 10:57:13 +00:00
|
|
|
#!/usr/bin/env perl
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
use strict;
|
|
|
|
use File::Path ;
|
|
|
|
use File::Basename ;
|
|
|
|
use File::Copy;
|
|
|
|
use Cwd;
|
|
|
|
use DBI;
|
|
|
|
|
|
|
|
my $basedir = dirname($0);
|
|
|
|
|
|
|
|
my $db="param";
|
2021-12-12 14:06:36 +00:00
|
|
|
my $host = $ENV{'PARAM_DB_HOST'} || 'unknown';
|
|
|
|
my $user = $ENV{'PARAM_DB_USER'} || 'unknown';
|
|
|
|
my $pass = $ENV{'PARAM_DB_PASS'} || 'unknown';
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
my $filename; my $filebase; my $out; my $conceptDir;
|
|
|
|
my $query; my $q; my $qh;
|
|
|
|
|
|
|
|
my $dbh = DBI->connect("dbi:mysql(RaiseError=>1):database=$db;host=$host",$user,$pass) or die $DBI::errstr;
|
|
|
|
|
|
|
|
# I have written to it already or not
|
2021-03-21 17:26:42 +00:00
|
|
|
#my $tarfilesflag = 0;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-11-18 22:11:16 +00:00
|
|
|
sub create_cfName {
|
|
|
|
my $p; my %seen;
|
|
|
|
my ($key) = "cfName";
|
|
|
|
my $field = "cf.name";
|
|
|
|
|
|
|
|
my $query= <<"EOF";
|
|
|
|
select $field,force128,edition,
|
2024-01-24 12:19:40 +00:00
|
|
|
centre.abbreviation,param_id,attribute.name,attribute_value,param.name,param.shortName from
|
|
|
|
param,grib_encoding,grib,attribute,centre,units,cf where
|
|
|
|
param.hide_def=0 and
|
2024-01-26 22:05:19 +00:00
|
|
|
param.retired=0 and
|
2024-01-24 12:19:40 +00:00
|
|
|
grib_encoding.id=grib.encoding_id and
|
|
|
|
param.id=grib_encoding.param_id and
|
|
|
|
attribute.id=grib.attribute_id and
|
|
|
|
centre.id=grib_encoding.centre_id and
|
|
|
|
units.id=param.units_id and
|
|
|
|
param.id=cf.grib1_ecmwf order by
|
|
|
|
edition,centre_id,param.o,param.id,grib_encoding.param_version,attribute.o;
|
2020-11-18 22:11:16 +00:00
|
|
|
EOF
|
|
|
|
|
|
|
|
my $qh=$dbh->prepare($query);
|
|
|
|
$qh->execute();
|
|
|
|
|
|
|
|
# file containing the list of grib api parameters files we want to tar and
|
|
|
|
# distribute to users for them to download and update their list of parameter
|
|
|
|
# to the latest
|
2021-03-21 17:26:42 +00:00
|
|
|
#open(TAR,$tarfilesflag ? ">>" : ">","tarfiles.txt") or die "Count not open file tarfiles.txt: $!";
|
|
|
|
#$tarfilesflag=1;
|
2020-11-18 22:11:16 +00:00
|
|
|
|
|
|
|
while (my ($keyval,$force128,$edition,$centre,$paramId,$attribute,$value,$name,$shortName)=$qh->fetchrow_array )
|
|
|
|
{
|
2024-01-24 12:19:40 +00:00
|
|
|
if ($centre eq "wmo" ) { $conceptDir=""; }
|
2020-11-18 22:11:16 +00:00
|
|
|
else { $conceptDir="/localConcepts/$centre"; }
|
|
|
|
|
|
|
|
if ($filebase ne "$basedir/grib$edition$conceptDir") {
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
$filebase="$basedir/grib$edition$conceptDir";
|
|
|
|
mkpath($filebase);
|
|
|
|
|
|
|
|
print TAR "grib$edition$conceptDir/$key.def\n";
|
2021-12-12 14:06:36 +00:00
|
|
|
#system("cp -f $filebase/$key.def $filebase/$key.def.orig");
|
2020-11-18 22:11:16 +00:00
|
|
|
open($out,"> $filebase/$key.def")
|
|
|
|
or die "unable to open $filebase/$key.def";
|
|
|
|
print $out "# Automatically generated by $0, do not edit\n";
|
|
|
|
$p=();
|
|
|
|
}
|
|
|
|
if ($p ne $paramId || exists($seen{$attribute}) ) {
|
|
|
|
if ($p) { print $out "\t}\n"; }
|
|
|
|
print $out "#$name\n" ;
|
|
|
|
print $out "\'".$keyval."\' = {\n" ;
|
|
|
|
$p=$paramId;
|
|
|
|
%seen=();
|
|
|
|
}
|
|
|
|
$seen{$attribute}=1;
|
|
|
|
print "($key=$keyval) $edition,$centre,$shortName,$paramId,$name,$attribute,$value\n";
|
|
|
|
# we need to allow strings in the attribute_value field
|
|
|
|
# for the moment we apply a patch here
|
|
|
|
if ($attribute =~ /stepType/ ) {
|
|
|
|
$value="\"accum\"";
|
|
|
|
}
|
|
|
|
if ($value eq '') {
|
|
|
|
$value="missing()";
|
|
|
|
}
|
|
|
|
print $out "\t $attribute = $value ;\n" ;
|
|
|
|
}
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
close(TAR);
|
|
|
|
}
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
sub create_def {
|
2013-12-19 17:28:43 +00:00
|
|
|
my $p; my %seen;
|
|
|
|
my ($key) =@_;
|
|
|
|
my $field=$key;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2013-12-19 17:28:43 +00:00
|
|
|
if ($key =~ /paramId/) { $field="param.id"; }
|
|
|
|
if ($key =~ /name/) { $field="param.name"; }
|
|
|
|
if ($key =~ /units/) { $field="units.name"; }
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2013-12-19 17:28:43 +00:00
|
|
|
my $query= <<"EOF";
|
2024-01-24 12:19:40 +00:00
|
|
|
select $field,force128,edition,
|
2021-12-12 14:06:36 +00:00
|
|
|
centre.abbreviation,param_id,attribute.name,attribute_value,param.name,param.shortName
|
2024-01-24 12:19:40 +00:00
|
|
|
from param,grib_encoding,grib,attribute,centre,units where
|
|
|
|
param.hide_def=0 and
|
2024-01-26 22:05:19 +00:00
|
|
|
param.retired=0 and
|
2024-01-24 12:19:40 +00:00
|
|
|
grib_encoding.id=grib.encoding_id and
|
|
|
|
param.id=grib_encoding.param_id and
|
|
|
|
attribute.id=grib.attribute_id and
|
|
|
|
centre.id=grib_encoding.centre_id and
|
|
|
|
units.id=param.units_id
|
|
|
|
order by edition,centre_id,param.o,param.id,grib_encoding.param_version,attribute.o;
|
2013-03-25 12:04:10 +00:00
|
|
|
EOF
|
|
|
|
|
2013-12-19 17:28:43 +00:00
|
|
|
my $qh=$dbh->prepare($query);
|
|
|
|
$qh->execute();
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
# file containing the list of grib api parameters files we want to tar and
|
|
|
|
# distribute to users for them to download and update their list of parameter
|
|
|
|
# to the latest
|
2021-03-21 17:26:42 +00:00
|
|
|
#open(TAR,$tarfilesflag ? ">>" : ">","tarfiles.txt") or die "Count not open file tarfiles.txt: $!";
|
|
|
|
#$tarfilesflag=1;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2013-12-19 17:28:43 +00:00
|
|
|
while (my ($keyval,$force128,$edition,$centre,$paramId,$attribute,$value,$name,$shortName)=$qh->fetchrow_array )
|
|
|
|
{
|
2024-01-24 12:19:40 +00:00
|
|
|
if ($centre eq "wmo" ) { $conceptDir=""; }
|
2013-03-25 12:04:10 +00:00
|
|
|
else { $conceptDir="/localConcepts/$centre"; }
|
2013-12-19 17:28:43 +00:00
|
|
|
#if ($key =~ /paramId/ && $force128==1 && $keyval >1000) {
|
|
|
|
# $keyval= $keyval % 1000;
|
|
|
|
#}
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
if ($filebase ne "$basedir/grib$edition$conceptDir") {
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
$filebase="$basedir/grib$edition$conceptDir";
|
2013-12-19 17:28:43 +00:00
|
|
|
mkpath($filebase);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
#copy("$filebase/$key.def","$filebase/$key.def.bkp")
|
2013-12-19 17:28:43 +00:00
|
|
|
# or die ("unable to copy $filebase/$key.def");
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
print TAR "grib$edition$conceptDir/$key.def\n";
|
2021-12-12 14:06:36 +00:00
|
|
|
#system("cp -f $filebase/$key.def $filebase/$key.def.orig");
|
2013-03-25 12:04:10 +00:00
|
|
|
open($out,"> $filebase/$key.def")
|
|
|
|
or die "unable to open $filebase/$key.def";
|
2015-12-11 18:08:30 +00:00
|
|
|
print $out "# Automatically generated by $0, do not edit\n";
|
2013-03-25 12:04:10 +00:00
|
|
|
$p=();
|
|
|
|
}
|
2013-12-19 17:28:43 +00:00
|
|
|
if ($p ne $paramId || exists($seen{$attribute}) ) {
|
|
|
|
if ($p) { print $out "\t}\n"; }
|
|
|
|
print $out "#$name\n" ;
|
|
|
|
print $out "\'".$keyval."\' = {\n" ;
|
|
|
|
$p=$paramId;
|
|
|
|
%seen=();
|
|
|
|
}
|
|
|
|
$seen{$attribute}=1;
|
|
|
|
print "($key=$keyval) $edition,$centre,$shortName,$paramId,$name,$attribute,$value\n";
|
|
|
|
# we need to allow strings in the attribute_value field
|
|
|
|
# for the moment we apply a patch here
|
|
|
|
if ($attribute =~ /stepType/ ) {
|
|
|
|
$value="\"accum\"";
|
|
|
|
}
|
2020-10-09 15:24:08 +00:00
|
|
|
if ($value eq '') {
|
|
|
|
$value="missing()";
|
|
|
|
}
|
2013-12-19 17:28:43 +00:00
|
|
|
print $out "\t $attribute = $value ;\n" ;
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
close(TAR);
|
|
|
|
}
|
2024-08-02 11:37:53 +00:00
|
|
|
|
|
|
|
sub create_cfVarName {
|
|
|
|
my $p; my %seen;
|
|
|
|
my ($key) =@_;
|
|
|
|
my $field=$key;
|
|
|
|
|
|
|
|
#if ($key =~ /paramId/) { $field="param.id"; }
|
|
|
|
#if ($key =~ /name/) { $field="param.name"; }
|
|
|
|
#if ($key =~ /units/) { $field="units.name"; }
|
|
|
|
if ($key =~ /cfVarName/) { $field="cfVarName"; }
|
|
|
|
|
|
|
|
my $query= <<"EOF";
|
|
|
|
select $field,force128,edition,
|
|
|
|
centre.abbreviation,param_id,attribute.name,attribute_value,param.name,param.shortName
|
|
|
|
from param,grib_encoding,grib,attribute,centre,units where
|
|
|
|
param.hide_def=0 and
|
|
|
|
grib_encoding.id=grib.encoding_id and
|
|
|
|
param.id=grib_encoding.param_id and
|
|
|
|
attribute.id=grib.attribute_id and
|
|
|
|
centre.id=grib_encoding.centre_id and
|
|
|
|
units.id=param.units_id
|
|
|
|
and cfVarName IS NOT NULL
|
|
|
|
order by edition,centre_id,param.o,param.id,grib_encoding.param_version,attribute.o;
|
|
|
|
EOF
|
|
|
|
|
|
|
|
my $qh=$dbh->prepare($query);
|
|
|
|
$qh->execute();
|
|
|
|
|
|
|
|
# file containing the list of grib api parameters files we want to tar and
|
|
|
|
# distribute to users for them to download and update their list of parameter
|
|
|
|
# to the latest
|
|
|
|
#open(TAR,$tarfilesflag ? ">>" : ">","tarfiles.txt") or die "Count not open file tarfiles.txt: $!";
|
|
|
|
#$tarfilesflag=1;
|
|
|
|
|
|
|
|
while (my ($keyval,$force128,$edition,$centre,$paramId,$attribute,$value,$name,$shortName)=$qh->fetchrow_array )
|
|
|
|
{
|
|
|
|
if ($centre eq "wmo" ) { $conceptDir=""; }
|
|
|
|
else { $conceptDir="/localConcepts/$centre"; }
|
|
|
|
#if ($key =~ /paramId/ && $force128==1 && $keyval >1000) {
|
|
|
|
# $keyval= $keyval % 1000;
|
|
|
|
#}
|
|
|
|
|
|
|
|
if ($filebase ne "$basedir/grib$edition$conceptDir") {
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
$filebase="$basedir/grib$edition$conceptDir";
|
|
|
|
mkpath($filebase);
|
|
|
|
|
|
|
|
#copy("$filebase/$key.def","$filebase/$key.def.bkp")
|
|
|
|
# or die ("unable to copy $filebase/$key.def");
|
|
|
|
|
|
|
|
print TAR "grib$edition$conceptDir/$key.def\n";
|
|
|
|
#system("cp -f $filebase/$key.def $filebase/$key.def.orig");
|
|
|
|
open($out,"> $filebase/$key.def")
|
|
|
|
or die "unable to open $filebase/$key.def";
|
|
|
|
print $out "# Automatically generated by $0, do not edit\n";
|
|
|
|
$p=();
|
|
|
|
}
|
|
|
|
if ($p ne $paramId || exists($seen{$attribute}) ) {
|
|
|
|
if ($p) { print $out "\t}\n"; }
|
|
|
|
print $out "#$name\n" ;
|
|
|
|
print $out "\'".$keyval."\' = {\n" ;
|
|
|
|
$p=$paramId;
|
|
|
|
%seen=();
|
|
|
|
}
|
|
|
|
$seen{$attribute}=1;
|
|
|
|
print "($key=$keyval) $edition,$centre,$shortName,$paramId,$name,$attribute,$value\n";
|
|
|
|
# we need to allow strings in the attribute_value field
|
|
|
|
# for the moment we apply a patch here
|
|
|
|
if ($attribute =~ /stepType/ ) {
|
|
|
|
$value="\"accum\"";
|
|
|
|
}
|
|
|
|
if ($value eq '') {
|
|
|
|
$value="missing()";
|
|
|
|
}
|
|
|
|
print $out "\t $attribute = $value ;\n" ;
|
|
|
|
}
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
close(TAR);
|
|
|
|
}
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
sub create_paramId_def {
|
2021-12-12 14:06:36 +00:00
|
|
|
my $p; my %seen;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2021-12-12 14:06:36 +00:00
|
|
|
my $query="select edition,centre.abbreviation,param_id,attribute.name,attribute_value,param.name,param.shortName
|
2024-01-24 12:19:40 +00:00
|
|
|
from param,grib_encoding,grib,attribute,centre where
|
|
|
|
param.hide_def=0 and
|
2024-01-26 22:05:19 +00:00
|
|
|
param.retired=0 and
|
2024-01-24 12:19:40 +00:00
|
|
|
grib_encoding.id=grib.encoding_id and
|
|
|
|
param.id=grib_encoding.param_id and
|
|
|
|
attribute.id=grib.attribute_id and
|
|
|
|
centre.id=grib_encoding.centre_id
|
|
|
|
order by edition,centre_id,param.o,param.id,attribute.o";
|
2021-12-12 14:06:36 +00:00
|
|
|
my $qh=$dbh->prepare($query);
|
|
|
|
$qh->execute();
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2021-12-12 14:06:36 +00:00
|
|
|
while (my ($edition,$centre,$paramId,$attribute,$value,$name,$shortName)=$qh->fetchrow_array )
|
|
|
|
{
|
2024-01-24 12:19:40 +00:00
|
|
|
if ($centre eq "wmo" ) { $conceptDir=""; }
|
2013-03-25 12:04:10 +00:00
|
|
|
else { $conceptDir="/localConcepts/$centre"; }
|
|
|
|
|
|
|
|
if ($filebase ne "$basedir/grib$edition$conceptDir") {
|
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
$filebase="$basedir/grib$edition$conceptDir";
|
2021-12-12 14:06:36 +00:00
|
|
|
mkpath($filebase);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
copy("$filebase/paramId.def","$filebase/paramId.def.bkp")
|
2021-12-12 14:06:36 +00:00
|
|
|
or die ("unable to copy $filebase/paramId.def");
|
2013-03-25 12:04:10 +00:00
|
|
|
open($out,"> $filebase/paramId.def")
|
|
|
|
or die "unable to open $filebase/paramId.def";
|
2015-12-11 18:08:30 +00:00
|
|
|
print $out "# Automatically generated by $0, do not edit\n";
|
2013-03-25 12:04:10 +00:00
|
|
|
$p=();
|
|
|
|
}
|
2021-12-12 14:06:36 +00:00
|
|
|
if ($p ne $paramId || exists($seen{$attribute}) ) {
|
|
|
|
if ($p) { print $out "\t}\n"; }
|
|
|
|
print $out "#$name\n" ;
|
|
|
|
print $out "\'".$paramId."\' = {\n" ;
|
|
|
|
$p=$paramId;
|
|
|
|
%seen=();
|
|
|
|
}
|
|
|
|
$seen{$attribute}=1;
|
|
|
|
print "$edition,$centre,$shortName,$paramId,$name,$attribute,$value\n";
|
|
|
|
print $out "\t $attribute = $value ;\n" ;
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
if ($filebase) {
|
|
|
|
print $out "}\n";
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub create_def_old {
|
2021-12-12 14:06:36 +00:00
|
|
|
my ($key,$query)=@_;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2021-12-12 14:06:36 +00:00
|
|
|
my $qh=$dbh->prepare($query);
|
|
|
|
$qh->execute();
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2021-12-12 14:06:36 +00:00
|
|
|
while (my ($edition,$centre,$paramId,$value)=$qh->fetchrow_array )
|
|
|
|
{
|
2024-01-24 12:19:40 +00:00
|
|
|
if ($centre eq "wmo" ) { $conceptDir=""; }
|
2013-03-25 12:04:10 +00:00
|
|
|
else { $conceptDir="/localConcepts/$centre"; }
|
|
|
|
|
|
|
|
if ($filebase ne "$basedir/grib$edition$conceptDir") {
|
|
|
|
if ($filebase) {
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
$filebase="$basedir/grib$edition$conceptDir";
|
2021-12-12 14:06:36 +00:00
|
|
|
mkpath($filebase);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
copy("$filebase/$key.def","$filebase/$key.def.bkp")
|
2021-12-12 14:06:36 +00:00
|
|
|
or die ("unable to copy $filebase/$key.def");
|
2013-03-25 12:04:10 +00:00
|
|
|
open($out,"> $filebase/$key.def")
|
|
|
|
or die "unable to open $filebase/$key.def";
|
2015-12-11 18:08:30 +00:00
|
|
|
print $out "# Automatically generated by $0, do not edit\n";
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
2021-12-12 14:06:36 +00:00
|
|
|
print $out "\'$value\' \t= { paramId=$paramId; }\n";
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
if ($filebase) {
|
|
|
|
close $out;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
create_def("paramId");
|
|
|
|
create_def("shortName");
|
|
|
|
create_def("name");
|
|
|
|
create_def("units");
|
2024-08-02 11:37:53 +00:00
|
|
|
create_cfVarName("cfVarName");
|
2020-11-18 22:11:16 +00:00
|
|
|
create_cfName("cfName");
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# #create_paramId_def();
|
|
|
|
|
|
|
|
# $query="select distinct edition,centre.abbreviation,param_id,param.shortName from param,grib_encoding,centre where
|
|
|
|
# param.hide_def=0 and
|
|
|
|
# param.id=grib_encoding.param_id and
|
|
|
|
# centre.id=grib_encoding.centre_id and
|
|
|
|
# shortName!='~' order by abbreviation,edition,param.o,param.id,shortName";
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# #select distinct edition,centre.abbreviation,param_id,param.shortName
|
|
|
|
# #from param,grib_encoding,grib,centre where param.hide_def=0 and param.id=grib.param_id and
|
|
|
|
# #centre.id=grib_encoding.centre_id and shortName!='~'
|
|
|
|
# #order by centre,edition,param.o,param_id";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# #create_def("shortName",$query);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# $query="select distinct edition,centre.abbreviation,param_id,param.name
|
|
|
|
# from param,grib,centre where param.hide_def=0 and param.id=grib.param_id and
|
|
|
|
# centre.id=grib.centre and shortName!='~'
|
|
|
|
# order by centre,edition,param.o,param_id";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# #create_def("name",$query);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# $query="select distinct edition,centre.abbreviation,param_id,units.name
|
|
|
|
# from param,grib,centre,units where param.hide_def=0 and param.id=grib.param_id and units.id=param.units_id
|
|
|
|
# and centre.id=grib.centre and shortName!='~'
|
|
|
|
# order by centre,edition,param.o,param_id";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2024-01-24 12:19:40 +00:00
|
|
|
# #create_def("units",$query);
|
2013-03-25 12:04:10 +00:00
|
|
|
|