Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/daipeihust/im-select
đ Switch your input method through terminal
https://github.com/daipeihust/im-select
im keyboard-layout linux mac terminal windows
Last synced: 4 days ago
JSON representation
đ Switch your input method through terminal
- Host: GitHub
- URL: https://github.com/daipeihust/im-select
- Owner: daipeihust
- License: mit
- Created: 2018-05-29T05:52:30.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-25T08:30:24.000Z (9 months ago)
- Last Synced: 2025-02-09T09:07:19.480Z (11 days ago)
- Topics: im, keyboard-layout, linux, mac, terminal, windows
- Language: C++
- Homepage:
- Size: 24.5 MB
- Stars: 1,061
- Watchers: 10
- Forks: 75
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Support: support_me.jpeg
Awesome Lists containing this project
README
# Welcome to **im-select** đ
data:image/s3,"s3://crabby-images/bd2f3/bd2f3af09a534e77ae59325c832040f418a304c2" alt="image"
Switch your input method in shell. This project is a basic support for VSCodeVim. It provides the command line program for VSCodeVim's autoSwitchIM function.Â
data:image/s3,"s3://crabby-images/26c3d/26c3db73eb0334270c9162aa3b428f5acf6d1053" alt=""
data:image/s3,"s3://crabby-images/fe6a2/fe6a2901900e19f32f2319effe5d3e20e9611771" alt="GitHub repo size"
data:image/s3,"s3://crabby-images/0d146/0d14644b8f6908b679ed09b54fd9ad70d825c9bb" alt="GitHub repo file count"
data:image/s3,"s3://crabby-images/7236a/7236a806b1141eb68def41fabd3700a56a38baa0" alt="GitHub release (by tag)"
data:image/s3,"s3://crabby-images/45731/457313a25624679a9fdd9a6532e3308ebde3b811" alt="GitHub issues"
data:image/s3,"s3://crabby-images/b05e2/b05e24f87d76cbbf39d62135df933ec7b932076d" alt="GitHub"
data:image/s3,"s3://crabby-images/7652e/7652e60611b33ebdb68bfe84c3c9c0e73ad026d8" alt="GitHub release (latest by date)"
data:image/s3,"s3://crabby-images/e4672/e46720143e3bf49ca10ceb8715f125bff4451e4f" alt="GitHub commit activity"
data:image/s3,"s3://crabby-images/8445c/8445c0ee7499cfcb79f1572f42c96b3b50874351" alt="GitHub contributors"
data:image/s3,"s3://crabby-images/95668/956684a1a7ddc3aa2c5617d9fbb336cfbf2491f4" alt="GitHub last commit"
data:image/s3,"s3://crabby-images/09d1e/09d1e5d35e67078e384978c143098179f541c485" alt="GitHub Discussions"
data:image/s3,"s3://crabby-images/2770d/2770d102d3bcadb3e2f0bc5ece512050088d62e9" alt="GitHub Repo stars"Â
[English](./README.md) | [įŽäŊä¸æ](./README_CN.md)
## Prerequisites
- using [VSCodeVim](https://github.com/VSCodeVim/Vim)
- have a Mac/Windows/Linux device
- download [git-bash](https://gitforwindows.org/)(if you on windows)
- know how to use [shell](https://zh.wikipedia.org/wiki/Unix_shell)## Install
### macOS
#### Homebrew
```shell
brew tap daipeihust/tap
brew install im-select
```Or you can run following command in your console:
```shell
curl -Ls https://raw.githubusercontent.com/daipeihust/im-select/master/install_mac.sh | sh
```The im-select program will be downloaded to your `/usr/local/bin/` path.
### windows
Download the [im-select.exe](https://github.com/daipeihust/im-select/raw/master/win/out/x86/im-select.exe), and move it to the proper path.(If you need the 64 bit version, you can download [this one](https://github.com/daipeihust/im-select/raw/master/im-select-win/out/x64/im-select.exe).)
### linux
You don't have to install this for linux. linux have tools to switch input methods
## Usage
## macOS
If your PATH contains `/usr/local/bin`, you can just use `im-select` instead of `/usr/local/bin/im-select`
### To get current input method key
```shell
/usr/local/bin/im-select
```
### To switch current input method
```shell
/usr/local/bin/im-select imkey
```
For example `/usr/local/bin/im-select com.apple.keylayout.US`## linux
### ibus
[@mengbo](https://github.com/mengbo) provided this configuration for ibus
```
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "xkb:us::eng",
"vim.autoSwitchInputMethod.obtainIMCmd": "/usr/bin/ibus engine",
"vim.autoSwitchInputMethod.switchIMCmd": "/usr/bin/ibus engine {im}"
```### xkb-switch
[@VEL4EG](https://github.com/VEL4EG) provided this configuration for xkb-switch
```
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "us",
"vim.autoSwitchInputMethod.obtainIMCmd": "/usr/local/bin/xkb-switch",
"vim.autoSwitchInputMethod.switchIMCmd": "/usr/local/bin/xkb-switch -s {im}"
```### fcitx
[@yunhao94](https://github.com/yunhao94) provided this configuration for fcitx
```
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "1",
"vim.autoSwitchInputMethod.obtainIMCmd": "/usr/bin/fcitx-remote",
"vim.autoSwitchInputMethod.switchIMCmd": "/usr/bin/fcitx-remote -t {im}",
```### gdbus
[@d-r-q](https://github.com/d-r-q) provide this configuration for gdbus
Put `gdbus call --session --dest org.gnome.Shell --object-path /org/gnome/Shell --method org.gnome.Shell.Eval "imports.ui.status.keyboard.getInputSourceManager().currentSource.index" | awk -F'[^0-9]*' '{print $2}'` into get-im.sh.
Put `gdbus call --session --dest org.gnome.Shell --object-path /org/gnome/Shell --method org.gnome.Shell.Eval "imports.ui.status.keyboard.getInputSourceManager().inputSources[$1].activate()"` into set-im.sh.
```
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "0",
"vim.autoSwitchInputMethod.obtainIMCmd": "",
"vim.autoSwitchInputMethod.switchIMCmd": " {im}",
```### qdbus (KDE)
[@igorechek06](https://igorek.dev) provided this configuration for qdbus
```
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "0",
"vim.autoSwitchInputMethod.obtainIMCmd": "/usr/bin/qdbus org.kde.keyboard /Layouts getLayout",
"vim.autoSwitchInputMethod.switchIMCmd": "/usr/bin/qdbus org.kde.keyboard /Layouts setLayout {im}",
```## windows
The im-select.exe is command line program, but it can't work in cmd or powershell. It's microsoft's bug, the keyboard API doesn't support in cmd and powershell. I recommend you git-bash.> Note: The git-bash is not required. It's only used to get current input method key, which needed in VSCodeVim's configuration.
## Run tests
### To get current keyboard locale
```shell
/path/to/im-select.exe
```### To switch current keyboard locale
```shell
/path/to/im-select.exe locale
```> Note: The path in windows is like: C:\Users\path\to\file
## Author
## đ¤ Contributing
If you find some issues, welcome to create pull request!
## Show your support
Give a âī¸ if this project helped you!
Buy me a coffee, if you like it! If you have any problems, you can contact me via email!
![]()
![]()
## đ License
This project is licensed under the terms of the MIT license.