NAME
Syntax::Kamelon::Indexer - Keeps track of available syntax definitions
SYNOPSIS
use Syntax::Kamelon::Indexer;
my $indexer = Syntax::Kamelon::Indexer->new(%options);
DESCRIPTION
This module keeps track of available syntax definitions. It attemptds to load an index file in the xmlfolder. If that fails it will rebuild the index and attempt to save it.
OPTIONS
The constructor is called with a paired list or hash of options as parameters. You can use the following options.
- indexfile => filename
-
Specifies the filename where Kamelon stores information about available syntax definitions.
By default it points to 'indexrc' in the xmlfolder. If the file does not exist Kamelon will load all xml files in the xmlfolder and attempt to create the indexfile.
Once the indexfile has been created it becomes static. If you add a syntax definition XML file to the xmlfolder it will no longer be recognized. Delete the indexfile and reload Kamelon to fix that.
- noindex => boolean
-
By default 0. If you set this option Kamelon will ignore the existence of an indexfile and manually build the index, without saving it. But it gives you the liberty of adding and removing syntax highlight definition files.
This option comes with a considerable startup penalty.
- xmlfolder => folder
-
This is the place where Kamelon looks for syntax highlight definition XML files. By default it searches @INC for 'Syntax/Kamelon/XML'. Here you find the XML files used in the Kate text editor. They are specially crafted for this module.
METHODS
- AvailableSyntaxes
-
Returns a list of all available syntax definitions.
- CreateExtIndex
-
Creates an index of all available file extensions in the Kate XML files. This is needed if you want to use the SyntaxPropose method.
- CreateIndex
-
Creates an index of all available xml files in the xmlfolder. This may take a while.
- ExtensionSyntaxes($fileextension)
-
Returns a list of Syntax definitions that support the given file extension.
- Extensions($reftofileextensiontable)
-
Sets and returns the table that supports the ExtensionSyntaxes method. It is a hash in the form of:
extension => [syntax1, syntax2, ...]
- FindINC($filename);
-
Searches @INC for $filename and returns the full path of its first occurance.
- GetXMLObject($syntax);
-
Creates and returns a Syntax::Kamelon::XMLData object loaded with the xml file belonging to $syntax.
- IndexFile
-
Sets and returns the index file name. Corrsponds with the indexfile option.
- InfoXXXXX
-
These methods return general information about the syntax definitions.
- Info($syntax, $tag);
-
$tag can have the value: 'ext', 'mime', 'menu' or 'file'.
- InfoExtensions($syntax);
- InfoMimeType($syntax);
- InfoSection($syntax);
- InfoXMLFile($syntax);
- LoadIndex($noindex);
-
Loads the index of XMLFolder into memory. $noindex is a boolean. If it is set it will not load the index file but rebuild the index.
- LoadXML($fullpathandfilename);
-
Creates and returns an XMLData object for the given filename.
- SaveIndex
-
Saves the index to xmlfolder/indexfile.
- XMLFolder
-
Sets and returns the xml folder name. Corresponds with the xmlfolder option.
AUTHOR AND COPYRIGHT
This module is written and maintained by:
Hans Jeuken < hansjeuken at xs4all dot nl>
Copyright (c) 2017 by Hans Jeuken, all rights reserved.
Published under the GPLV3 license
SEE ALSO
Syntax::Kamelon, Syntax::Kamelon::Builder, Syntax::Kamelon::Debugger, Syntax::Kamelon::Diagnostics, Syntax::Kamelon::XMLData, Syntax::Kamelon::Format::Base, Syntax::Kamelon::Format::TT