Skip to content

Acode-Foundation/acode-plugin-git

 
 

Repository files navigation

Acode Plugin Git SCM

Version License Acode

Professional Git integration for Acode Editor

FeaturesInstallationRequirementsAPIContributing

Git SCM v2 is a complete rewrite that communicates directly with the native Git binary installed on your system, providing full Git compatibility. This plugin executes real Git commands through Acode's Executor API, ensuring 100% Git compatibility. Unlike JavaScript-based solutions (isomorphic-git), this plugin communicates directly with your system Git installation for full compatibility and optimal performance.

Screenshoots

Source Control File Tree Decorations Branch Management Git Command

Requirements

Git must be installed on your system and Acode latest version with Terminal and Executor API support:

apk add git

SSH (Required for GitHub / SSH remotes)

Alpine Linux ships with Dropbear SSH by default, which conflicts with OpenSSH and causes Git authentication issues. This plugin requires OpenSSH for full compatibility.

After installation, generate and configure your SSH keys normally.

Features

Core Git Operations

  • Repository Management: Init, Clone, Multi-repository support
  • Staging & Commits: Stage/unstage files, commit, amend commits, undo commits
  • Branches: Create, delete, rename, merge, rebase branches
  • Remote Operations: Pull, push, fetch (with prune), sync (Pull & Push)
  • History: View commit history
  • Tags & Remotes: Tag and remote management

Acode Integration

  • File Decorations: Visual decoration in SCM panel and file explorer
  • Editor Integration: Commit message editor opens in Acode (via IPC)
  • Credential Management: Integrated askpass for authentication
  • Multi-repository: Work with multiple Git repositories
  • Status Bar: Quick sync actions and repository status

Installation

  1. Open Settings
  2. Select Plugins
  3. Search for "Git SCM"
  4. Tap Install
  5. Restart

How It Works

The plugin follows a Shell → Parse → Render workflow. The same architecture as the VS Code Git extension:

flowchart LR
    A["⚡ Shell\nAcode Executor API"] --> B["🔍 Parse\nstdout/stderr\n→ Models"]
    B --> C["🖥️ Render\nUI · Views\nDecorations"]
Loading
Stage Responsibility
Shell Execute Git commands via Acode Executor API
Parse Process stdout/stderr into internal models
Render Display models in UI (resource state, decorations, views)

API Documentation

Git API

Access the Git API in Acode:

const gitPlugin = acode.require("git");
const gitAPI = gitPlugin.getAPI(1);

// Get repository
const repo = gitAPI.getRepository("/path/to/repositoy");

// repository status
await repo.status();

// Create a branch
await repo.createBranch("feature-branch", true);

// Commit
await repo.commit("Your commit message", { all: true });

// Push to remote
await repo.push("origin", "main");

SCM API

Access the SCM API:

const scm = acode.require("scm");

// Create a source control provider
const sourceControl = scm.createSourceControl("my-scm", "My SCM", "/public");

// Create resource groups
const changes = sourceControl.createResourceGroup("changes", "Changes");

// Add resources
changes.resourceStates = [
  {
    resourceUri: "/path/to/file",
    decorations: {
      strikeThrough: false,
    },
  },
];

See type definition files:

For complete API documentation, see DOCS.md.

Customization

Settings Overview

Setting Description Default
enabled Enable/disable Git integration true
useEditorAsCommitInput Use Acode editor for commit messages true
decorationsEnabled Show file decorations true
autorefresh Automatically refresh repository status true
autofetch Automatically fetch from remote true
autofetchPeriod Fetch interval in seconds 180
enableSmartCommit Commit all changes when nothing staged false
confirmSync Confirm before sync operation true
allowForcePush Allow force push operations false

💡 See all available settings in Acode → Settings → Plugins → Git SCM.

Command Palette Commands

Press Ctrl+Shift+P and type Git to see all available commands:

View all commands
Git: Clone                   Git: Init
Git: Pull                    Git: Push
Git: Fetch                   Git: Sync
Git: Commit                  Git: Commit (Amend)
Git: Undo Last Commit        Git: Create Branch
Git: Checkout                Git: Merge Branch
Git: Rebase Branch           Git: Add Remote
Git: Stage All Changes       Git: Unstage All Changes
...

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Credits & Attribution

This project (the Acode Git SCM integration using Executor) is licensed under the MIT License. See the LICENSE file.

Parts of this project are derived from or heavily inspired by the Visual Studio Code project and its Git extension:

The execution layer has been reworked to use Acode Executor API rather than VS Code's internal APIs.

Support & Contact


Happy coding ✨

About

Plugin for Acode to provide version control features

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • TypeScript 97.9%
  • SCSS 1.6%
  • JavaScript 0.5%