NAME
Vroom::Vroom - Slide Shows in Vim
SYNOPSIS
> mkdir MySlides # Make a Directory for Your Slides
> cd MySlides # Go In There
> vim slides.vroom # Write Some Slides
> vroom --vroom # Show Your Slides
DESCRIPTION
Ever given a Slide Show and needed to switch over to the shell?
Now you don't ever have to switch again. You're already there.
Vroom lets you create your slides in a single file using a Wiki-like style, much like Spork and Sporx do. The difference is that your slides don't compile to HTML or JavaScript or XUL. They get turned into a set of files that begin with '0', like '03' or '07c' or '05b.pl'.
The slides are named in alpha order. That means you can bring them all into a Vim session with the command: vim 0*
. vroom --vroom
does exactly that.
Vroom creates a file called ./.vimrc
with helpful key mappings for navigating a slideshow. See "KEY MAPPINGS" below.
Please note that you will need the following line in your $HOME/.vimrc
file in order to pick up the local .vimrc
file.
set exrc
Vroom takes advantage of Vim's syntax highlighting. It also lets you run slides that contain code.
Since Vim is an editor, you can change your slides during the show.
COMMAND USAGE
Vroom has a few command line options:
- vroom
-
Just running vroom will compiles 'slides.vroom' into slide files.
- vroom --vroom
-
Compile and start vim show.
- vroom --clean
-
Clean up all the compiled output files.
INPUT FORMAT
Here is an example slides.vroom file:
---- config
# These are YAML settings for Vroom
title: My Spiffy Slideshow
height: 84
width: 20
# skip: 12 # Skip 12 slides. Useful when making slides.
---- center
My Presentation
by Ingy
----
== Stuff I care about:
* Foo
+* Bar
+* Baz
---- perl,i10
# Perl code indented 10 spaces
use Vroom::Vroom;
print "Hello World";
---- center
THE END
A line that starts with '==' is a header line. It will be centered.
Lines that begin with a '+' cause vroom to split the slide there, causing an animation effect.
CONFIGURATION OPTIONS
Each slide can have one or more configuration options. Options are a comma separated list that follow the '----' header for a slide. Like this:
---- center
---- html
---- perl,i20
---- config
---- skip
- skip
-
Ignore the following slide completely.
- center
-
Center the contents of the slide.
- i##
-
'i' followed by a number means to indent the contents by the number of characters.
- perl,ruby,python,js,yaml,make,html
-
Specifies that the slide is one of those syntaxen, and that the appropriate file extension will be used, thus causing vim to syntax highlight the slide.
- config
-
The slide is really a yaml configuration. It will not be displayed in the presentation, but will tell vroom what to do from that point forward. You can use more than one config slide in your
slides.vroom
file.
You can specify the following confguration options in a config slide:
- title <text>
-
The title of your presentation.
- height <number>
-
The number of lines in the terminal you plan to use when presenting the show. Used for centering the content.
- width <number>
-
The number of columns in the terminal you plan to use when presenting the show. Used for centering the content.
- list_indent <number>
-
Auto detect slides that have lists in them, and indent them by the specified number of columns.
KEY MAPPINGS
These are the standard key mappings specified in the local .vimrc
.
- <SPACE>
-
Advance one slide.
- <BACKSPACE>
-
Go back one slide.
- <R>
-
Run current slide as Perl.
- <Q>
-
Quit Vroom.
CUSTOM CONFIGURATION
You can create a file called .vroom/vimrc
in your home directory. If vroom sees this file, it will append it onto every local .vimrc
file it creates.
Use this file to specify your own custom vim settings for all your vroom presentations.
NOTE
Vroom is called Vroom but the module is Vroom::Vroom because the CPAN shell sometimes thinks Vroom is Tim Vroom, and it refuses to install him.
Use a shell command like this to install Vroom:
sudo cpan Vroom::Vroom
AUTHOR
Ingy döt Net <ingy@cpan.org>
COPYRIGHT
Copyright (c) 2008. Ingy döt Net.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
See http://www.perl.com/perl/misc/Artistic.html