Did you know ... Search Documentation:
Packs (add-ons) for SWI-Prolog

Below is a list of known packages. Please be aware that packages are not moderated. Installing a pack does not execute code in the pack, but simply loading a library from the pack may execute arbitrary code. More information about packages is available here. You can search for packages from the Prolog command line using pack_list/1. This contacts the pack server for packs that match by name or title. A leading i indicates that the pack is already installed, while p merely indicates that it is known by the server.

?- pack_list(graph).
p callgraph@0.3.4           - Predicate call graph visualisation
i graphml@0.1.0             - Write GraphML files
i gvterm@1.1                - Show Prolog terms using graphviz
p musicbrainz@0.6.3         - Musicbrainz client library
p sindice@0.0.3             - Access to Sindice semantic web search engine

After finding the right pack, the pack and its dependencies can be installed using the pack_install/1 as illustrated below.

?- pack_install(hello).

Clicking the package shows details and allows you to rate and comment the pack.

Pack
tot: 38
Version
(#older)
Downloads
tot: 10,068
(#latest)
Rating
(#votes/
#comments)
Title
list_util0.13.0193,0691
Predicates for working with lists
regex0.3.3111,6341,239
Regular expressions
tap1.0.3261,3471
Automated tests via Test Anything Protocol
mavis0.2.3131,0642
Optional type declarations
julian0.1.3768314
Date and time library
func0.4.28349217
(2/2)
Function application and composition
spawn0.0.1174
Easy concurrency
quickcheck0.3.0171531
QuickCheck randomized testing
djson0.0.32140134
Declarative JSON
dcg_util0.3.1313825
(1/1)
DCG utility predicates
function_expansion0.1.241095
(1/1)
Help for writing function-like macros
atom_feed0.2.0410086
Parse Atom and RSS feeds
interpolate0.1.02911
String interpolation
delay0.3.378456
Avoid instantiation errors for built-in predicates
amazon_api0.0.328174
Interface to Amazon APIs
sweet0.1.137368
Sugar to make Prolog a little sweeter
maybe0.1.137269
The maybe type represents an optional value
condition0.1.136553
Condition system a la Common Lisp
bencode0.0.153
Bencoding from BitTorrent protocol
roman0.1.051
Roman numerals
julian_lang_en0.0.214948
Parse English language phrases into library(julian) constraints
jolog0.0.314737
Concurrency via join calculus
format_spec0.0.214443
Parse and check format/2 specifications
lcs0.0.143
Longest common subsequence
web0.1.113936
Easy web client
uri_qq0.3.033827
URI quasiquotations
semantria0.0.433828
Use Semantria natural language API
thousands0.2.033429
(0/1)
Thousands separator for large integers
readability_parser0.0.433021
Readability Parser API
dotcloud0.0.213024
Conveniences for running on dotCloud
chan0.2.029
Directional channels for thread communication
unified_diff0.0.127
Parse and generate unified diffs
miser0.0.127
Build self-optimizing predicates
tidylog0.0.116
term_diff0.0.111513
pager0.1.01121
Send output to user's preferred pager
notes8000.1.01101
Query phone number data from 800notes.com
nanp0.1.01109
phone numbers in the North American Numbering Plan