summaryrefslogtreecommitdiffstats
path: root/oovbaapi/genconstidl/api-to-idl.pl
diff options
context:
space:
mode:
Diffstat (limited to 'oovbaapi/genconstidl/api-to-idl.pl')
-rw-r--r--oovbaapi/genconstidl/api-to-idl.pl203
1 files changed, 203 insertions, 0 deletions
diff --git a/oovbaapi/genconstidl/api-to-idl.pl b/oovbaapi/genconstidl/api-to-idl.pl
new file mode 100644
index 0000000000..933025cef2
--- /dev/null
+++ b/oovbaapi/genconstidl/api-to-idl.pl
@@ -0,0 +1,203 @@
+:
+ eval 'exec perl -S $0 ${1+"$@"}'
+ if 0;
+#
+# This file is part of the LibreOffice project.
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+# This file incorporates work covered by the following license notice:
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed
+# with this work for additional information regarding copyright
+# ownership. The ASF licenses this file to you under the Apache
+# License, Version 2.0 (the "License"); you may not use this file
+# except in compliance with the License. You may obtain a copy of
+# the License at http://www.apache.org/licenses/LICENSE-2.0 .
+#
+
+sub usage() {
+ print "Usage: api-to-idl.pl source.api destination_path\n";
+ print;
+ print "This tool converts oovbaapi *.api files into *.idl's.\n";
+ exit 1;
+}
+
+my $src = shift;
+my $dest = shift;
+
+if ( !defined( $src ) || !defined( $dest ) || $src eq "-h" || $src eq "--help" ) {
+ usage();
+}
+
+# Parsing functions
+my $state = "";
+my $source = "";
+my $name = "";
+my $value = "";
+
+my %result;
+
+# Process element start event
+sub start_element($) {
+ my ($el) = @_;
+
+ @element_attr = split( /\s+/, $el );
+ my $element = $element_attr[0];
+
+ if ( $element eq "element" ) {
+ if ( $element_attr[1] =~ /type="?([^"]*)"?/ && $1 eq "constant" ) {
+ $state = "constant";
+ $source = "";
+ $name = "";
+ $value = "";
+ }
+ }
+ elsif ( $state eq "constant" && $element eq "source" ) {
+ $state = "source";
+ if ( $element_attr[1] =~ /id="?([^"]*)"?/ ) {
+ chomp( $source = $1 );
+ }
+ }
+ elsif ( $state eq "source" && $element eq "name" ) {
+ $state = "name";
+ }
+ elsif ( $state eq "source" && $element eq "value" ) {
+ $state = "value";
+ }
+}
+
+# Process element end event
+sub end_element($) {
+ my ($element) = @_;
+
+ if ( $state eq "name" && $element eq "name" ) {
+ $state = "source";
+ }
+ elsif ( $state eq "value" && $element eq "value" ) {
+ $state = "source";
+ }
+ elsif ( $state ne "" && $element eq "element" ) {
+ $state = "";
+
+ my @destination = split( /\./, $source );
+ my $module = shift( @destination );
+ my $type = shift( @destination );
+
+ $module =~ tr/[A-Z]/[a-z]/;
+
+ $result{$module} = {} unless exists $result{$module};
+ $result{$module}{$type} = [] unless exists $result{$module}{$type};
+
+ push( @{$result{$module}{$type}},
+ { "name" => $name, "value" => $value } );
+ }
+}
+
+# Process characters
+sub characters($) {
+ my ($data) = @_;
+
+ if ( $state eq "name" ) {
+ chomp( $name = $data );
+ }
+ elsif ( $state eq "value" ) {
+ chomp( $value = $data );
+ }
+}
+
+# Create idls from the parsed data
+sub generate_idls($) {
+ my ($path) = @_;
+
+ foreach $module ( keys %result ) {
+ foreach $type ( keys %{$result{$module}} ) {
+ my $fname = $path . "/" . $type . ".idl";
+ open( IDL, ">$fname" ) || die "Cannot write $fname.";
+
+ if( $module eq "vba" ) {
+ print IDL "module ooo { module $module {\n";
+ }
+ else {
+ print IDL "module ooo { module vba { module $module {\n";
+ }
+
+ print IDL " constants $type {\n";
+ foreach $constant ( @{$result{$module}{$type}} ) {
+ print IDL " const long $constant->{'name'} = $constant->{'value'};\n";
+ }
+ if( $module eq "vba" ) {
+ print IDL " };\n}; };\n";
+ }
+ else {
+ print IDL " };\n}; }; };\n";
+ }
+
+ close( IDL );
+ }
+ }
+}
+
+# Parse the input
+open( IN, "<$src" ) || die "Cannot open $src.";
+
+my $in_comment = 0;
+my $line = "";
+while (<IN>) {
+ # ignore comments
+ s/<!--[^>]*-->//g;
+ if ( /<!--/ ) {
+ $in_comment = 1;
+ s/<!--.*//;
+ }
+ elsif ( /-->/ && $in_comment ) {
+ $in_comment = 0;
+ s/.*-->//;
+ }
+ elsif ( $in_comment ) {
+ next;
+ }
+ # ignore empty lines
+ chomp;
+ s/^\s*//;
+ s/\s*$//;
+ next if ( $_ eq "" );
+
+ # take care of lines where element continues
+ if ( $line ne "" ) {
+ $line .= " " . $_;
+ }
+ else {
+ $line = $_;
+ }
+ next if ( !/>$/ );
+
+ # the actual parsing
+ my @starts = split( /</, $line );
+ $line = "";
+ foreach $start ( @starts ) {
+ next if ( $start eq "" );
+
+ @ends = split( />/, $start );
+ my $element = $ends[0];
+ my $data = $ends[1];
+
+ # start or end element
+ if ( $element =~ /^\/(.*)/ ) {
+ end_element( $1 );
+ }
+ else {
+ start_element( $element );
+ }
+
+ # the data
+ characters( $data );
+ }
+}
+close( IN );
+
+# Generate the output
+generate_idls($dest);