Metadata-Version: 2.4
Name: megamap
Version: 1.0.1
Summary: Generate a visual map of your codebase
Author-email: Hrothgar <hrothgarrrr@gmail.com>
Requires-Python: >=3.7
Requires-Dist: drawsvg
Requires-Dist: pygments
Description-Content-Type: text/markdown

<p align="center">
  <img width="1231" height="300" src="https://raw.githubusercontent.com/rothos/megamap/master/banner.png">
</p>


# Megamap

Megamap is a mega awesome version of the minimap feature of text editors like
Sublime. Give megamap a directory full of source code, and it will
produce a PNG image which is a beautiful birdseye view of all the source code.


## Installation

```bash
pip install megamap
```

## Usage

```bash
megamap [input_directory] [output_filename]
```

By default, `input_directory` = `.` and `output_filename` = `megamap.png`.

Optional arguments:
```
-h, --help            show this help message and exit
-a, --aspect-ratio ASPECT_RATIO
                      Target aspect ratio (width/height) for the output image (default: 1.5)
-b, --banner          Enable banner mode (sets target aspect ratio to 5.0)
-c, --cols COLS       Number of characters per line in output image (default: 80)
--include-hidden      Include hidden files and directories
--list-styles         List available syntax highlighting styles and exit
-q, --quiet           Suppress all output except errors
-s, --style STYLE     Syntax highlighting style (use "random" for random style)
-v, --verbose         Enable verbose output
--version             Print program version number and exit
-x, --scale SCALE     Pixel scale factor (must be integer, default: 1)
-z, --zebra           Enable zebra striping of background colors between files
```

The program will automatically:
- Skip common non-code files (LICENSE, README, etc.)
- Skip files with non-code extensions (.txt, .md, .json, etc.)
- Skip binary and non-text files
- Skip files without a valid syntax highlighter


## Pretty pictures

These two images were created using the same input (this program's own source code)
with different parameters:

<p align="center">
  <img width="352" height="320" src="https://raw.githubusercontent.com/rothos/megamap/master/gen.py_1.png">
</p>

<p align="center">
  <img width="402" height="288" src="https://raw.githubusercontent.com/rothos/megamap/master/gen.py_2.png">
</p>

Source code of entire projects can be elegantly illustrated:

<p align="center">
  <img width="1232" height="791" src="https://raw.githubusercontent.com/rothos/megamap/master/statebus.png">
</p>


## FAQ

### How are the files sorted?

The files are sorted alphabetically by directory and then by file name,
with files in the base directory first.

### How do I find out what all the syntax highlighting styles are called?

You can either:
1. Run `megamap --list-styles` to see all available styles
2. Use `random` as the style to let megamap choose one randomly

### What about word wrapping?

Not currently supported.
