matthew-matvei/freeman

View on GitHub
README.md

Summary

Maintainability
Test Coverage
# FreeMAN

[![Travis-CI build status](https://travis-ci.org/matthew-matvei/freeman.svg?branch=develop)](https://travis-ci.org/matthew-matvei/freeman)
[![AppVeyor build status](https://ci.appveyor.com/api/projects/status/a919pf573a0tv0fg/branch/develop?svg=true)](https://ci.appveyor.com/project/matthew-matvei/freeman)
[![Dependencies](https://david-dm.org/matthew-matvei/freeman.svg)](https://david-dm.org/matthew-matvei/freeman)
[![Dev Dependencies](https://david-dm.org/matthew-matvei/freeman/dev-status.svg)](https://david-dm.org/matthew-matvei/freeman#info=devDependencies)
[![Maintainability](https://api.codeclimate.com/v1/badges/962d19a24fb074a1df39/maintainability)](https://codeclimate.com/github/matthew-matvei/freeman/maintainability)
[![First contributions welcome](http://img.shields.io/badge/first--contributions-welcome-green.svg?style=flat-square)](.github/CONTRIBUTING.md)

A free, extensible, cross-platform file manager for power users

---

![FreeMAN with open integrated terminal](./resources/using-the-app.gif)

## Features

* Quick, clean, dual-paned file-system navigation with a strong keyboard-led
    focus
* Integrated terminal per navigation pane for those things a file explorer just
    can't do
* Focus on customisability to tailor it to the user's whims
* Quick navigation with a *Go To* box

### Future

* Tighter integration between navigation and integrated terminals
* Further behaviour to be customisable
* Extending usefulness of the *Go To* and *Commands* boxes

## Roadmap

* Core application ready for beta use
* Out-of-the-box plugins ready for beta use
* Core application ready for production use
* Out-of-the-box plugins ready for production use

The core application is ready for beta use, supporting Linux and Windows OS's. Feel free to set up
`electron-builder` for MacOS and make a PR.

## Getting started

    npm install
    npm start

If you want, you can add user-specific settings files, e.g. `freeman.keys.json`
like so:

    touch {userData}/freeman.keys.json

`{userData}` above refers to Electron's `app.getPath("userData")` location, *(which
depends on whether the application is running in a development or production
environment)*. Example files can be found in the `./resources/` folder.

## Packaging

If you would like to package / install the program, on Windows and Linux you can:

    npm run package

Then run the appropriate built executable.

## Running

During development, after compiling you can:

    npm run start

After packaging, you can run the system-dependent executable outputted by
`electron-builder` in the `./dist/` folder.

## Developing

An overview of the codebase can be found in the [docs](docs/CODE_STRUCTURE.md).
If you find it helpful, you can `npm run docs` and open the generated
`docs/generated/index.html` file. Please let me know if you find this useful.

## Debugging

Providing the `--verbose` or `-V` command-line argument will make the application
log in more detail, helping trace execution when using the packaged app. Logs of
warnings and errors can be found at `{appData}/log.log`.

## How to contribute

Contributions are welcome! Work on the core application is still under way. There are
numerous areas with room for improvement in usability and stability. My
priorities for development are currently:

* Core functionality
* Plugin functionality (starting with out-of-the-box ones)
* Appearance

I'll take whatever pull requests, issues, contributors and PMs I can get! Please
have a look at the [Contributing Guidelines](./.github/CONTRIBUTING.md) before
submitting a PR.