svgsym: A tool to prune unused symbols from icon SVG files.

[ gpl, program, utility ] [ Propose Tags ]


Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees


  • No Candidates
Versions [RSS],
Change log
Dependencies array (>=0.5 && <0.6), base (>=4.14 && <4.17), bytestring (>=0.10 && <0.11), containers (>=0.6 && <0.7), directory (>=1.3 && <1.4), filepath (>=1.4 && <1.5), filepattern (>=0.1.2 && <0.2), optparse-applicative (>=0.16 && <0.17), regex-base (>=0.94 && <0.95), regex-tdfa (>=1.3.1 && <1.4), xml (>=1.3 && <1.4) [details]
License GPL-3.0-or-later
Copyright (c) 2022 Robert Helgesson
Author Robert Helgesson
Category Utility
Home page
Bug tracker
Uploaded by RobertHelgesson at 2022-05-07T08:19:39Z
Distributions NixOS:
Executables svgsym
Downloads 94 total (3 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs not available [build log]
Last success reported on 2022-05-07 [all 1 reports]

Readme for svgsym-

[back to package description]


This is a simple tool to prune unused symbols from icon SVG files.

Specifically, this tools takes as input

  • an SVG file that consists only of symbol elements,

  • one of more glob patterns of source files, and

  • a regular expression that identifies symbol references.

It then scans your source files for references to symbols in the SVG file. The output of the tool is an SVG file that contains only the symbols referenced in your source files.


We can prune the all.svg file from project for a Haskell project by running the below command. Note that the symbol regular expression consist of a single capture group that captures the actual symbol identifier.

$ svgsym css-gg/all.svg \
    --content './src/**/*.hs' \
    --symbol '"(gg-[a-z]+)"' \
    > ./output/static/css-gg.svg

Bug Reports and Sending Patches

Bug reports and patches are managed through my sourcehut public inbox.


The intended development flow is to use a Nix Flake development shell, e.g., using Direnv or directly running

$ nix develop .

This will help set up a shell containing the necessary development dependencies. This shell will also be populated with utilities that can be run directly in the terminal:

  • p-format – formats the project's Cabal, Haskell, and Nix code.


GNU General Public License v3.0 or later