- swipl
- library
- error.pl
- debug.pl
- apply.pl
- lists.pl -- List Manipulation
- broadcast.pl -- Event service
- predicate_options.pl
- 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 -- Extensible arithmetic
- 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
- edit.pl -- Editor interface
- hashtable.pl -- Hash tables
- check.pl -- Consistency checking
- ansi_term.pl -- Print decorated text to ANSI consoles
- portray_text.pl -- Portray text
- terms.pl -- Term manipulation
- backcomp.pl -- Backward compatibility
- sort.pl
- intercept.pl -- Intercept and signal interface
- date.pl -- Process dates and times
- prolog_profile.pl -- Execution profiler
- listing.pl -- List programs and pretty print clauses
- quintus.pl -- Quintus compatibility
- optparse.pl -- command line parsing
- make.pl -- Reload modified source files
- threadutil.pl -- Interactive thread utilities
- qsave.pl -- Save current program as a state or executable
- zip.pl -- Access resource ZIP archives
- writef.pl -- Old-style formatted write
- prolog_codewalk.pl -- Prolog code walker
- prolog_stack.pl -- Examine the Prolog stack
- prolog_debug.pl -- User level debugging tools
- help.pl -- Text based manual
- exceptions.pl -- Exception classification
- when.pl -- Conditional coroutining
- files.pl
- statistics.pl -- Get information about resource usage
- wfs.pl -- Well Founded Semantics interface
- tty.pl -- Terminal operations
- prolog_trace.pl -- Print access to predicates
- prolog_autoload.pl -- Autoload all dependencies
- prolog_versions.pl -- Demand specific (Prolog) versions
- charsio.pl -- I/O on Lists of Character Codes
- prolog_jiti.pl -- Just In Time Indexing (JITI) utilities
- heaps.pl -- heaps/priority queues
- increval.pl -- Incremental dynamic predicate modification
- tables.pl -- XSB interface to tables
- fastrw.pl -- Fast reading and writing of terms
- prolog_coverage.pl -- Coverage analysis tool
- rwlocks.pl -- Read/write locks
- varnumbers.pl -- Utilities for numbered terms
- strings.pl -- String utilities
- macros.pl -- Macro expansion
- explain.pl -- Describe Prolog Terms
- prolog_metainference.pl -- Infer meta-predicate properties
- system.pl -- System utilities
- prolog_history.pl -- Per-directory persistent commandline history
- prolog_config.pl -- Provide configuration information
- shell.pl -- Elementary shell commands
- prolog_wrap.pl -- Wrapping predicates
- oset.pl -- Ordered set manipulation
- base32.pl -- Base32 encoding and decoding
- streams.pl -- Manage Prolog streams
- codesio.pl -- I/O on Lists of Character Codes
- coinduction.pl -- Co-Logic Programming
- win_menu.pl -- Console window menu
 
 
- library
- csv(?Rows)// is det
- csv(?Rows, +Options)// is det
- Prolog DCG to `read/write' CSV data. Options:
- separator(+Code)
- The comma-separator. Must be a character code. Default is
(of course) the comma. Character codes can be specified
using the 0' notation. E.g., using separator(0';)parses a semicolon separated file.
- ignore_quotes(+Boolean)
- If true(default false), threat double quotes as a normal character.
- strip(+Boolean)
- If true(defaultfalse), strip leading and trailing blank space. RFC4180 says that blank space is part of the data.
- skip_header(+CommentLead)
- Skip leading lines that start with CommentLead. There is
no standard for comments in CSV files, but some CSV files
have a header where each line starts with #. After skipping comment lines this option causes csv//2 to skip empty lines. Note that an empty line may not contain white space characters (space or tab) as these may provide valid data.
- convert(+Boolean)
- If true(default), use name/2 on the field data. This translates the field into a number if possible.
- case(+Action)
- If down, downcase atomic values. Ifup, upcase them and ifpreserve(default), do not change the case.
- functor(+Atom)
- Functor to use for creating row terms. Default is row.
- arity(?Arity)
- Number of fields in each row. This predicate raises
a domain_error(row_arity(Expected), Found)if a row is found with different arity.
- match_arity(+Boolean)
- If false(defaulttrue), do not reject CSV files where lines provide a varying number of fields (columns). This can be a work-around to use some incorrect CSV files.