- swipl
- library
- error.pl
- debug.pl
- apply.pl
- lists.pl
- broadcast.pl -- Event service
- predicate_options.pl -- Access and analyse predicate options
- shlib.pl -- Utility library for loading foreign objects (DLLs, shared objects)
- option.pl -- Option list processing
- thread_pool.pl -- Resource bounded thread management
- gensym.pl -- Generate unique symbols
- settings.pl
- arithmetic.pl
- main.pl -- Provide entry point for scripts
- readutil.pl -- Read utilities
- operators.pl -- Manage operators
- pairs.pl -- Operations on key-value lists
- prolog_source.pl -- Examine Prolog source-files
- quasi_quotations.pl -- Define Quasi Quotation syntax
- url.pl -- Analysing and constructing URL
- www_browser.pl -- Open a URL in the users browser
- prolog_colour.pl -- Prolog syntax colouring support.
- record.pl -- Access compound arguments by name
- prolog_xref.pl -- Prolog cross-referencer data collection
- occurs.pl -- Finding and counting sub-terms
- ordsets.pl -- Ordered set manipulation
- assoc.pl -- Binary associations
- ugraphs.pl -- Graph manipulation library
- iostream.pl -- Utilities to deal with streams
- atom.pl -- Operations on atoms
- prolog_pack.pl -- A package manager for Prolog
- solution_sequences.pl -- Modify solution sequences
- git.pl -- Run GIT commands
- ctypes.pl -- Character code classification
- utf8.pl -- UTF-8 encoding/decoding on lists of character codes.
- base64.pl -- Base64 encoding and decoding
- persistency.pl -- Provide persistent dynamic predicates
- pure_input.pl -- Pure Input from files and streams
- nb_set.pl -- Non-backtrackable sets
- aggregate.pl -- Aggregation operators on backtrackable predicates
- csv.pl -- Process CSV (Comma-Separated Values) data
- dialect.pl -- Support multiple Prolog dialects
- apply_macros.pl -- Goal expansion rules to avoid meta-calling
- yall.pl -- Lambda expressions
- prolog_code.pl -- Utilities for reasoning about code
- dif.pl -- The dif/2 constraint
- thread.pl -- High level thread primitives
- rbtrees.pl -- Red black trees
- nb_rbtrees.pl -- Non-backtrackable operations on red black trees
- random.pl -- Random numbers
- sandbox.pl -- Sandboxed Prolog code
- prolog_format.pl -- Analyse format specifications
- pprint.pl -- Pretty Print Prolog terms
- modules.pl -- Module utility predicates
- lazy_lists.pl -- Lazy list handling
- edinburgh.pl -- Some traditional Edinburgh predicates
- prolog_clause.pl -- Get detailed source-information about a clause
- prolog_breakpoints.pl -- Manage Prolog break-points
- dicts.pl -- Dict utilities
- help.pl -- Text based manual
- tty.pl -- Terminal operations
- backcomp.pl -- Backward compatibility
- date.pl -- Process dates and times
- listing.pl -- List programs and pretty print clauses
- prolog_profile.pl -- Execution profiler
- quintus.pl -- Quintus compatibility
- charsio.pl -- I/O on Lists of Character Codes
- prolog_autoload.pl -- Autoload all dependencies
- check.pl -- Consistency checking
- optparse.pl -- command line parsing
- base32.pl -- Base32 encoding and decoding
- codesio.pl -- I/O on Lists of Character Codes
- coinduction.pl -- Co-Logic Programming
- heaps.pl -- heaps/priority queues
- sort.pl
- statistics.pl -- Get information about resource usage
- terms.pl -- Term manipulation
- varnumbers.pl -- Utilities for numbered terms
- when.pl -- Conditional coroutining
- ansi_term.pl -- Print decorated text to ANSI consoles
- strings.pl -- String utilities
- explain.pl -- Describe Prolog Terms
- threadutil.pl -- Interactive thread utilities
- prolog_stack.pl -- Examine the Prolog stack
- edit.pl -- Editor interface
- make.pl -- Reload modified source files
- prolog_codewalk.pl -- Prolog code walker
- prolog_metainference.pl -- Infer meta-predicate properties
- wfs.pl -- Well Founded Semantics interface
- prolog_config.pl -- Provide configuration information
- zip.pl -- Access resource ZIP archives
- oset.pl -- Ordered set manipulation
- tables.pl -- XSB interface to tables
- prolog_trace.pl -- Print access to predicates
- portray_text.pl -- Portray text
- shell.pl -- Elementary shell commands
- hashtable.pl -- Hash tables
- prolog_wrap.pl -- Wrapping predicates
- win_menu.pl -- Console window menu
- system.pl -- System utilities
- prolog_debug.pl -- User level debugging tools
- prolog_coverage.pl -- Coverage analysis tool
- files.pl
- rwlocks.pl -- Read/write locks
- macros.pl -- Macro expansion
- intercept.pl -- Intercept and signal interface
- prolog_versions.pl -- Demand specific (Prolog) versions
- writef.pl -- Old-style formatted write
- fastrw.pl -- Fast reading and writing of terms
- prolog_jiti.pl -- Just In Time Indexing (JITI) utilities
- qsave.pl -- Save current program as a state or executable
- increval.pl -- Incremental dynamic predicate modification
- streams.pl -- Manage Prolog streams
- prolog_history.pl -- Per-directory persistent commandline history
- library
- parse_url(?URL, ?Attributes) is det
- Construct or analyse a URL. URL is an atom holding a URL or a
variable. Attributes is a list of components. Each component is
of the format Name(Value). Defined components are:
- protocol(Protocol)
- The used protocol. This is, after the optional
url:
, an identifier separated from the remainder of the URL using :. parse_url/2 assumes thehttp
protocol if no protocol is specified and the URL can be parsed as a valid HTTP url. In addition to the RFC-1738 specified protocols, thefile
protocol is supported as well. - host(Host)
- Host-name or IP-address on which the resource is located. Supported by all network-based protocols.
- port(Port)
- Integer port-number to access on the \arg{Host}. This only appears if the port is explicitly specified in the URL. Implicit default ports (e.g., 80 for HTTP) do not appear in the part-list.
- path(Path)
- (File-) path addressed by the URL. This is supported for the
ftp
,http
andfile
protocols. If no path appears, the library generates the path/
. - search(ListOfNameValue)
- Search-specification of HTTP URL. This is the part after the
?
, normally used to transfer data from HTML forms that use the HTTP GET method. In the URL it consists of a www-form-encoded list of Name=Value pairs. This is mapped to a list of Prolog Name=Value terms with decoded names and values. - fragment(Fragment)
- Fragment specification of HTTP URL. This is the part after
the
#
character.
The example below illustrates all of this for an HTTP URL.
?- parse_url('http://www.xyz.org/hello?msg=Hello+World%21#x', P). P = [ protocol(http), host('www.xyz.org'), fragment(x), search([ msg = 'Hello World!' ]), path('/hello') ]
By instantiating the parts-list this predicate can be used to create a URL.