aboutsummaryrefslogtreecommitdiffstats
path: root/docs/buildsignals.pl
diff options
context:
space:
mode:
authorTom Feist <shabble@cowu.be>2010-07-13 20:12:31 +0000
committerTom Feist <shabble@cowu.be>2010-07-13 20:12:31 +0000
commit5f20c8d6f2c4b37c028d075a5fc048c92991ea64 (patch)
treebcff000c271a722ef9f6a633be9dc5794cff5788 /docs/buildsignals.pl
parentstarted marking up signals for auto-generation (diff)
downloadirssi-scripts-5f20c8d6f2c4b37c028d075a5fc048c92991ea64.tar.gz
irssi-scripts-5f20c8d6f2c4b37c028d075a5fc048c92991ea64.zip
reformatting of signals into more useful format for parsing, work on teh signal generator
Diffstat (limited to '')
-rwxr-xr-xdocs/buildsignals.pl168
1 files changed, 152 insertions, 16 deletions
diff --git a/docs/buildsignals.pl b/docs/buildsignals.pl
index 11cd74a..5409ae2 100755
--- a/docs/buildsignals.pl
+++ b/docs/buildsignals.pl
@@ -2,19 +2,28 @@
use strict;
use warnings;
-
+#use Pod::Simple::Debug (3);
use Data::Dumper;
package Pod::Simple::IrssiSignalParser;
use base qw/Pod::Simple::PullParser/;
+use Carp qw/cluck/;
use Data::Dumper;
+sub new {
+ my $self = __PACKAGE__->SUPER::new(@_);
+
+ $self->{__type_mapping} = {};
+ $self->{__signals} = {};
+
+ return bless $self, __PACKAGE__;
+}
sub run {
my $self = shift;
- my ($seen_start, $seen_end) = (0,0);
+ # my ($seen_start, $seen_end) = (0,0);
my $text_token;
Token:
@@ -22,21 +31,157 @@ sub run {
while(my $token = $self->get_token()) {
#print "PRocessing token: $token\n";
- if (!$seen_start && $token->is_start) {
+ if ($token->is_start) {
if ($token->tag eq 'Data') {
- print "Start Data token: $token\n";
+ print "Start Data token: ", $token->dump, "\n";
$text_token = $self->get_token;
+ print "next token: ", $text_token->dump, "\n";
- if ($text_token->is_text && $text_token->text =~ /START/) {
- print "Found start!\n\n";
- $seen_start = 1;
+ if ($text_token->is_text && $text_token->text =~ /START OF (.*)$/) {
+ print "Found start of $1!\n\n";
+ my $type = $1;
+
+ if ($type eq 'SIGNAL TYPES') {
+ $self->process_types;
+ } elsif ($type eq 'SIGNAL DEFINITIONS') {
+ $self->process_definitions;
+ }
}
}
}
}
}
+sub process_types {
+ my $self = shift;
+
+ my $list_ended = 0;
+ my $list_started = 0;
+
+ print "Processing signal types\n";
+
+ while (!$list_ended) {
+
+ my $token = $self->get_token;
+
+ if (!$list_started) {
+ if ($token->is_start && $token->tag eq 'over-text') {
+ $list_started = 1;
+ } else {
+ next;
+ }
+ } else {
+ if ($token->is_end && $token->tag eq 'over-text') {
+ $list_ended = 1;
+ } else {
+ $self->unget_token($token);
+ # do tag processing here
+ print "Processing token ", $token->dump, $/;
+ $self->process_type_entry;
+ }
+ }
+ }
+
+ print "Done Processing signal types\n";
+
+}
+
+sub validate_token {
+ my ($self, $token, $expected, $type) = @_;
+
+ unless ($token->type eq $type && $token->is_tag($expected)) {
+ cluck "Eeek. Expected $expected: $type, got $token->type";
+
+ # cluck("Invalid token. " # on line " . $token->attr('start_line')
+ # . "expected $expected $type, got " . $token->tag
+ # . " " . $token->type . " : " . $token->dump);
+
+ }
+}
+
+sub process_type_entry {
+ my $self = shift;
+
+ my $token = $self->get_token;
+ $self->validate_token($token, 'item-text', 'start');
+
+ $token = $self->get_token;
+ $self->validate_token($token, 'C', 'start');
+
+ $token = $self->get_token;
+ my $c_type = $token->text;
+
+ $token = $self->get_token;
+ $self->validate_token($token, 'C', 'end');
+
+ $token = $self->get_token; # consume the separator whitespace.
+ die "incorrect separator" unless $token->text =~ /^\s+$/;
+
+ $token = $self->get_token;
+ $self->validate_token($token, 'C', 'start');
+
+ $token = $self->get_token;
+ my $perl_type = $token->text;
+
+ $token = $self->get_token;
+ $self->validate_token($token, 'C', 'end');
+
+ $token = $self->get_token;
+ $self->validate_token($token, 'item-text', 'end');
+
+ print "*** Creating mapping for $c_type => $perl_type\n";
+ $self->{__type_mapping}->{$c_type} = $perl_type;
+}
+
+sub process_definitions {
+ my $self = shift;
+
+ my $list_ended = 0;
+ my $list_started = 0;
+
+ print "Processing signal definitions\n";
+
+ while (!$list_ended) {
+
+ my $token = $self->get_token;
+ $list_ended = 1 unless $token;
+
+ if (!$list_started) {
+ if ($token->is_start && $token->tag eq 'over-text') {
+ $list_started = 1;
+ } else {
+ next;
+ }
+ } else {
+ if ($token->is_end && $token->tag eq 'over-text') {
+ $list_ended = 1;
+ } else {
+ $self->unget_token($token);
+ # do tag processing here
+ print "Processing token ", $token->dump, $/;
+ $self->process_def_entry;
+ }
+ }
+ }
+
+ print "Done Processing signal defs\n";
+
+}
+
+sub process_def_entry {
+ my $self = shift;
+ my $token;
+ print "Processing definition entry\n";
+ while ($token = $self->get_token()) {
+
+ last if $token->is_end && $token->tag eq 'item-text';
+ }
+ #$self->unget_token($token);
+ print "Done Processing definition entry\n";
+
+}
+
package main;
my $input_file = $ARGV[0] // 'Signals.pm';
@@ -45,12 +190,3 @@ my $parser = Pod::Simple::IrssiSignalParser->new;
$parser->accept_targets('irssi_signal_defs', 'irssi_signal_types');
my $tree = $parser->parse_file($input_file);
-
-# if ($type eq 'Data' && $text =~ /START OF SIGNAL DEFINITIONS/) {
-# $seen_start = 1;
-# }
-
-# if ($type eq 'Data' && $text =~ /END OF SIGNAL DEFINITIONS/) {
-# $seen_end = 1;
-# }
-