An open API service indexing awesome lists of open source software.

https://github.com/karolkiljan/krux

Ork z kopalni. Mówi mało. Wie dużo. Pomaga.
https://github.com/karolkiljan/krux

claude-code orc plugin polish token-compression

Last synced: about 1 month ago
JSON representation

Ork z kopalni. Mówi mało. Wie dużo. Pomaga.

Awesome Lists containing this project

README

          



krux


Krux kopać ruda w Górnicza Dolina. Teraz Krux robić kod w Dolina Krzemowa.

---

Ork wiedzieć dużo. Ork gadać mało. Claude Code słuchać.

Redukcja tokenów ~55% avg (12 promptów, haiku). Najlepiej na bugfixach i setupie.

## Przed i po

### Zwykły Claude (81 tokenów)

> "Oczywiście, chętnie pomogę! Problem który napotykasz prawdopodobnie wynika z tego, że tworzysz nową referencję obiektu przy każdym renderowaniu. Kiedy przekazujesz obiekt inline jako prop, React widzi go jako inny obiekt za każdym razem i wywołuje rerenderowanie. Powinieneś użyć useMemo do memoizacji obiektu."

### Krux Claude (18 tokenów)

> "Nowa referencja każdy render. Inline prop → nowy obiekt → rerender. `useMemo`. Zrobione."

### Zwykły Claude

> "Świetne pytanie! Błąd który napotykasz najprawdopodobniej wynika z niepoprawnego sprawdzania wygaśnięcia tokenu JWT w middleware uwierzytelniania. Sprawdzanie używa operatora mniejszości zamiast mniejszości lub równości. Pozwól że zaproponuję poprawkę tego problemu."

### Krux Claude

> "Auth middleware padać. Token expiry: `<` zamiast `<=`. Fix linia 14."

**Ten sam fakt. Mniej słów. Ork wiedzieć dużo - ork nie gadać dużo.**

```
┌─────────────────────────────────────────────────┐
│ bugfix / setup ████████████████ 72–76% │
│ code-review █████████████░░░ 65% │
│ debugging ████████████░░░░ 37–59% │
│ architecture ██████████░░░░░░ 53% │
│ devops / refactor █████████░░░░░░░ 42–49% │
│ explanation ████████░░░░░░░░ 44% │
│ RAZEM ███████████░░░░░ 55% │
│ │
│ TREŚĆ TECHNICZNA ████████████████ 100% │
└─────────────────────────────────────────────────┘
```

## Dlaczego ork - nie tylko kompresja

Krux nie gadać więcej niż trzeba.

| Zwykły Claude | Krux Claude |
|---------------|-------------|
| `zrobiłem` | `zrobić` - bezokolicznik = wszystkie czasy |
| `przez middleware` | `middleware` - mianownik zawsze |
| `jest pusty` | `pusty` - brak „być" |
| `jeśli nie naprawisz, błąd` | `napraw, albo błąd` |
| `wiem, że jest błąd` | `wiem: błąd` - bez „że" |

**Górnicza Dolina** uczyć: każde słowo kosztować. Każdy cios musieć trafiać.
**Dolina Krzemowa** uczyć: każdy token kosztować magiczna ruda. Model szybszy - myśleć mniej.

## Orkowie — armia generala Krux

Krux teraz **general**. Dowodzi 14 orków — specjalistycznych agentów, każdy do konkretnej roboty. Nie musisz wybierać — piszesz po polsku, krux sam wzywa właściwego orka na podstawie kontekstu. Możesz też wywołać wprost: `/krux:ork-nazwa`.

### Kiedy który ork się odpala

| Ork | Rola | Frazy które go wzywają |
|-----|------|------------------------|
| ork-architekt | Projekt architektury | „architektura", „projekt", „struktura", „moduły" |
| ork-badacz | Eksploracja kodu | „znajdź", „gdzie jest", „szukaj", „explore" |
| ork-czysciciel | Refaktoring (dedup, podział plików, styl) | „refaktoryzuj", „przerób", „uporządkuj", „duplikacja" |
| ork-kowal | Backend (API, bazy danych, server) | „backend", „API", „endpoint", „baza danych", „SQL" |
| ork-malarz | UI/frontend | „UI", „frontend", „wygląd", „design", „CSS", „komponent" |
| ork-niszczyciel | Usuwanie martwego kodu | „usuń", „martwy kod", „unused", „nieużywane", „zbędny" |
| ork-sedzia | Code review | „review", „przejrzyj", „audyt", „ocena kodu" |
| ork-skryba | Dokumentacja | „docs", „dokumentacja", „README", „komentarze" |
| ork-sprawdzacz | Testy/weryfikacja | „test", „testy", „npm test", „verify", „coverage" |
| ork-straznik | Audyt hooków pluginu krux | po zmianie w `hooks/*.js`, „audytuj hook" |
| ork-tropiciel | Debugging | „debug", „błąd", „stack trace", „napraw bug", „crash" |
| ork-wroz | Analiza ryzyka, planowanie | „ryzyko", „co jeśli", „plan", „konsekwencje" |
| ork-wynalazca | Prototyp, MVP, nowa funkcja | „prototype", „MVP", „nowy", „dodaj funkcję", „szybko" |
| ork-wyrocznia | Q&A, wyjaśnienia | „wyjaśnij", „co to", „jak działa", „jak zrobić" |

### Co zwraca ork

Każdy ork zwraca standardowy JSON z polami: `status` (ok/warning/error), `summary` (1 zdanie dla ciebie), `details` (szczegóły dla kruxa), opcjonalnie `files`, `tests`, `verdict`. Krux bierze `summary` i podsumowuje po swojemu — dostajesz zwięzły wynik, nie wywód.

### Wielu orków na raz

Dwa skille dla zaawansowanych workflow:

- `/krux-orki-lancuch` — sekwencja orków gdzie wynik pierwszego = input drugiego.
Przykład: ork-badacz znajdzie → ork-tropiciel naprawi → ork-sprawdzacz przetestuje.
- `/krux-orki-rownolegle` — wielu orków jednocześnie na niezależne zadania.
Przykład: 3 bugi w różnych plikach → 3 ork-tropiciele równolegle.

## Skille

| Komenda | Co robi |
|---------|---------|
| *(domyślnie aktywny)* | Tryb krux - łamana gramatyka, maksymalna kompresja |
| `/krux-commit` | Commit message - Conventional Commits, ≤50 znaków |
| `/krux-review` | Code review - `L42: 🔴 bug: opis. fix.` |
| `/krux-compress ` | Przepisz markdown w stylu krux, ~40% mniej tokenów |
| `/krux-context-threshold ` | Ustaw próg tokenów dla context watch (domyślnie 85000) |
| `/krux-flow [on\|off\|cel]` | Tryb iteracyjny — jeden ruch na raz, bez upfront planu. Włącz też przez `flow`, wyłącz `stop flow` |
| `/krux-help` | Karta referencyjna - wszystkie prawa i słownik |

## Wymagania

- Claude Code (dostarcza Node.js — plugin nie wymaga dodatkowych zależności)

## Instalacja

```bash
claude plugin marketplace add karolkiljan/krux
claude plugin install krux@krux-marketplace
```

## Użycie

Aktywuje się sam przy starcie sesji. Plugin sam proponuje konfigurację statusline `[KRUX]` przy pierwszym uruchomieniu.

**Trwałe przełączanie** (persystuje między sesjami — zapisuje stan do `~/.claude/.krux-mode`):

| Fraza | Efekt |
|-------|-------|
| `krux` / `włącz krux` / `start krux` / `aktywuj krux` | Włącz |
| `stop krux` / `wyłącz krux` / `normalny tryb` | Wyłącz |

**Ważne:** fraza musi być **całą wiadomością** — bez dodatkowego tekstu. `krux` działa, `hej krux włącz się` nie. Polskie znaki opcjonalne (regex ogarnie obie wersje).

**Slash command `/krux:krux`** — jednorazowy. Wciąga skill do bieżącej sesji, ale **nie zmienia** `.krux-mode`. Następna sesja wróci do zapisanego stanu.

**Sprawdzenie stanu:**
```bash
cat ~/.claude/.krux-mode # on albo off
```

Wyłączenie trwa aż do ręcznego włączenia - niezależnie od sesji.

## Konfiguracja

**Zmienne środowiskowe:**
```bash
export KRUX_DEFAULT_MODE=off # wyłącz domyślnie
export KRUX_CONTEXT_THRESHOLD=85000 # próg ostrzeżenia context watch (tokeny)
export KRUX_CONTEXT_COOLDOWN=300 # minimalny odstęp między ostrzeżeniami (sekundy)
export KRUX_CONTEXT_WATCH=off # wyłącz context watch (persona krux zostaje)
```

**Plik stanu** (`~/.claude/.krux-mode`) - automatycznie zarządzany przez hook:
```
off
```

## Odinstalowanie

`claude plugin uninstall krux` usuwa plugin, ale plugin zostawia w `~/.claude/` kilka plików stanu. Do wyczyszczenia ręcznie:

```bash
rm -f ~/.claude/.krux-active ~/.claude/.krux-mode \
~/.claude/.krux-statusline-asked \
~/.claude/.krux-statusline.sh ~/.claude/.krux-statusline.ps1
```

Jeśli zarejestrowany był statusline `[KRUX]`, usuń pole `statusLine` z `~/.claude/settings.json`.

Projektowe `.claude/settings.local.json` może trzymać wpis `enabledPlugins["krux@krux-marketplace"]` — usuń klucz ręcznie, jeśli chcesz wyczyścić do zera.

## Granice

- **Kod / commity / PR:** pisz normalnie - krux nie modyfikuje kodu
- **Ostrzeżenia bezpieczeństwa:** pełna klarowność zawsze
- **Nieodwracalne operacje:** pełne potwierdzenie, bez skrótów
- **`stop krux`:** natychmiastowe wyłączenie

## Inspiracja

Polska adaptacja [caveman](https://github.com/JuliusBrussee/caveman) - JuliusBrussee.

## Licencja

MIT

---

Jak podoba - token kosztować dużo ruda. Jak chcieć [da rude](https://www.youtube.com/watch?v=y6120QOlsfU) - [móc](https://cuplink.to/bibsonello).



Kup kawę

*Górnicza Dolina dawać siłę. Dolina Krzemowa dawać zastosowanie. Krux dawać obom.*