Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mattn/memo
📓 Memo Life For You
https://github.com/mattn/memo
go golang jekyll markdown memo
Last synced: about 9 hours ago
JSON representation
📓 Memo Life For You
- Host: GitHub
- URL: https://github.com/mattn/memo
- Owner: mattn
- License: mit
- Created: 2017-02-07T18:48:43.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-11-26T11:08:13.000Z (about 2 months ago)
- Last Synced: 2025-01-05T15:00:20.250Z (7 days ago)
- Topics: go, golang, jekyll, markdown, memo
- Language: Go
- Homepage:
- Size: 762 KB
- Stars: 979
- Watchers: 13
- Forks: 81
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - mattn/memo - 📓 Memo Life For You (Go)
README
# memo
Memo Life For You
![Memo Life For You](https://raw.githubusercontent.com/mattn/memo/master/screenshot.gif)
## Usage
```
NAME:
memo - Memo Life For YouUSAGE:
memo [global options] command [command options] [arguments...]VERSION:
0.0.4COMMANDS:
new, n create memo
list, l list memo
edit, e edit memo
delete, d delete memo
grep, g grep memo
cat, v view memo
config, c configure
serve, s start http server
help, h Shows a list of commands or help for one commandGLOBAL OPTIONS:
--help, -h show help
--version, -v print the version
```## Installation
```
$ go install github.com/mattn/memo@latest
```Let's start create memo file.
```
$ memo new
Title:
```Input title for the memo, then you see the text editor launched. After saving markdown, list entries with `memo list`.
```
$ memo list
2017-02-07-memo-command.md : Installed memo command
```And grep
```
$ memo grep command
2017-02-07-memo-command.md:1:# Installed memo command
```## Configuration
run `memo config`.
```toml
memodir = "/path/to/you/memo/dir" # specify memo directory
memotemplate = "path/to/tmpl.txt" # optional memo template file. default '~/.config/memo/template.txt'
editor = "vim" # your favorite text editor
column = 30 # column size for list command
selectcmd = "peco" # selector command for edit command
grepcmd = "grep -nH" # grep command executable
assetsdir = "/path/to/assets" # assets directory for serve command
pluginsdir = "path/to/plugins" # plugins directory for plugin commands. default '~/.config/memo/plugins'.
```memodir, memotemplate and assetsdir can be used `~/` prefix or `$HOME` or OS specific environment variables. editor, selectcmd and grepcmd can be used placeholder below.
|placeholder|replace to |
|-----------|---------------|
|${FILES} |target files |
|${DIR} |same as memodir|
|${PATTERN} |grep pattern |## Memo Template
You can use memo template using Go's text/template format. A template receives the following attributes.
- Title
- Date (format: %Y-%m-%d %H:%M)
- Categories (always empty)
- Tags (always empty)The following is a template example to apply YAML Frontmatter.
```
---
title: {{.Title}}
date: {{.Date}}
---{{.Title}}
===========
```You can also use glidenote/memolist.vim's template format like following.
```
title: {{_title_}}
==========
date: {{_date_}}
tags: [{{_tags_}}]
categories: [{{_categories_}}]
----------
```## Supported GrepCmd
|Command |Configuration |
|---------------------------------------------------|------------------------------------|
|GNU Grep |grepcmd = "grep -nH" #default |
|[ag](https://github.com/ggreer/the_silver_searcher)|grepcmd = "ag ${PATTERN} ${DIR}" |
|[jvgrep](https://github.com/mattn/jvgrep) |grepcmd = "jvgrep ${PATTERN} ${DIR}"|## Supported SelectCmd
|Command |Configuration |
|--------------------------------------|-----------------|
|[gof](https://github.com/mattn/gof) |selectcmd = "gof"|
|[cho](https://github.com/mattn/cho) |selectcmd = "cho"|
|[fzf](https://github.com/junegunn/fzf)|selectcmd = "fzf"|## Extend With Plugin Commands
You can extend memo with custom commands.
Place an executable file in your `pluginsdir`, memo can use it as a subcommand.
For example, If you place `foo` file in your `pluginsdir`, you can run it by `memo foo`.Below is spec of plugins:
* MUST handle `-usage` option to show briefly, at least.
* MUST NOT handle `--xxx` option.
* MUST NOT use multi-byte strings in the usage.## License
MIT
## Author
Yasuhiro Matsumoto (a.k.a. mattn)