NAME Kasago - A Perl source code indexer SYNOPSIS my $kasago = Kasago->new({ dbh => $dbh }); $kasago->init; # this creates the tables for you # import/update a directory $kasago->import($source, $dir); # delete a directory $kasago->delete($source); my @sources = $kasago->sources; my @files = $kasago->files($source); my @tokens = $kasago->tokens($source, $file); # search for a token foreach my $token ($kasago->search('orange')){ print $token->source . "/" . $token->file . "@" . $token->col . "," . $token->row . ": " . $token->line . "\n"; } # search for a token, merging lines foreach my $hit ($kasago->search_merged($search)) { print $hit->source . "/" . $hit->file . "@" . $hit->row . ": " . $hit->line . "\n"; foreach my $token (@{ $hit->tokens }) { print " @" . $token->col . ": " . $token->value . "\n"; } } # search for tokens foreach my $token ($kasago->search_more($search)) { print $token->source . "/" . $token->file . "@" . $token->col . "," . $token->row . ": " . $token->line . "\n"; } # searh for tokens, merging lines foreach my $hit ($kasago->search_more_merged($search)) { print $hit->source . "/" . $hit->file . "@" . $hit->row . ": " . $hit->line . "\n"; foreach my $token (@{ $hit->tokens }) { print " @" . $token->col . ": " . $token->value . "\n"; } } DESCRIPTION Kasago is a module for indexing Perl source code. You can index source trees, and then query the index for symbols, strings, and documentation. Kasago uses the PPI module to parse Perl and stores the index in a PostegreSQL database. Thus you need to have DBD::Pg installed and a database available for Kasago. Why is this called Kasago? Because that's the Japanese name for a beautiful fish. METHODS new This is the constructor. It takes a DBI database handle as a parameter. This must be a valid dababase handle for a PostgreSQL database, constructed along the lines of 'my $dbh = DBI->connect("DBI:Pg:dbname=kasago", "", "")': my $kasago = Kasago->new({ dbh => $dbh }); delete This deletes a source from the index: $kasago->delete($source); files Given a source, returns a list of the files indexed in that source: my @files = $kasago->files($source); import This recursively imports a directory into Kasago. If the source is already indexed, the index is updated. You pass a source name and the directory path: $kasago->import($source, $dir); init This created the tables needed by Kasago in the database. You only need run this once. If you run this after initialisation, it will delete the index. $kasago->init; search This searches the index for an individual token: foreach my $token ($kasago->search('orange')){ print $token->source . "/" . $token->file . "@" . $token->col . "," . $token->row . ": " . $token->line . "\n"; } search_merged This searches the index for an individual token, but merges multiple tokens on the same line together: foreach my $hit ($kasago->search_merged($search)) { print $hit->source . "/" . $hit->file . "@" . $hit->row . ": " . $hit->line . "\n"; foreach my $token (@{ $hit->tokens }) { print " @" . $token->col . ": " . $token->value . "\n"; } } search_more This searches the index for tokens. "orange" would return all hits for orange, "orange leon" would return all hits for both "orange" and "leon". "orange -leon" shows all the hits for "orange" but without files that contain "leon", "+orange +leon" returns hits in files that contain both "orange" and "leon": foreach my $token ($kasago->search_more($search)) { print $token->source . "/" . $token->file . "@" . $token->col . "," . $token->row . ": " . $token->line . "\n"; } search_more_merged This searches the index for tokens as search_more, but merges multiple tokens on the same line together: foreach my $hit ($kasago->search_more_merged($search)) { print $hit->source . "/" . $hit->file . "@" . $hit->row . ": " . $hit->line . "\n"; foreach my $token (@{ $hit->tokens }) { print " @" . $token->col . ": " . $token->value . "\n"; } } sources This returns a list of the sources currently indexed: my @sources = $kasago->sources; tokens Given a source and a file, returns a list of the tokens indexed: my @tokens = $kasago->tokens($source, $file); AUTHOR Leon Brocard <acme@astray.com>. COPYRIGHT Copyright (C) 2005, Leon Brocard This module is free software; you can redistribute it or modify it under the same terms as Perl itself.