# # KDOM IDL parser # # Copyright (C) 2005 Nikolas Zimmermann # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Library General Public # License as published by the Free Software Foundation; either # version 2 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Library General Public License for more details. # # You should have received a copy of the GNU Library General Public License # along with this library; see the file COPYING.LIB. If not, write to # the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, # Boston, MA 02110-1301, USA. # package IDLStructure; use strict; use Class::Struct; # Used to represent a parsed IDL document struct( idlDocument => { module => '$', # Module identifier classes => '@', # All parsed interfaces fileName => '$' # file name }); # Used to represent 'interface' blocks struct( domClass => { name => '$', # Class identifier (without module) parents => '@', # List of strings constants => '@', # List of 'domConstant' functions => '@', # List of 'domFunction' attributes => '@', # List of 'domAttribute' extendedAttributes => '$', # Extended attributes constructor => '$', # Constructor isException => '$', # Used for exception interfaces }); # Used to represent domClass contents (name of method, signature) struct( domFunction => { isStatic => '$', signature => '$', # Return type/Object name/extended attributes parameters => '@', # List of 'domSignature' raisesExceptions => '@', # Possibly raised exceptions. }); # Used to represent domClass contents (name of attribute, signature) struct( domAttribute => { type => '$', # Attribute type (including namespace) isStatic => '$', signature => '$', # Attribute signature getterExceptions => '@', # Possibly raised exceptions. setterExceptions => '@', # Possibly raised exceptions. }); # Used to represent a map of 'variable name' <-> 'variable type' struct( domSignature => { direction => '$', # Variable direction (in or out) name => '$', # Variable name type => '$', # Variable type extendedAttributes => '$' # Extended attributes }); # Used to represent string constants struct( domConstant => { name => '$', # DOM Constant identifier type => '$', # Type of data value => '$', # Constant value extendedAttributes => '$', # Extended attributes }); # Helpers our $idlId = '[a-zA-Z0-9]'; # Generic identifier our $idlIdNs = '[a-zA-Z0-9:]'; # Generic identifier including namespace our $idlIdNsList = '[a-zA-Z0-9:,\ ]'; # List of Generic identifiers including namespace our $idlType = '[a-zA-Z0-9_]'; # Generic type/"value string" identifier # Match a string value, a hexadecimal number, or an integral number. # Note: some of the characters that are allowed in the string value may not be allowed by # interfaceSelector. our $constValue = '("[^"\r\n]*")|(0[xX][a-fA-F0-9]+)|(-?[0-9]*)'; our $idlDataType = '[a-zA-Z0-9\ ]'; # Generic data type identifier # Magic IDL parsing regular expressions my $supportedTypes = "((?:(?:unsigned )?(?:int|short|(?:long )?long)|(?:$idlIdNs*))(?:\\[\\]|<(?:$idlIdNsList*)>)?)"; # Special IDL notations. This regular expression extracts the string between the first [ and its corresponding ]. our $extendedAttributeSyntax = qr/\[[^\[\]]*(?:(??{$IDLStructure::extendedAttributeSyntax})[^\[\]]*)*\]/x; # Used for extended attributes # Regular expression based IDL 'syntactical tokenizer' used in the IDLParser our $moduleSelector = 'module\s*(' . $idlId . '*)\s*{'; our $moduleNSSelector = 'module\s*(' . $idlId . '*)\s*\[ns\s*(' . $idlIdNs . '*)\s*(' . $idlIdNs . '*)\]\s*;'; our $constantSelector = '(' . $extendedAttributeSyntax . ' )?const\s+' . $supportedTypes . '\s*(' . $idlType . '*)\s*=\s*(' . $constValue . ')'; our $raisesSelector = 'raises\s*\((' . $idlIdNsList . '*)\s*\)'; our $getterRaisesSelector = '\bgetter\s+raises\s*\((' . $idlIdNsList . '*)\s*\)'; our $setterRaisesSelector = '\bsetter\s+raises\s*\((' . $idlIdNsList . '*)\s*\)'; our $typeNamespaceSelector = '((?:' . $idlId . '*::)*)\s*(' . $idlDataType . '*)'; our $interfaceSelector = '(interface|exception)\s*((?:' . $extendedAttributeSyntax . ' )?)(' . $idlIdNs . '*)\s*(?::(\s*[^{]*))?{([-a-zA-Z0-9_"=\s(),;:\[\]<>&\|]*)'; our $interfaceMethodSelector = '\s*((?:' . $extendedAttributeSyntax . ' )?)(static\s+)?' . $supportedTypes . '\s*(' . $idlIdNs . '*)\s*\(\s*([a-zA-Z0-9:\s,=\[\]<>]*)'; our $interfaceParameterSelector = '(in|out)\s*((?:' . $extendedAttributeSyntax . ' )?)' . $supportedTypes . '\s*(' . $idlIdNs . '*)'; our $interfaceAttributeSelector = '\s*(static\s+)?(readonly attribute|attribute)\s*(' . $extendedAttributeSyntax . ' )?' . $supportedTypes . '\s*(' . $idlType . '*)'; 1;