⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gentag.t

📁 source of perl for linux application,
💻 T
字号:
BEGIN {    if ($ENV{PERL_CORE}) {        chdir('t') if -d 't';        @INC = qw(../lib);    }}# Before `make install' is performed this script should be runnable with# `make test'. After `make install' it should work as `perl test.pl'######################### We start with some black magic to print on failure.# Change 1..1 below to 1..last_test_to_print .# (It may become useful if the test is moved to ./t subdirectory.)BEGIN { $| = 1; print "1..37\n"; }END {print "not ok 1\n" unless $loaded;}use Text::Balanced qw ( gen_extract_tagged );$loaded = 1;print "ok 1\n";$count=2;use vars qw( $DEBUG );sub debug { print "\t>>>",@_ if $DEBUG }######################### End of black magic.$cmd = "print";$neg = 0;while (defined($str = <DATA>)){	chomp $str;	$str =~ s/\\n/\n/g;	if ($str =~ s/\A# USING://)	{		$neg = 0;		eval{local$^W;*f = eval $str || die};		next;	}	elsif ($str =~ /\A# TH[EI]SE? SHOULD FAIL/) { $neg = 1; next; }	elsif (!$str || $str =~ /\A#/) { $neg = 0; next }	$str =~ s/\\n/\n/g;	debug "\tUsing: $cmd\n";	debug "\t   on: [$str]\n";	my @res;	$var = eval { @res = f($str) };	debug "\t list got: [" . join("|",map {defined $_ ? $_ : '<undef>'} @res) . "]\n";	debug "\t list left: [$str]\n";	print "not " if (substr($str,pos($str)||0,1) eq ';')==$neg;	print "ok ", $count++;	print " ($@)" if $@ && $DEBUG;	print "\n";	pos $str = 0;	$var = eval { scalar f($str) };	$var = "<undef>" unless defined $var;	debug "\t scalar got: [$var]\n";	debug "\t scalar left: [$str]\n";	print "not " if ($str =~ '\A;')==$neg;	print "ok ", $count++;	print " ($@)" if $@ && $DEBUG;	print "\n";}__DATA__# USING: gen_extract_tagged('{','}');	{ a test };# USING: gen_extract_tagged(qr/<[A-Z]+>/,undef, undef, {ignore=>["<BR>"]});	<A>aaa<B>bbb<BR>ccc</B>ddd</A>;# USING: gen_extract_tagged("BEGIN","END");	BEGIN at the BEGIN keyword and END at the END;	BEGIN at the beginning and end at the END;# USING: gen_extract_tagged(undef,undef,undef,{ignore=>["<[^>]*/>"]});	<A>aaa<B>bbb<BR/>ccc</B>ddd</A>;# USING: gen_extract_tagged(";","-",undef,{reject=>[";"],fail=>"MAX"});	; at the ;-) keyword# USING: gen_extract_tagged("<[A-Z]+>",undef, undef, {ignore=>["<BR>"]});	<A>aaa<B>bbb<BR>ccc</B>ddd</A>;# THESE SHOULD FAIL	BEGIN at the beginning and end at the end;	BEGIN at the BEGIN keyword and END at the end;# TEST EXTRACTION OF TAGGED STRINGS# USING: gen_extract_tagged("BEGIN","END",undef,{reject=>["BEGIN","END"]});# THESE SHOULD FAIL	BEGIN at the BEGIN keyword and END at the end;# USING: gen_extract_tagged(";","-",undef,{reject=>[";"],fail=>"PARA"});	; at the ;-) keyword# USING: gen_extract_tagged();	<A>some text</A>;	<B>some text<A>other text</A></B>;	<A>some text<A>other text</A></A>;	<A HREF="#section2">some text</A>;# THESE SHOULD FAIL	<A>some text	<A>some text<A>other text</A>;	<B>some text<A>other text</B>;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -