summaryrefslogtreecommitdiff
path: root/scripts/Dpkg/Build/Types.pm
diff options
context:
space:
mode:
authorGuillem Jover <guillem@debian.org>2016-01-29 22:46:11 +0100
committerGuillem Jover <guillem@debian.org>2016-02-15 02:10:45 +0100
commit6e28595c2dd54f38b7e005355692996179e2c557 (patch)
treeaf7a0e0787dc686d5477373e435c1a1dc0f87ee5 /scripts/Dpkg/Build/Types.pm
parentba511d919ea9bfe727fefb897a5503be93f1cade (diff)
downloaddpkg-6e28595c2dd54f38b7e005355692996179e2c557.tar.gz
Dpkg::Build::Types: Add new module
Diffstat (limited to 'scripts/Dpkg/Build/Types.pm')
-rw-r--r--scripts/Dpkg/Build/Types.pm192
1 files changed, 192 insertions, 0 deletions
diff --git a/scripts/Dpkg/Build/Types.pm b/scripts/Dpkg/Build/Types.pm
new file mode 100644
index 000000000..2dda43780
--- /dev/null
+++ b/scripts/Dpkg/Build/Types.pm
@@ -0,0 +1,192 @@
+# Copyright © 2007 Frank Lichtenheld <djpig@debian.org>
+# Copyright © 2010, 2013-2016 Guillem Jover <guillem@debian.org>
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
+
+package Dpkg::Build::Types;
+
+use strict;
+use warnings;
+
+our $VERSION = '0.01';
+our @EXPORT = qw(
+ BUILD_DEFAULT
+ BUILD_SOURCE
+ BUILD_ARCH_DEP
+ BUILD_ARCH_INDEP
+ BUILD_BINARY
+ BUILD_SOURCE_DEP
+ BUILD_SOURCE_INDEP
+ BUILD_FULL
+ build_has
+ build_has_not
+ build_is
+ set_build_type
+);
+
+use Exporter qw(import);
+
+use Dpkg::Gettext;
+use Dpkg::ErrorHandling;
+
+=encoding utf8
+
+=head1 NAME
+
+Dpkg::Build::Types - track build types
+
+=head1 DESCRIPTION
+
+The Dpkg::Build::Types module is used by various tools to track and decide
+what artifacts need to be built.
+
+The build types are bit constants that are exported by default. Multiple
+types can be ORed.
+
+=head1 CONSTANTS
+
+=over 4
+
+=item BUILD_DEFAULT
+
+This build is the default.
+
+=item BUILD_SOURCE
+
+This build includes source artifacts.
+
+=item BUILD_ARCH_DEP
+
+This build includes architecture dependent binary artifacts.
+
+=item BUILD_ARCH_INDEP
+
+This build includes architecture independent binary artifacts.
+
+=item BUILD_BINARY
+
+This build includes binary artifacts.
+
+=item BUILD_SOURCE_DEP
+
+This build includes source and architecture dependent binary artifacts.
+
+=item BUILD_SOURCE_INDEP
+
+This build includes source and architecture independent binary artifacts.
+
+=item BUILD_FULL
+
+This build includes source and binary artifacts.
+
+=cut
+
+# Simple types.
+use constant {
+ BUILD_DEFAULT => 1,
+ BUILD_SOURCE => 2,
+ BUILD_ARCH_DEP => 4,
+ BUILD_ARCH_INDEP => 8,
+};
+
+# Composed types.
+use constant {
+ BUILD_BINARY => BUILD_ARCH_DEP | BUILD_ARCH_INDEP,
+ BUILD_SOURCE_DEP => BUILD_SOURCE | BUILD_ARCH_DEP,
+ BUILD_SOURCE_INDEP => BUILD_SOURCE | BUILD_ARCH_INDEP,
+};
+use constant {
+ BUILD_FULL => BUILD_BINARY | BUILD_SOURCE,
+};
+
+my $current_type = BUILD_FULL | BUILD_DEFAULT;
+my $current_option = undef;
+
+=back
+
+=head1 FUNCTIONS
+
+=over 4
+
+=item build_has($bits)
+
+Return a boolean indicating whether the current build type has the specified
+$bits.
+
+=cut
+
+sub build_has
+{
+ my ($bits) = @_;
+
+ return ($current_type & $bits) == $bits;
+}
+
+=item build_has_not($bits)
+
+Return a boolean indicating whether the current build type does not have the
+specified $bits.
+
+=cut
+
+sub build_has_not
+{
+ my ($bits) = @_;
+
+ return ($current_type & $bits) != $bits;
+}
+
+=item build_is($bits)
+
+Return a boolean indicating whether the current build type is the specified
+set of $bits.
+
+=cut
+
+sub build_is
+{
+ my ($bits) = @_;
+
+ return $current_type == $bits;
+}
+
+=item set_build_type($build_type, $build_option)
+
+Set the current build type to $build_type, which was specified via the
+$build_option command-line option.
+
+=cut
+
+sub set_build_type
+{
+ my ($build_type, $build_option) = @_;
+
+ usageerr(g_('cannot combine %s and %s'), $current_option, $build_option)
+ if build_has_not(BUILD_DEFAULT) and $current_type != $build_type;
+
+ $current_type = $build_type;
+ $current_option = $build_option;
+}
+
+=back
+
+=head1 CHANGES
+
+=head2 Version 0.xx
+
+This is a private module.
+
+=cut
+
+1;