File: fmtinsns.pl

package info (click to toggle)
nasm 3.01-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 23,660 kB
  • sloc: ansic: 129,101; asm: 40,471; perl: 8,238; sh: 4,146; makefile: 1,281; xml: 726; python: 582; lisp: 578; sed: 11
file content (40 lines) | stat: -rwxr-xr-x 927 bytes parent folder | download | duplicates (34)
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
#!/usr/bin/perl
#
# Re-align the columns in insns.dat, and enforce case conventions
#

@cols = (0, 16, 48, 96);

while ($line = <STDIN>) {
    chomp $line;
    if ($line !~ /^\s*(\;.*|)$/) {
	($ln = $line) =~ s/\s+$//;
	if ($line =~ /^\s*(\S+)\s+(\S+)\s+(\S+|\[.*\])\s+(\S+)\s*$/) {
	    @fields = ($1, $2, $3, $4);
	    $fields[0] = "\U$fields[0]" unless ($fields[0] =~ /^[^a-z]+cc$/);
	    $fields[3] =~ s/\,+$//;
	    $fields[3] = "\U$fields[3]" unless ($fields[3] eq 'ignore');
	    $c = 0;
	    $line = '';
	    for ($i = 0; $i < scalar(@fields); $i++) {
		if ($i > 0 && $c >= $cols[$i]) {
		    $line .= ' ';
		    $c++;
		}	
		while ($c < $cols[$i]) {
		    $line .= "\t";
		    $c = ($c+8)	& ~7;
		}
		$line .= $fields[$i];
		for ($j = 0; $j < length($fields[$i]); $j++) {
		    if (substr($fields[$i], $j, 1) eq "\t") {
			$c = ($c+8) & ~7;
		    } else {
			$c++;
		    }
		}
	    }
	}
    }
    print $line, "\n";
}