First check in
This commit is contained in:
136
Makefile
Normal file
136
Makefile
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
# This file is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License version 2 as
|
||||||
|
# published by the Free Software Foundation here:
|
||||||
|
# (http://www.gnu.org/licenses/gpl-2.0.html)
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
# Some, but not all of variables are required. The following list
|
||||||
|
# describes the required variables:
|
||||||
|
#
|
||||||
|
# * URL: The main website of the upstream project
|
||||||
|
# * REPO: The location of the package on the source pacakge
|
||||||
|
# server. This might be one of core, main, dev, or
|
||||||
|
# perhaps others.
|
||||||
|
# * BRIEF: Short description, should be 50 chars or less
|
||||||
|
# * SNAPVER: This is the package version. When a package is
|
||||||
|
# changed, but no changes are made to the source code
|
||||||
|
# this value should be increased. This would include
|
||||||
|
# things like usher being modified, changes to default
|
||||||
|
# configuration files, file permissions, etc.
|
||||||
|
# * ARCHIVE: The default commands that set this variable should
|
||||||
|
# work in most cases, but in some cases it may need
|
||||||
|
# to be modified. This variable should contain the
|
||||||
|
# path to the source of the package (./SRC/filename)
|
||||||
|
# * TYPE: This is probably not really needed due to the
|
||||||
|
# ability of gnu tar to figure it out on its own.
|
||||||
|
# Should probably be removed at some point.
|
||||||
|
# * SRCDIR: This is the name of the source directory after the
|
||||||
|
# package source is extracted. The default command
|
||||||
|
# should in most cases set this automatically.
|
||||||
|
# * PATCHDIR: This directory should be ./SRC/patches and is
|
||||||
|
# required, whether or not patches are used.
|
||||||
|
# * VERSION: This should be set automatically based on the
|
||||||
|
# version string in the source directory and SNAPVER.
|
||||||
|
# The default command here should work in many cases,
|
||||||
|
# but certain packages may need to use a different
|
||||||
|
# method.
|
||||||
|
#
|
||||||
|
# Variables that aren't required:
|
||||||
|
#
|
||||||
|
# * ARCH: This should be populated for packages which contain
|
||||||
|
# compiled binaries. If it is not populated the ARCH
|
||||||
|
# will be set to 'noarch'.
|
||||||
|
# * DEPENDS: If any other packages are required for this package
|
||||||
|
# to function then they need to be listed here,
|
||||||
|
# preferably in alphabetical order.
|
||||||
|
# * BUILDDEPS: Any package beyond packages from the core repo
|
||||||
|
# need to be listed here. The idea is that we
|
||||||
|
# can automate building and testing packages
|
||||||
|
# from clean core systems. The core repo is
|
||||||
|
# intended to include only the base minimum
|
||||||
|
# packages which provide a functional system.
|
||||||
|
# * SRCPKG: By default this is populated automatically with
|
||||||
|
# the name of the package (current directory). If
|
||||||
|
# the source package is used to generate multiple
|
||||||
|
# packages then this variable should contain the
|
||||||
|
# name of the git repo that tracks the source.
|
||||||
|
# * DESC: This is to be used to provide a longer description
|
||||||
|
# of the package.
|
||||||
|
|
||||||
|
ARCH =
|
||||||
|
DEPENDS =
|
||||||
|
BUILDDEPS =
|
||||||
|
SRCPKG =
|
||||||
|
URL =
|
||||||
|
REPO =
|
||||||
|
BRIEF =
|
||||||
|
DESC =
|
||||||
|
SNAPVER =
|
||||||
|
|
||||||
|
ARCHIVE := $(PWD)/SRC/$(shell ls SRC|egrep '(bz2|gz|tar|xz)$$'|tail -1)
|
||||||
|
TYPE := $(shell file -ib $(ARCHIVE)|cut -d';' -f1|tr -d '\n')
|
||||||
|
SRCDIR := $(shell tar -tf $(ARCHIVE)|head -1|sed 's/\/.*//')
|
||||||
|
PATCHDIR := $(PWD)/SRC/patches
|
||||||
|
VERSION := $(shell echo $(SRCDIR)|egrep -o '\-[0-9].*'|sed 's/^-//')-$(SNAPVER)
|
||||||
|
|
||||||
|
include /usr/share/snap/Makefile.snaplinux
|
||||||
|
|
||||||
|
$(SRCDIR)/configure: $(ARCHIVE)
|
||||||
|
@if [ '$(TYPE)' == 'application/x-bzip2' ]; then \
|
||||||
|
tar -jxf $(ARCHIVE); \
|
||||||
|
elif [ '$(TYPE)' == 'application/x-gzip' ]; then \
|
||||||
|
tar -zxf $(ARCHIVE); \
|
||||||
|
elif [ '$(TYPE)' == 'application/x-tar' ]; then \
|
||||||
|
tar -xf $(ARCHIVE); \
|
||||||
|
elif [ '$(TYPE)' == 'application/x-xz' ]; then \
|
||||||
|
tar -xf $(ARCHIVE); \
|
||||||
|
else \
|
||||||
|
echo 'Unable to determine archive type'; \
|
||||||
|
exit 1; \
|
||||||
|
fi
|
||||||
|
@touch $(SRCDIR)/configure
|
||||||
|
|
||||||
|
$(SRCDIR)/config.log: $(SRCDIR)/configure
|
||||||
|
@cd $(SRCDIR) && \
|
||||||
|
for patch in `find $(PATCHDIR) -name \*.patch|sort`; do \
|
||||||
|
patch --verbose -Np1 -i $$patch; \
|
||||||
|
done
|
||||||
|
@cd $(SRCDIR); \
|
||||||
|
./configure \
|
||||||
|
--prefix=/usr \
|
||||||
|
--build=x86_64-snap-linux-gnu \
|
||||||
|
--host=x86_64-snap-linux-gnu \
|
||||||
|
--target=x86_64-snap-linux-gnu
|
||||||
|
|
||||||
|
# binfile should be replaced with a file generated by the
|
||||||
|
# make process. It won't really break anything if not
|
||||||
|
# set to a valid file, but the source make process will
|
||||||
|
# be re-executed even if it isn't necessary
|
||||||
|
|
||||||
|
$(SRCDIR)/binfile: $(SRCDIR)/config.log
|
||||||
|
@cd $(SRCDIR) && make
|
||||||
|
|
||||||
|
$(ROOT): $(SRCDIR)/binfile
|
||||||
|
@if [ -d $(ROOT) ]; then \
|
||||||
|
touch $(ROOT); \
|
||||||
|
else \
|
||||||
|
mkdir -v $(ROOT); \
|
||||||
|
fi
|
||||||
|
|
||||||
|
@cd $(SRCDIR) && make install DESTDIR=$(ROOT)
|
||||||
|
|
||||||
|
test: $(ROOT)
|
||||||
|
@cd $(SRCDIR); \
|
||||||
|
make check
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@rm -rvf $(ROOT) \
|
||||||
|
$(SNAPINFO) \
|
||||||
|
$(MANIFEST) \
|
||||||
|
$(FILES) \
|
||||||
|
$(SRCDIR)
|
||||||
|
|
||||||
5
SNAP/README
Normal file
5
SNAP/README
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
This is the directory where the manifest, snapinfo,
|
||||||
|
and files.tar.gz files will be created. It is also
|
||||||
|
where the usher file should be placed if it is
|
||||||
|
required by the package. Any other files that need
|
||||||
|
to be included could also be placed here.
|
||||||
3
SRC/patches/README
Normal file
3
SRC/patches/README
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Place any patch files here and preface each with a
|
||||||
|
number indicating the order of execution. Patch
|
||||||
|
files are expected to use a .patch extension.
|
||||||
79
SRC/snap-tools/gitlist
Executable file
79
SRC/snap-tools/gitlist
Executable file
@@ -0,0 +1,79 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
use Data::Dumper;
|
||||||
|
|
||||||
|
#for b in `git branch --no-color|sed 's/.* //'`; do echo [$b]; for t in `git tag`; do if git branch --contains $t|sed 's/.* //'|grep -q ^$b\$; then echo " $t"; fi; done; done
|
||||||
|
|
||||||
|
sub gitbranches {
|
||||||
|
( my $dir = shift ) =~ s/\/$//;
|
||||||
|
my $branches = {};
|
||||||
|
my $cmd = "git --git-dir=\"$dir/.git\" --work-tree=\"$dir\""
|
||||||
|
. " branch --no-color";
|
||||||
|
|
||||||
|
open( my $git, "$cmd|" ) || die( $! );
|
||||||
|
|
||||||
|
while ( <$git> ) {
|
||||||
|
chomp();
|
||||||
|
|
||||||
|
if ( $_ =~ /\s*\*?\s*(.*)$/ ) {
|
||||||
|
$branches->{$1} = [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
close( $git );
|
||||||
|
|
||||||
|
return( $branches );
|
||||||
|
}
|
||||||
|
|
||||||
|
sub gitcontains {
|
||||||
|
( my $dir = shift ) =~ s/\/$//;
|
||||||
|
my $branches = gitbranches( $dir );
|
||||||
|
my $tags = gittags( $dir );
|
||||||
|
|
||||||
|
foreach my $tag ( @$tags ) {
|
||||||
|
my $cmd = "git --git-dir=\"$dir/.git\" --work-tree=\"$dir\""
|
||||||
|
. " branch --contains \"$tag\"";
|
||||||
|
|
||||||
|
open( my $git, "$cmd|" ) || die( $! );
|
||||||
|
|
||||||
|
while ( <$git> ) {
|
||||||
|
chomp();
|
||||||
|
|
||||||
|
if ( $_ =~ /\s*\*?\s*(.*)$/ ) {
|
||||||
|
push( @{$branches->{$1}}, $tag );
|
||||||
|
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return( $branches );
|
||||||
|
}
|
||||||
|
|
||||||
|
sub gittags {
|
||||||
|
( my $dir = shift ) =~ s/\/$//;
|
||||||
|
my $tags = [];
|
||||||
|
my $cmd = "git --git-dir=\"$dir/.git\" --work-tree=\"$dir\" tag";
|
||||||
|
|
||||||
|
open( my $git, "$cmd|" ) || die( $! );
|
||||||
|
|
||||||
|
while ( <$git> ) {
|
||||||
|
chomp();
|
||||||
|
|
||||||
|
push( @$tags, $_ );
|
||||||
|
}
|
||||||
|
|
||||||
|
close( $git );
|
||||||
|
|
||||||
|
return( $tags );
|
||||||
|
}
|
||||||
|
|
||||||
|
my $branches = gitcontains( $ARGV[0] );
|
||||||
|
|
||||||
|
foreach my $branch ( sort( keys( %$branches ) ) ) {
|
||||||
|
print "[$branch]\n";
|
||||||
|
|
||||||
|
foreach my $tag ( @{$branches->{$branch}} ) {
|
||||||
|
print " $tag\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user