$ret .= ")";
my @attrs;
if ( $flags =~ /r/ ) {
- push @attrs, "__attribute__((noreturn))";
+ push @attrs, "__attribute__noreturn__";
}
if ( $flags =~ /a/ ) {
- push @attrs, "__attribute__((malloc))";
+ push @attrs, "__attribute__malloc__";
$flags .= "R"; # All allocing must check return value
}
if ( $flags =~ /R/ ) {
- push @attrs, "__attribute__((warn_unused_result))";
+ push @attrs, "__attribute__warn_unused_result__";
}
if ( $flags =~ /P/ ) {
- push @attrs, "__attribute__((pure))";
+ push @attrs, "__attribute__pure__";
}
if( $flags =~ /f/ ) {
my $prefix = $has_context ? 'pTHX_' : '';
}
if ( @nonnull ) {
my @pos = map { $has_context ? "pTHX_$_" : $_ } @nonnull;
- push @attrs, sprintf( "__attribute__((nonnull(%s)))", join( ",", @pos ) );
+ push @attrs, map { sprintf( "__attribute__nonnull__(%s)", $_ ) } @pos;
}
if ( @attrs ) {
$ret .= "\n";
#define PERLVARIC(v,t,i) PERLVAR(v,t)
#define PERLVARISC(v,i) PERLVAR(v,char)
+/* In Tru64 (__DEC && __osf__) the cc option -std1 causes that one
+ * cannot cast between void pointers and function pointers without
+ * info level warnings. The PL_force_link_funcs[] would cause a few
+ * hundred of those warnings. In code one can circumnavigate this by using
+ * unions that overlay the different pointers, but in declarations one
+ * cannot use this trick. Therefore we just disable the warning here
+ * for the duration of the PL_force_link_funcs[] declaration. */
+
+#if defined(__DECC) && defined(__osf__)
+#pragma message save
+#pragma message disable (nonstandcast)
+#endif
+
#include "thrdvar.h"
#include "intrpvar.h"
#include "perlvars.h"
+#if defined(__DECC) && defined(__osf__)
+#pragma message restore
+#endif
+
#undef PERLVAR
#undef PERLVARA
#undef PERLVARI