주말에 저는 Reddit을 통해 Flow Launcher용 플러그인과 관련된 프로젝트를 선택했습니다. Ubuntu Linux 환경에 맞게 fzf 및 rofi 버전을 만든 후 uLauncher로 포팅하는 것이 얼마나 어려울까?
여기에 제가 한 일을 기록합니다.
1. ~/.local/share/ulauncher/extensions/ 내부
새 디렉토리를 만듭니다. 제 경우에는 ~/.local/share/ulauncher/extensions/com.github.ubuntupunk.ulauncher-vim
을 만들었습니다.2. 다음 파일을 터치합니다:
├── images │ └── icon.png ├── versions.json ├── manifest.json └── main.py
3. versions.json에 다음 상용구를 배치합니다.
[ {"required_api_version": "2", "commit": "master"} ]
4. 매니페스트.json에서
{ "required_api_version": "2", "name": "Demo extension", "description": "Extension Description", "developer_name": "John Doe", "icon": "images/icon.png", "options": { "query_debounce": 0.1 }, "preferences": [ { "id": "demo_kw", "type": "keyword", "name": "Demo", "description": "Demo extension", "default_value": "dm" } ] }
5. main.py에서
from ulauncher.api.client.Extension import Extension from ulauncher.api.client.EventListener import EventListener from ulauncher.api.shared.event import KeywordQueryEvent, ItemEnterEvent from ulauncher.api.shared.item.ExtensionResultItem import ExtensionResultItem from ulauncher.api.shared.action.RenderResultListAction import RenderResultListAction from ulauncher.api.shared.action.HideWindowAction import HideWindowAction class DemoExtension(Extension): def __init__(self): super().__init__() self.subscribe(KeywordQueryEvent, KeywordQueryEventListener()) class KeywordQueryEventListener(EventListener): def on_event(self, event, extension): items = [] for i in range(5): items.append(ExtensionResultItem(icon='images/icon.png', name='Item %s' % i, description='Item description %s' % i, on_enter=HideWindowAction())) return RenderResultListAction(items) if __name__ == '__main__': DemoExtension().run()
6. 이제 매니페스트.json을 편집하세요.
{ "required_api_version": "2", "name": "Vim Prompter", "description": "Vim cheatsheet helper", "developer_name": "David Robert Lewis", "icon": "images/icon.png", "options": { "query_debounce": 0.1 }, "preferences": [ { "id": "vm_kw", "type": "keyword", "name": "Vim", "description": "Search for Vim commands", "default_value": "vm" } ]
7. main.py에 명령어 로딩 기능 추가
class VmExtension(Extension): def load_vim_commands(self): """Load Vim commands from JSON file.""" package_dir = os.path.dirname(os.path.abspath(__file__)) full_path = os.path.join(package_dir, 'db', 'commands.json') with open(full_path, 'r') as file: return json.load(file) def __init__(self): super().__init__() self.vim_commands = self.load_vim_commands() self.subscribe(KeywordQueryEvent, KeywordQueryEventListener())
8. 다음을 사용하여 db 폴더를 생성합니다.
commands.json
예제 구조:
{ "categories": { "navigation": { "name": "Navigation", "patterns": [ "scroll", "jump", "goto", "position" ], "subcategories": { "cursor": { "name": "Cursor Movement", "patterns": [ "move[s]? cursor", "^[hjkl]$", "^[HJKL]$", "^[wWeEbB]$" ] },
여기에서 전체 Commands.json을 볼 수 있습니다.
9. 키워드쿼리이벤트리스너를 수정하여 검색 기능을 구현합니다.
class KeywordQueryEventListener(EventListener): def on_event(self, event, extension): query = event.get_argument() or "" items = [] # If no query, show all commands (limited to first 8) commands_to_show = extension.vim_commands # If there's a query, filter commands if query: commands_to_show = [ cmd for cmd in extension.vim_commands if query.lower() in cmd['command'].lower() or query.lower() in cmd['description'].lower() ] # Limit results to first 8 matches for cmd in commands_to_show[:8]: items.append(ExtensionResultItem( icon='images/icon.png', name=cmd['command'], description=f"{cmd['name']} - {cmd['description']}", on_enter=HideWindowAction() )) return RenderResultListAction(items)
10. URL 열기 기능을 추가합니다. Vim 명령 URL을 열려면 webbrowser를 가져오고 on_enter 작업을 수정해야 합니다.
from ulauncher.api.shared.action.OpenUrlAction import OpenUrlAction class KeywordQueryEventListener(EventListener): def on_event(self, event, extension): query = event.get_argument() or "" items = [] commands_to_show = extension.vim_commands if query: commands_to_show = [ cmd for cmd in extension.vim_commands if query.lower() in cmd['command'].lower() or query.lower() in cmd['description'].lower() ] for cmd in commands_to_show[:8]: url = f"https://vim.rtorr.com/#:~:text={cmd['rtorr_description']}" items.append(ExtensionResultItem( icon='images/icon.png', name=cmd['command'], description=f"{cmd['name']} - {cmd['description']}", on_enter=OpenUrlAction(url) )) return RenderResultListAction(items)
11. 주요 변경 사항은 다음과 같습니다.
- OpenUrlAction 가져오기 추가
- HideWindowAction을 OpenUrlAction으로 대체했습니다
- 명령의 rtorr_description을 사용하여 URL을 구성했습니다
12. 전체 프로젝트 코드는 여기에서 볼 수 있습니다.
ulauncher-vim 저장소
여기에 ulauncher 확장 프로그램이 있습니다
참고자료
- https://dev.to/brpaz/an-introduction-to-ulauncher-extension-development-1m69
- https://ext.ulauncher.io/-/github-ubuntupunk-ulauncher-vim
위 내용은 명령 데이터베이스를 사용하여 ulauncher 확장 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 버전 3.10에 도입 된 Python의 새로운 "매치"진술에 대해 논의하며, 이는 다른 언어로 된 문장과 동등한 역할을합니다. 코드 가독성을 향상시키고 기존 IF-ELIF-EL보다 성능 이점을 제공합니다.

Python 3.11의 예외 그룹은 여러 예외를 동시에 처리하여 동시 시나리오 및 복잡한 작업에서 오류 관리를 향상시킵니다.

Python의 기능 주석은 유형 확인, 문서 및 IDE 지원에 대한 기능에 메타 데이터를 추가합니다. 코드 가독성, 유지 보수를 향상 시키며 API 개발, 데이터 과학 및 라이브러리 생성에 중요합니다.

이 기사는 파이썬의 단위 테스트, 이점 및 효과적으로 작성하는 방법에 대해 설명합니다. 테스트를 위해 UnitTest 및 Pytest와 같은 도구를 강조 표시합니다.

기사는 Python의 액세스 지정자에 대해 논의합니다. Python은 명명 규칙을 사용하여 엄격한 시행보다는 클래스 멤버의 가시성을 나타냅니다.

기사는 Python의 \ _ \ _ init \ _ \ _ () 메소드와 객체 속성 초기화에서 자기의 역할에 대해 설명합니다. \ _ \ _ init \ _ \ _ ()에 대한 다른 클래스 방법 및 상속의 영향도 포함됩니다.

이 기사는 @classmethod, @staticMethod 및 Python의 인스턴스 방법의 차이점에 대해 설명하며 속성, 사용 사례 및 이점을 자세히 설명합니다. 필요한 기능과 DA를 기반으로 올바른 메소드 유형을 선택하는 방법을 설명합니다.

inpython, youappendElementStoalistUsingTheAppend () 메소드 1) useappend () forsinglelements : my_list.append (4) .2) useextend () 또는 = formultiplementements : my_list.extend (other_list) 또는 my_list = [4,5,6] .3) useinsert () forspecificpositions : my_list.insert (1,5) .Bearware


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
