ddraw: Validate structure pointers and sizes in IDirect3D3::FindDevice.
[wine/testsucceed.git] / tools / winapi / util.pm
blob6697d56c2ecd925075487131ce1a6fbb0c989c28
2 # Copyright 1999, 2000, 2001 Patrik Stridvall
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License, or (at your option) any later version.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 package util;
21 use strict;
23 use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
24 require Exporter;
26 @ISA = qw(Exporter);
27 @EXPORT = qw(
28 append_file edit_file read_file replace_file
29 normalize_set is_subset
31 @EXPORT_OK = qw();
32 %EXPORT_TAGS = ();
34 ########################################################################
35 # _compare_files
37 sub _compare_files($$) {
38 my $file1 = shift;
39 my $file2 = shift;
41 local $/ = undef;
43 return -1 if !open(IN, "< $file1");
44 my $s1 = <IN>;
45 close(IN);
47 return 1 if !open(IN, "< $file2");
48 my $s2 = <IN>;
49 close(IN);
51 return $s1 cmp $s2;
54 ########################################################################
55 # append_file
57 sub append_file($$@) {
58 my $filename = shift;
59 my $function = shift;
61 open(OUT, ">> $filename") || die "Can't open file '$filename'";
62 my $result = &$function(\*OUT, @_);
63 close(OUT);
65 return $result;
68 ########################################################################
69 # edit_file
71 sub edit_file($$@) {
72 my $filename = shift;
73 my $function = shift;
75 open(IN, "< $filename") || die "Can't open file '$filename'";
76 open(OUT, "> $filename.tmp") || die "Can't open file '$filename.tmp'";
78 my $result = &$function(\*IN, \*OUT, @_);
80 close(IN);
81 close(OUT);
83 if($result) {
84 unlink("$filename");
85 rename("$filename.tmp", "$filename");
86 } else {
87 unlink("$filename.tmp");
90 return $result;
93 ########################################################################
94 # read_file
96 sub read_file($$@) {
97 my $filename = shift;
98 my $function = shift;
100 open(IN, "< $filename") || die "Can't open file '$filename'";
101 my $result = &$function(\*IN, @_);
102 close(IN);
104 return $result;
107 ########################################################################
108 # replace_file
110 sub replace_file($$@) {
111 my $filename = shift;
112 my $function = shift;
114 open(OUT, "> $filename.tmp") || die "Can't open file '$filename.tmp'";
116 my $result = &$function(\*OUT, @_);
118 close(OUT);
120 if($result && _compare_files($filename, "$filename.tmp")) {
121 unlink("$filename");
122 rename("$filename.tmp", $filename);
123 } else {
124 unlink("$filename.tmp");
127 return $result;
130 ########################################################################
131 # normalize_set
133 sub normalize_set($) {
134 local $_ = shift;
136 if(!defined($_)) {
137 return undef;
140 my %hash = ();
141 foreach my $key (split(/\s*&\s*/)) {
142 $hash{$key}++;
145 return join(" & ", sort(keys(%hash)));
148 ########################################################################
149 # is_subset
151 sub is_subset($$) {
152 my $subset = shift;
153 my $set = shift;
155 foreach my $subitem (split(/ & /, $subset)) {
156 my $match = 0;
157 foreach my $item (split(/ & /, $set)) {
158 if($subitem eq $item) {
159 $match = 1;
160 last;
163 if(!$match) {
164 return 0;
167 return 1;