-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile.PL
103 lines (99 loc) · 4.23 KB
/
Makefile.PL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
use 5.014002;
use Devel::CheckLib;
check_lib_or_exit( lib => 'rados', header => 'rados/librados.h' );
use ExtUtils::MakeMaker;
use File::Copy;
use File::Spec;
use File::Which;
# See lib/ExtUtils/MakeMaker.pm for details of how to influence
# the contents of the Makefile that is written.
my $gnulike_p = which('gcc') && -e '/dev/null';
WriteMakefile(
NAME => 'Ceph::Rados',
VERSION_FROM => 'lib/Ceph/Rados.pm', # finds $VERSION
CONFIGURE_REQUIRES => {
'Devel::CheckLib' => 0,
'ExtUtils::MakeMaker' => 0,
'File::Which' => 0,
($gnulike_p ?
('C::Scan::Constants' => 0) :
('ExtUtils::Constant' => 0)
),
}, # e.g., Module::Name => 1.1
TEST_REQUIRES => {
'Test::More' => 0,
'Test::Exception' => 0,
'Test::SharedFork' => 0,
'Data::Dump' => 0,
},
ABSTRACT_FROM => 'lib/Ceph/Rados.pm', # retrieve abstract from module
AUTHOR => 'Alex <alex@openimp.com>',
LIBS => ['-lrados'], # e.g., '-lm'
DEFINE => '', # e.g., '-DHAVE_SOMETHING'
INC => '-I.', # e.g., '-I. -I/usr/include/other'
# Un-comment this if you add C files to link with later:
# OBJECT => '$(O_FILES)', # link all the C files too
);
if ($gnulike_p) {
eval {require C::Scan::Constants};
# looks like we're on something Gnu-like, attempt to find rados header file
# and generate constants from it
my $output = `echo '#include <rados/librados.h>' | cpp -H -o /dev/null 2>&1 | head -n1`;
# drop out to fallback if we get an error
goto FALLBACK if $output =~ m/clang: error/;
my ($path) = ($output =~ m!^\. (.*)$!);
my @constants = C::Scan::Constants::extract_constants_from( $path );
@constants = grep { $_ ne 'CEPH_LIBRADOS_H' and
$_ ne 'CEPH_RADOS_API' and
$_ ne 'VOIDPTR_RADOS_T'} @constants;
# suppress help to STDERR
open SAVERR, ">&STDERR";
open STDERR, ">/dev/null";
C::Scan::Constants::write_constants_module( "Ceph::Rados", @constants );
open STDERR, ">&SAVERR";
close SAVERR;
}
elsif (eval {require ExtUtils::Constant; 1}) {
# If you edit these definitions to change the constants used by this module,
# you will need to use the generated const-c.inc and const-xs.inc
# files to replace their "fallback" counterparts before distributing your
# changes.
my @names = (qw(CEPH_OSD_TMAP_CREATE CEPH_OSD_TMAP_HDR CEPH_OSD_TMAP_RM
CEPH_OSD_TMAP_SET LIBRADOS_CREATE_EXCLUSIVE
LIBRADOS_CREATE_IDEMPOTENT LIBRADOS_LOCK_FLAG_RENEW
LIBRADOS_OP_FLAG_EXCL LIBRADOS_OP_FLAG_FAILOK
LIBRADOS_SNAP_DIR LIBRADOS_SNAP_HEAD LIBRADOS_SUPPORTS_WATCH
LIBRADOS_VERSION_CODE LIBRADOS_VER_EXTRA LIBRADOS_VER_MAJOR
LIBRADOS_VER_MINOR),
{name=>"LIBRADOS_CMPXATTR_OP_EQ", macro=>"1"},
{name=>"LIBRADOS_CMPXATTR_OP_GT", macro=>"1"},
{name=>"LIBRADOS_CMPXATTR_OP_GTE", macro=>"1"},
{name=>"LIBRADOS_CMPXATTR_OP_LT", macro=>"1"},
{name=>"LIBRADOS_CMPXATTR_OP_LTE", macro=>"1"},
{name=>"LIBRADOS_CMPXATTR_OP_NE", macro=>"1"},
{name=>"LIBRADOS_OPERATION_BALANCE_READS", macro=>"1"},
{name=>"LIBRADOS_OPERATION_IGNORE_CACHE", macro=>"1"},
{name=>"LIBRADOS_OPERATION_IGNORE_OVERLAY", macro=>"1"},
{name=>"LIBRADOS_OPERATION_LOCALIZE_READS", macro=>"1"},
{name=>"LIBRADOS_OPERATION_NOFLAG", macro=>"1"},
{name=>"LIBRADOS_OPERATION_ORDER_READS_WRITES", macro=>"1"},
{name=>"LIBRADOS_OPERATION_SKIPRWLOCKS", macro=>"1"});
ExtUtils::Constant::WriteConstants(
NAME => 'Ceph::Rados',
NAMES => \@names,
DEFAULT_TYPE => 'IV',
C_FILE => 'const-c.inc',
XS_FILE => 'const-xs.inc',
);
}
# we don't want to blow up on missing const files, ever
FALLBACK:
foreach my $file ('const-c.inc', 'const-xs.inc') {
if (!-e $file) {
my $fallback = File::Spec->catfile('fallback', $file);
copy ($fallback, $file) or die "Can't copy $fallback to $file: $!";
}
}
sub MY::postamble {
return "\$(XS_FILES): ".join(" ", <XS/*.xs>)."\n\ttouch \$(XS_FILES)";
}