Personal patchset for Telegram Desktop.
No support, no warranty, no promises. Issues, questions, and feature requests will not be answered. Use at your own risk. See LICENSE.
Inspired by inugram (Telegram Android patchset).
patches/— exported.patchfiles, applied in order fromseries.series— patch order; export target, do not hand-edit.upstream-commit— pinned tdesktop SHA.src/cpp/arcanegram/— fork C++ code, junctioned into the worktree at setup.res/— fork-owned resources (lang strings, icons).worktree/— gitignored local tdesktop checkout managed by stgit.
Patch groups: bugfix | feature | debloat | hooks | misc.
Requirements:
- Node 20+, pnpm
- git, stgit (
stg --version) - tdesktop build toolchain — see tdesktop build docs
pnpm install
pnpm run setupClones tdesktop into worktree/ (with submodules — first run is ~15 min, ~5 GB), applies patches, junctions fork code in. Open worktree/ in your IDE and build the Telegram target.
cd worktree
stg new feature__my-thing -m 'short description'
# ...edit worktree...
stg refresh
cd ..
pnpm run export
git add patches/ series
git commit -m "feat(patches): short description"To edit an existing patch, push it to the top first:
cd worktree && stg float feature__my-thing
# ...edit...
stg refresh
cd .. && pnpm run exportpnpm run rebase latest
# ...resolve any conflicts in worktree, then:
pnpm run export- Directory junctions are used instead of symlinks for the fork-source dir, so no admin / dev mode required.
- File-level "symlinks" fall back to copy +
git update-index --skip-worktreeon platforms that refusefs.symlinkfor files.
- libyuv duplicate symbols (
LNK2005) on Windows Debug. libavif and tg_owt both statically bundlelibyuv, causingLNK2005for ~50 symbols (ScalePlane,CopyPlane, etc.) when linking with PDB (/Zi). Worked around by passing-DCMAKE_MSVC_DEBUG_INFORMATION_FORMAT=(empty) inbuild-telegram.bat, which disables debug info and avoids the conflict. The binary builds and runs correctly. If you re-enable/Zi, expect duplicate-symbol link errors.
Unlicense (public domain) with an explicit no-support clause. Do whatever you want with the code; expect nothing in return.