## vim_printer [data:image/s3,"s3://crabby-images/86deb/86deb32582c8028e2394b834cc80d730e9e203d2" alt="Gem Version"](http://badge.fury.io/rb/vim_printer) [data:image/s3,"s3://crabby-images/ad086/ad08646ee5313930d23147e70c792f6d8e80528d" alt="Dependency Status"](https://gemnasium.com/agilecreativity/vim_printer) [data:image/s3,"s3://crabby-images/742de/742decdb398884117dedee0bb864c7d627e84da7" alt="Code Climate"](https://codeclimate.com/github/agilecreativity/vim_printer) [data:image/s3,"s3://crabby-images/f05f8/f05f8203a791a1d1d8a1fc7b9184383f8bc4cb91" alt="Endorse"](https://coderwall.com/agilecreativity) Print any files to html using the power of Vim. Output will be saved to `vim_printer_output.tar.gz` and ready for extract and viewing in your favourite browser. - Unlimited support for [vim colorschemes][] if enabled, or `default` colorscheme that comes with Vim. - Can print any files in any languages that you can open with Vim. - Use the power of [Vim][] to print the code without any other tools. - Tested in Linux/OSX and should also works with Windows. ### Example Outputs: - The original input using [seoul256.vim][] colorscheme in Vim data:image/s3,"s3://crabby-images/c1c94/c1c9486a638fe1aafc9b13b2e52d5aaabb356eb1" alt="" The html output as rendered in the browser data:image/s3,"s3://crabby-images/7f5a6/7f5a6fa5107c9d1454d305fa3505e58a4155b322" alt="" - The original input using `Tomorrow-Night` colorscheme from [Tomorrow-theme][] in Vim data:image/s3,"s3://crabby-images/8a995/8a995b8bb92b52448bd0059c30efcc0f18a15dee" alt="" The html output as renderd in the browser data:image/s3,"s3://crabby-images/474b1/474b1c438f95241b61f9abe8b6c4ed8699795371" alt="" ### Requirements - [Vim][] - any recent version should be ok. - Any decent `~/.vimrc` should do * There are so many great vim dotfiles in github repos. * [NeoBundle][] is a very good start if you are new to Vim. * If you like you can use [my dotvim][] which is based on the [NeoBundle][]. * Use any [vim colorschemes][] if not the `default` colorscheme will be used. My personal favourite are [seoul256.vim][] and [Tomorrow-Theme][] - Any valid file types that are supported by Vim will be shown proper color in the output. * By default Vim comes with supported for major languages so you should see the proper syntax with color in the output. * On newer language like [Elixir][], you may have to first install [vim-elixir][] to see the proper syntax in the output. If this is not installed then you will get the output but will not have the beautiful color syntax. ### Sample session - Run with the sample fixture files ```sh vim_printer print -b test/fixtures/inputs -e rb java -r ``` Will produce the file `output.tar.gz` with the following result on the screen. ``` FYI: process file 1 of 8 : test/fixtures/inputs/demo1.xxx.rb FYI: process file 2 of 8 : test/fixtures/inputs/demo1.yyy.rb FYI: process file 3 of 8 : test/fixtures/inputs/demo2.xxx.rb FYI: process file 4 of 8 : test/fixtures/inputs/demo2.yyy.rb FYI: process file 5 of 8 : test/fixtures/inputs/java/demo3.xxx.java FYI: process file 6 of 8 : test/fixtures/inputs/java/demo3.yyy.java FYI: process file 7 of 8 : test/fixtures/inputs/java/demo4.xxx.java FYI: process file 8 of 8 : test/fixtures/inputs/java/demo4.yyy.java Your output file is output.tar.gz ``` ### Usage - Install the gem for your version of ruby e.g. for rbenv your session will be something like ```sh rbenv local 2.1.1 # or whatever the version of you ruby rbenv rehash gem install vim_printer ``` - Print any files using the gem ```sh vim_printer ``` - Print any files that you like using the simple command The following command will print out all java, and ruby files recursively using the `solarized` colorscheme. ```sh vim_printer print --base-dir ./test/fixtures \ --exts rb \ --theme solarized ``` Your output will be saved to the default `output.tar.gz` in the directory where you run this command. To see the output in your browser just type: ```sh mkdir -p ~/Desktop/vim_printer mv output.tar.gz ~/Desktop/vim_printer cd ~/Desktop/vim_printer tar zxvf output.tar.gz ``` - Print only files that contain the word `xxx` in the title ```sh vim_printer print --base-dir ./test/fixtures \ --exts java \ --theme solarized \ --n xxx ``` - For help in using the gem just type `vim_printer` without any parameter You should see something like the following: ``` Usage: vim_printer print [OPTIONS] Options: -b, [--base-dir=BASE_DIR] # Base directory # Default: . (current directory) -e, [--exts=one two three] # List of extensions to search for -f, [--non-exts=one two three] # List of extensions to search for -n, [--inc-words=one two three] # List of words to be included in the result -x, [--exc-words=one two three] # List of words to be excluded from the result -i, [--ignore-case], [--no-ignore-case] # Match case insensitively # Default: true -r, [--recursive], [--no-recursive] # Search for files recursively # Default: true -t, [--theme=THEME] # Vim colorscheme to use # Default: default -v, [--version], [--no-version] # Display version information Print the list of files ``` ### Development/Testing ```sh git clone https://github.com/agilecreativity/vim_printer.git cd vim_printer bundle # run default test rake ``` ### Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Make sure that you add the tests and ensure that all tests are passed 5. Push to the branch (`git push origin my-new-feature`) 6. Create new Pull Request [NeoBundle]: https://github.com/Shougo/neobundle.vim [Vim]: https://www.vim.org [my dotvim]: https://github.com/agilecreativity/dotvim [Elixir]: http://elixir-lang.org [vim-elixir]: https://github.com/elixir-lang/vim-elixir [vim colorschemes]: https://github.com/flazz/vim-colorschemes/tree/master/colors [seoul256.vim]: https://github.com/junegunn/seoul256.vim [Tomorrow-theme]: https://github.com/ChrisKempson/Tomorrow-Theme