mirror of https://github.com/F-Stack/f-stack.git
73 lines
2.4 KiB
Perl
73 lines
2.4 KiB
Perl
#!/usr/bin/perl
|
|
use strict;
|
|
use warnings;
|
|
use IPC::Open2;
|
|
my $pid;
|
|
|
|
open(my $lsfiles, "-|", "git ls-files -s") or die "fork lsfiles: $!";
|
|
|
|
while (<$lsfiles>) {
|
|
if ($_ =~ m/^120000 ([0-9a-f]{40}) (.*)\t(.*)/) {
|
|
my ($obj, $stage, $path) = ($1,$2,$3);
|
|
if (!defined $pid) {
|
|
$pid = open2(*Rderef, *Wderef, "git cat-file --batch-check='deref-ok %(objectname)' --follow-symlinks")
|
|
or die "open git cat-file: $!";
|
|
}
|
|
print Wderef "$ENV{GIT_COMMIT}:$path\n" or die "write Wderef: $!";
|
|
my $deref = <Rderef>;
|
|
if ($deref =~ m/^deref-ok ([0-9a-f]{40})$/) {
|
|
$_ = "100644 $1 $stage\t$path\n"
|
|
} elsif ($deref =~ /^dangling /) {
|
|
# Skip next line
|
|
my $dummy = <Rderef>;
|
|
} else {
|
|
die "Failed to parse symlink $ENV{GIT_COMMIT}:$path $deref";
|
|
}
|
|
}
|
|
|
|
my $m = 0;
|
|
|
|
# Keep the copyright. Also ensures we never have a completely empty commit.
|
|
$m++ if m/\tCOPYING$/;
|
|
|
|
# A few architectures have dts files at non standard paths. Massage those into
|
|
# a standard arch/ARCH/boot/dts first.
|
|
|
|
# symlink: arch/microblaze/boot/dts/system.dts -> ../../platform/generic/system.dts
|
|
next if m,\tarch/microblaze/boot/dts/system.dts$,;
|
|
$m++ if s,\tarch/microblaze/platform/generic/(system.dts)$,\tarch/microblaze/boot/dts/$1,;
|
|
|
|
# arch/mips/lantiq/dts/easy50712.dts
|
|
# arch/mips/lantiq/dts/danube.dtsi
|
|
# arch/mips/netlogic/dts/xlp_evp.dts
|
|
# arch/mips/ralink/dts/rt3050.dtsi
|
|
# arch/mips/ralink/dts/rt3052_eval.dts
|
|
$m++ if s,\tarch/mips/([^/]*)/dts/(.*\.dts.?)$,\tarch/mips/boot/dts/$2,;
|
|
|
|
# arch/mips/cavium-octeon/octeon_68xx.dts
|
|
# arch/mips/cavium-octeon/octeon_3xxx.dts
|
|
# arch/mips/mti-sead3/sead3.dts
|
|
$m++ if s,\tarch/mips/([^/]*)/([^/]*\.dts.?)$,\tarch/mips/boot/dts/$2,;
|
|
|
|
# arch/x86/platform/ce4100/falconfalls.dts
|
|
$m++ if s,\tarch/x86/platform/ce4100/falconfalls.dts,\tarch/x86/boot/dts/falconfalls.dts,;
|
|
|
|
# test cases
|
|
$m++ if s,\tdrivers/of/testcase-data/,\ttestcase-data/,;
|
|
|
|
# Now rewrite generic DTS paths
|
|
$m++ if s,\tarch/([^/]*)/boot/dts/(.*\.dts.?)$,\tsrc/$1/$2,;
|
|
$m++ if s,\tarch/([^/]*)/boot/dts/(.*\.h)$,\tsrc/$1/$2,;
|
|
|
|
# Also rewrite the DTS include paths for dtc+cpp support
|
|
$m++ if s,\tarch/([^/]*)/include/dts/,\tsrc/$1/include/,;
|
|
$m++ if s,\tinclude/dt-bindings/,\tinclude/dt-bindings/,;
|
|
|
|
# Rewrite the bindings subdirectory
|
|
$m++ if s,\tDocumentation/devicetree/bindings/,\tBindings/,;
|
|
|
|
print if $m > 0;
|
|
}
|
|
kill $pid if $pid;
|
|
exit 0;
|