File:
[LON-CAPA] /
loncom /
xml /
style.pm
Revision
1.22:
download - view:
text,
annotated -
select for diffs
Mon Nov 24 18:55:01 2008 UTC (16 years, 3 months ago) by
jms
Branches:
MAIN
CVS tags:
version_2_9_X,
version_2_9_99_0,
version_2_9_1,
version_2_9_0,
version_2_8_99_1,
version_2_8_99_0,
version_2_12_X,
version_2_11_X,
version_2_11_6_msu,
version_2_11_6,
version_2_11_5_msu,
version_2_11_5,
version_2_11_4_uiuc,
version_2_11_4_msu,
version_2_11_4,
version_2_11_3_uiuc,
version_2_11_3_msu,
version_2_11_3,
version_2_11_2_uiuc,
version_2_11_2_msu,
version_2_11_2_educog,
version_2_11_2,
version_2_11_1,
version_2_11_0_RC3,
version_2_11_0_RC2,
version_2_11_0_RC1,
version_2_11_0,
version_2_10_X,
version_2_10_1,
version_2_10_0_RC2,
version_2_10_0_RC1,
version_2_10_0,
loncapaMITrelate_1,
language_hyphenation_merge,
language_hyphenation,
bz6209-base,
bz6209,
bz5969,
bz2851,
PRINT_INCOMPLETE_base,
PRINT_INCOMPLETE,
HEAD,
GCI_3,
GCI_2,
BZ5971-printing-apage,
BZ5434-fox,
BZ4492-merge,
BZ4492-feature_horizontal_radioresponse
Added/modified POD comments
1: # The LearningOnline Network with CAPA
2: # Style Parser Module (new version)
3: #
4: # $Id: style.pm,v 1.22 2008/11/24 18:55:01 jms Exp $
5: #
6: # Copyright Michigan State University Board of Trustees
7: #
8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
9: #
10: # LON-CAPA is free software; you can redistribute it and/or modify
11: # it under the terms of the GNU General Public License as published by
12: # the Free Software Foundation; either version 2 of the License, or
13: # (at your option) any later version.
14: #
15: # LON-CAPA is distributed in the hope that it will be useful,
16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18: # GNU General Public License for more details.
19: #
20: # You should have received a copy of the GNU General Public License
21: # along with LON-CAPA; if not, write to the Free Software
22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23: #
24: # /home/httpd/html/adm/gpl.txt
25: #
26: # http://www.lon-capa.org/
27: #
28: # Copyright for TtHfunc and TtMfunc by Ian Hutchinson.
29: # TtHfunc and TtMfunc (the "Code") may be compiled and linked into
30: # binary executable programs or libraries distributed by the
31: # Michigan State University (the "Licensee"), but any binaries so
32: # distributed are hereby licensed only for use in the context
33: # of a program or computational system for which the Licensee is the
34: # primary author or distributor, and which performs substantial
35: # additional tasks beyond the translation of (La)TeX into HTML.
36: # The C source of the Code may not be distributed by the Licensee
37: # to any other parties under any circumstances.
38: #
39: # written 01/08/01 by Alexander Sakharuk
40: #
41:
42: package Apache::style;
43:
44: use strict;
45: use HTML::TokeParser;
46:
47: sub styleparser {
48:
49: my ($target,$content_style_string)=@_;
50: my @keys = ();
51: my @values = ();
52: my $current_value;
53: my $allow=0;
54: my $pstyle = HTML::TokeParser->new(\$content_style_string);
55: $pstyle->xml_mode('1');
56: while (my $stoken = $pstyle->get_token) {
57: if (($stoken->[0] eq 'S') && ($stoken->[1] eq 'definetag')) {
58: push @keys,$stoken->[2]->{'name'};
59: $current_value='';
60: $allow=0;
61: } elsif (($stoken->[0] eq 'E') && ($stoken->[1] eq 'definetag')) {
62: $current_value =~ s/(\s)+/$1/g;
63: $current_value =~ s/\n//g;
64: push(@values,$current_value);
65: } elsif (($target eq 'meta') && ($stoken->[0] eq 'S') && ($stoken->[1] eq 'meta')) {
66: $allow=1;
67: } elsif (($target eq 'meta') && ($stoken->[0] eq 'E') && ($stoken->[1] eq 'meta')) {
68: $allow=0;
69: } elsif (($target ne 'meta') && ($stoken->[0] eq 'S') && ($stoken->[1] eq 'render')) {
70: $allow=1;
71: } elsif (($target ne 'meta') && ($stoken->[0] eq 'E') && ($stoken->[1] eq 'render')) {
72: $allow=0;
73: } elsif (($target ne 'meta') && ($target ne 'web') && ($stoken->[0] eq 'S') && ($stoken->[1] eq 'web')) {
74: $allow=0;
75: } elsif (($target ne 'meta') && ($target ne 'web') && ($stoken->[0] eq 'E') && ($stoken->[1] eq 'web')) {
76: $allow=1;
77: } elsif (($target ne 'meta') && ($target ne 'tex') && ($stoken->[0] eq 'S') && ($stoken->[1] eq 'tex')) {
78: $allow=0;
79: } elsif (($target ne 'meta') && ($target ne 'tex') && ($stoken->[0] eq 'E') && ($stoken->[1] eq 'tex')) {
80: $allow=1;
81: } elsif (($stoken->[0] eq 'S') && ($stoken->[1] eq 'target') && (not $stoken->[2]->{'name'}=~/(^\s*$target\s*,|,\s*$target\s*,|,\s*$target\s*$|^\s*$target\s*$)/)) {
82: $allow=0;
83: } elsif (($stoken->[0] eq 'E') && ($stoken->[1] eq 'target')) {
84: $allow=1;
85: } elsif (($target ne 'meta') && ($stoken->[0] eq 'S') && ($stoken->[1] eq $target)) {
86: $allow=1;
87: } elsif (($target ne 'meta') && ($stoken->[0] eq 'E') && ($stoken->[1] eq $target)) {
88: } elsif (($stoken->[0] eq 'S') && ($stoken->[1] eq 'target') && ($stoken->[2]->{'name'}=~/(^\s*$target\s*,|,\s*$target\s*,|,\s*$target\s*$|^\s*$target\s*$)/)) {
89: $allow=1;
90: } elsif ($allow) {
91: if ($stoken->[0] eq 'T') {
92: $current_value .= $stoken->[1];
93: } elsif ($stoken->[0] eq 'S') {
94: my $number=-1;
95: if ($stoken->[1] ne $keys[-1]) {
96: $number = &testkey($stoken->[0],$stoken->[1],@keys);
97: }
98: if ($number != -1) {
99: $current_value .= &testvalue($number,$stoken->[0],$stoken->[2],@values);
100: } else {
101: $current_value .= $stoken->[4];
102: }
103: } elsif ($stoken->[0] eq 'E') {
104: my $number=-1;
105: if (('/'.$stoken->[1]) ne $keys[-1]) {
106: $number = &testkey($stoken->[0],$stoken->[1],@keys);
107: }
108: if ($number != -1) {
109: $current_value .= &testvalue($number,$stoken->[0],$stoken->[2],@values);
110: } else {
111: $current_value .= $stoken->[2];
112: }
113: }
114: }
115: }
116: my %style_for_target;
117: for (my $i=0; $i<=$#keys; $i++) {
118: if ($values[$i] !~ /^\s*$/) {
119: $style_for_target{$keys[$i]}=$values[$i];
120: }
121: }
122: return %style_for_target;
123: }
124:
125:
126: sub testkey {
127:
128: my ($zeroth,$first,@keys) = @_;
129: my $number = -1;
130: if ($zeroth eq 'S') {
131: for (my $i=$#keys; $i>=0; $i=$i-1) {
132: if ($first eq lc($keys[$i])) {
133: $number = $i;
134: last;
135: }
136: }
137: } elsif ($zeroth eq 'E') {
138: for (my $i=$#keys; $i>=0; $i=$i-1) {
139: if ('/'.$first eq lc($keys[$i])) {
140: $number = $i;
141: last;
142: }
143: }
144: }
145: return $number;
146: }
147:
148: sub testvalue {
149:
150: my ($number,$zeroth,$second,@values) = @_;
151: my $current_content = $values[$number];
152: if ($zeroth eq 'S') {
153: my %tempo_hash = %$second;
154: while ((my $current_k,my $current_v) = each %tempo_hash) {
155: $current_content =~ s/\$$current_k/$current_v/g;
156: }
157: } elsif ($zeroth eq 'E') {
158: $current_content = $values[$number];
159: }
160: return $current_content;
161: }
162:
163: 1;
164:
165: __END__
166:
167: =pod
168:
169: =head1 NAME
170:
171: Apache::style.pm
172:
173: =head1 SYNOPSIS
174:
175: Style parsing module
176:
177: This is part of the LearningOnline Network with CAPA project
178: described at http://www.lon-capa.org.
179:
180:
181: =head1 SUBROUTINES
182:
183: =over
184:
185: =item styleparser()
186:
187: =item testkey()
188:
189: =item testvalue()
190:
191: =back
192:
193: =cut
194:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>