Skip to content

Dlurak/moxide

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Moxide

Moxide is a powerful tmux session manager written in Rust that simplifies the process of creating and managing complex tmux sessions. It allows you to define and control multiple windows and commands effortlessly, making it a perfect fit for developers and teams alike.

Features

  • Declarative and Extensible: Define your sessions using simple YAML configuration files. Customize and extend your setup as needed.
  • Single Binary: Moxide is distributed as a single binary, requiring no runtime or interpreter, making it easy to install and run.
  • Projects, Templates, and Directories:
    • Directories: Create named sessions based on the directory you're working in.
    • Templates: Reusable templates for common setups. For instance, a Rust template might open Neovim in one window and run Cargo commands in another.
    • Projects: Combine directories with templates to streamline workflows. Specify a template for a project or directly define the windows and commands needed.

Installation

To install Moxide, use the following command:

cargo install moxide

Nix

Moxide is also available in nixpkgs under the name moxide, if you use nix you know how to install a nixpkg but still here is a command:

nix shell nixpkgs#moxide

Why moxide

Moxide offers a unique combination of features:

  • Reusable Templates: Easily define a session once and apply it across multiple projects, making it ideal for managing similar setups.
  • Flexibility: Choose whether to use a template or define project-specific configurations, allowing for customization when needed.
  • Declarative Configuration: Use simple YAML files for configuration, promoting readability and ease of management.

Here are some scenarios how moxide might help people:

  • Developers managing multiple projects that require similar setups.
  • Teams looking for a standardized tmux environment across shared codebases.
  • Individuals who appreciate the flexibility of reusing templates while maintaining the option for custom project configurations.

Configuration Files

Moxide uses simple YAML configuration files. Below are examples of how to configure directories, projects, and templates.

Example Configuration Files

Directories

~/.config/moxide/directories.yaml

- name: "Downloads"
  path: "~/Downloads/"
- name: "Home"
  path: "~/"

Projects

~/.config/moxide/projects/Moxide.yaml

name: Moxide

root_dir: ~/SoftwareDevelopment/cli/moxide/
template: Rust

It is also possible to have project specific configs.

Templates

~/.config/template/Rust.yaml

name: Rust

windows:
  - name: Neovim
    panes:
      - nvim
  - name: Cargo
    layout: even-horizontal
    panes:
      - cargo build
      - cargo clippy

Usage

Moxide allows you to choose whether to apply a template to a project or define the windows and commands per project. This flexibility enables teams to maintain standard setups while accommodating unique project needs.

Launching Moxide Sessions

moxide project start ProjectName
moxide template start Rust --directory ~
moxide dir start Downloads
moxide dir start "~/Pictures/"

Scripting integration

Moxide can be easily integrated into shell scripts. Below is a sample script for launching Moxide sessions with a selection tool:

#!/bin/bash

project_emoji="🚀"
template_emoji="🛠️"
directory_emoji="📁"

list=$(moxide list \
    --format-project "$project_emoji {}"\
    --format-template "$template_emoji {}"\
    --format-directory "$directory_emoji {}"
)

value=$(echo "$list" | \
    fzf \
    --no-sort \
    --layout reverse \
    --border rounded \
    --border-label "Moxide Sessions" \
    --no-scrollbar \
    --prompt "" \
    --pointer "👉" \
    --color=bg+:#313244,bg:#1e1e2e,spinner:#f5e0dc,hl:#f38ba8 \
    --color=fg:#cdd6f4,header:#f38ba8,info:#cba6f7,pointer:#f5e0dc \
    --color=marker:#b4befe,fg+:#cdd6f4,prompt:#cba6f7,hl+:#f38ba8 \
    --color=selected-bg:#45475a
)

emoji="${value:0:1}"
name="${value:2}"

case "$emoji" in
    $project_emoji)
        moxide project start "$name"
        ;;
    $template_emoji)
        moxide template start "$name"
        ;;
    $directory_emoji)
        moxide dir start "$name"
        ;;
esac

You can bind this script into a tmux popup with the following command:

bind-key s display-popup -B -E -w 40% -h 12 "~/Dotfiles/scripts/shell/moxide.sh"

Similar Projects

If you are exploring alternatives, you might find these similar tools useful: