Eric D Johnson > Vim-Debug-0.903 > Vim::Debug

Download:
Vim-Debug-0.903.tar.gz

Dependencies

Annotate this POD

Website

View/Report Bugs
Module Version: 0.903   Source   Latest Release: Vim-Debug-0.904

NAME ^

Vim::Debug - Perl wrapper around a command line debugger

SYNOPSIS ^

    package Vim::Debug;

    my $debugger = Vim::Debug->new(
        language => 'Perl',                    # required
        invoke   => 'perl -Ilib -d t/perl.pl', # required
    );

    $debugger->start;
    sleep(1) until $debugger->read;
    print "line:   " . $debugger->line . "\n";
    print "file:   " . $debugger->file . "\n";
    print "output: " . $debugger->output . "\n";

    $debugger->step;          sleep(1) until $debugger->read;
    $debugger->next;          sleep(1) until $debugger->read;
    $debugger->write('help'); sleep(1) until $debugger->read;

    $debugger->quit; 

DESCRIPTION ^

If you are new to Vim::Debug please read the user manual, Vim::Debug::Manual, first.

Vim::Debug is an object oriented wrapper around the Perl command line debugger. In theory the debugger could be for any language -- not just Perl. But only Perl is supported currently.

The read() method is non blocking. This allows a user to send an interrupt when they get stuck in an infinite loop.

ATTRIBUTES ^

invoke

language

stop

line

file

value

status

FUNCTIONS ^

start()

Starts up the command line debugger in a seperate process.

start() always returns undef.

write($command)

Write $command to the debugger's stdin. This method blocks until the debugger process reads. Be sure to include a newline.

write() always returns undef;

read()

Performs a nonblocking read on stdout from the debugger process. read() first looks for a debugger prompt.

If one is not found, the debugger isn't finished thinking so read() returns 0.

If a debugger prompt is found, the output is parsed. The following information is parsed out and saved into attributes: line(), file(), value(), and out().

read() will also send an interrupt (CTL+C) to the debugger process if the stop() attribute is set to true.

out($out)

If called with a parameter, out() removes ornaments (like <CTL-M> or irrelevant error messages or whatever) from text and saves the value.

If called without a parameter, out() returns the saved value.

translate($in)

Translate a protocol command ($in) to a native debugger command. The native debugger command is returned as an arrayref of strings.

Dies if no translation is found.

SEE ALSO ^

Vim::Debug::Manual, Vim::Debug::Perl, Devel::ebug, perldebguts

BUGS ^

In retrospect its possible there is a better solution to this. Perhaps directly hooking directly into the debugger rather than using regexps to parse stdout and stderr?

AUTHOR ^

Eric Johnson <kablamo at iijo dot nospamthanks dot org>

COPYRIGHT AND LICENSE ^

This software is copyright (c) 2013 by Eric Johnson.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.

syntax highlighting: