[go: up one dir, main page]

File: cpfmerge

package info (click to toggle)
ale 0.9.0.3-5
  • links: PTS
  • area: main
  • in suites: bookworm, bullseye
  • size: 7,260 kB
  • sloc: cpp: 21,826; sh: 10,106; xml: 4,129; ansic: 2,343; makefile: 563; perl: 454; exp: 319
file content (74 lines) | stat: -rwxr-xr-x 1,966 bytes parent folder | download | duplicates (6)
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
#!/usr/bin/perl -w

# Copyright 2005 David Hilvert <dhilvert@auricle.dyndns.org>,
#                              <dhilvert@ugcs.caltech.edu>

#  This file is part of the Anti-Lamenessing Engine.
#
#  The Anti-Lamenessing Engine 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 3 of the License, or
#  (at your option) any later version.
#
#  The Anti-Lamenessing Engine 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 Anti-Lamenessing Engine; if not, write to the Free Software
#  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

#
# Script to merge ALE cpf files.  Assumes that the first columns of all files
# refer to points in the first frame in the sequence.  These are written as the
# first column in the output, followed by the first file's columns, and then
# the second file's columns, etc.
#

print "V 0\n";

$data_count = 0;

foreach (@ARGV) {
	@file_lines = `cat $_`;

	$first_data_line = 1;
	$old_data_count = $data_count;

	%used_keys = ();

	foreach (@file_lines) {
		/^A (\d+ \d+) (.*)$/ or next;

		$key = $1;
		$data = $2;

		if ($first_data_line) {
			$data_copy = $data;
			while ($data_copy =~ s/^\d+ \d+(.*)$/$1/) {
				$data_count++;
			}
			$first_data_line = 0;
		}

		next if ($used_keys{$key});

		if (!defined($points{$key})) {
			$points{$key} = " nan nan" x $old_data_count;
		}

		$points{$key} .= " $data";
		$used_keys{$key} = 1;
	}

	foreach $key (keys %points) {
		if (!defined($used_keys{$key})) {
			$points{$key} .= " nan nan";
		}
	}
}

foreach $key (keys %points) {
	print "A $key" . "$points{$key}\n";
}