File: Framework.pm

package info (click to toggle)
libfile-bom-perl 0.15-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 180 kB
  • ctags: 23
  • sloc: perl: 692; makefile: 2
file content (125 lines) | stat: -rw-r--r-- 2,335 bytes parent folder | download | duplicates (2)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package Test::Framework;

#
# Common resources for tests
#

use File::Spec::Functions qw( catfile );
use File::Temp qw( tmpnam );
use POSIX qw( mkfifo );

# some of the program text is UTF-8
use utf8;

use base qw( Exporter );

our(%file2path, %file2enc, %filecontent, @test_files, $fifo_supported);

@EXPORT = qw(
	make_test_data
	remove_test_data
	%file2path
	%file2enc
	%filecontent
	@test_files
	write_fifo
	$fifo_supported
	hexdump
    );

%file2enc = (
	'utf-32le.txt' => 'UTF-32LE',
	'utf-32be.txt' => 'UTF-32BE',
	'utf-16le.txt' => 'UTF-16LE',
	'utf-16be.txt' => 'UTF-16BE',
	'utf-8.txt'    => 'UTF-8',
	'no_bom.txt'   => '',
    );
%filecontent = (
	'utf-32le.txt' => 'Ûñíçôđè',
	'utf-32be.txt' => 'Ûñíçôđè',
	'utf-16le.txt' => 'Ûñíçôđè',
	'utf-16be.txt' => 'Ûñíçôđè',
	'utf-8.txt'    => 'Ûñíçôđè',
	'no_bom.txt'   => 'ascii',
    );
@test_files = keys %file2enc;

$file2path{$_} = catfile(qw(t data), $_) for @test_files;

# write data into files
sub make_test_data {
    while (my($name, $path) = each %file2path) {
	my $enc = $file2enc{$name};
	my $mode = $enc ? ">:encoding($enc)" : '>';

	open my $fh, $mode, $path
	    or die "Can't write '$path': $!\n";

	print $fh "\x{feff}" if $enc;
	print $fh $filecontent{$name}, "\n";

	close $fh;
    }
}

sub remove_test_data {
    for my $path (values %file2path) {
	unlink $path or warn "Couldn't remove '$path': $!";
    }
}

eval {
    my $tmp = tmpnam;

    if (mkfifo($tmp, 0700)) {
	unlink $tmp;
    }
    else {
	die $!;
    }
};

if ($@ =~ /^POSIX::mkfifo not implemented on this architecture/) {
    $fifo_supported = 0;
}
else {
    $fifo_supported = 1;
}

sub write_fifo ($) {
    my $bytes = shift;

    my $fifo = tmpnam();

    mkfifo($fifo, 0700) or die "Couldn't create fifo at '$fifo': $!";

    my $pid = fork();
    if ($pid) {
        # I'm the parent
	return ($pid, $fifo);
    }
    elsif (!defined $pid) {
        die "$0: fork: $!";
    }
    else {
        # I'm the child
	if (open my $writer, '>', $fifo) {
	    print $writer $bytes;
	    close $writer;
	}
	else {
	    unlink $fifo or die "Couldn't write or unlink fifo at '$fifo': $!";
	    die "Couldn't write to fifo at '$fifo': $!";
	}

	exit 0;
    }
}

sub hexdump {
    use bytes;
    join(' ', map { unpack("H2", pack("C1", ord)) } split('', $_[0]))
}

1;