Disk ARchive  2.5.0
Full featured and portable backup and archiving tool
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups
File List
Here is a list of all documented files with brief descriptions:
o*archive.hppArchive class is defined in this module
o*archive_options.hppThis file contains a set of classes used to transmit options to archive operation
o*archive_version.hppClass archive_version that rules which archive format to follow
o*cache.hppCache class
o*capabilities.hppProvide information about current thread (underlying using the widthdrawn POSIX.1e API)
o*cat_all_entrees.hppInclude file gathering all entree found in a catalogue
o*cat_blockdev.hppClass used to record block special devices in a catalogue
o*cat_chardev.hppClass used to record character special devices in a catalogue
o*cat_detruit.hppUsed to record information in a catalogue about a deleted file (differential backup context)
o*cat_device.hppParent class for all special devices inodes
o*cat_directory.hppClass used to organize objects in tree in catalogue as like directories in a filesystem
o*cat_door.hppClass used in a catalogue to store solaris door filesystem entries
o*cat_entree.hppBase class for all object contained in a catalogue
o*cat_eod.hppObject exchanged with a catalogue (never stored in it) to signal the end of a directory
o*cat_etoile.hppClass holding an cat_inode object that get pointed by multiple mirage objects (smart pointers) to record hard links in a catalogue
o*cat_file.hppClass used to record plain files in a catalogue
o*cat_ignored.hppClass used to remember that an entry has been ignored and shall not be recorded as deleted using a detruit object in a catalogue
o*cat_ignored_dir.hppClass used to remember in a catalogue that a cat_directory has been ignored
o*cat_inode.hppBase object for all inode types, managed EA and FSA, dates, permissions, ownership, ..
o*cat_lien.hppClass used to store symbolic links in a catalogue
o*cat_mirage.hppSmart pointer to an etoile object. Used to store hard link information inside a catalogue
o*cat_nomme.hppBase class of all objects contained in a catalogue and that can be named
o*cat_prise.hppClass to record filesystem (UNIX) sockets in a catalogue
o*cat_tools.hppSet of routines used by catalogue related classes
o*cat_tube.hppClass to record named pipes in a catalogue
o*catalogue.hppHere is defined the many classed which is build of the catalogue
o*command_line.hppRouting in charge of the command-line and included files parsing
o*compile_time_features.hppNested namespace containing routines that give features activated at compile time
o*compressor.hppCompression engine implementation
o*config.h
o*config_file.hppSpecific routines to manages included files's targets
o*crc.hppClass crc definition, used to handle Cyclic Redundancy Checks
o*crit_action_cmd_line.hppRoutines to convert command-line overwriting criterium to their crit_action counterparts
o*criterium.hppClasses that let the user define the policy for overwriting files
o*crypto.hppCrypto algoritm definition
o*crypto_asym.hppAsymetric cryptographical algoritms relying on gpgme
o*crypto_sym.hpp
o*cygwin_adapt.hppThin adaptation layer to Cygwin specifities
o*dar.hppMain module for dar command-line tool
o*dar_suite.hppRoutine to manage CLI's common initialization and ultimate exception catching
o*data_tree.hppTwo classes used to store tree information in dar_manager databases
o*database.hppThis file holds the database class definition
o*database_header.hppDefines the database structure in file
o*database_options.hppThis file holds the options for database operations
o*datetime.hppThis file contains the definition of class datetime that stores unix times in a portable way
o*deci.hppManages the decimal representation of infinint
o*defile.hppHere is defined the defile class
o*ea.hppSet of routines to manage EA values associated to a file
o*ea_filesystem.hppFilesystem dependent Extended Attributes operationsThis file contains a set of routines used to manipulate (read, write or test the presence of) Extended Attributes
o*elastic.hppHere is defined the elastic class
o*entrepot.hppDefines the entrepot interface. Entrepot interface defines a generic way to interact with files (slices) on a filesystem. It is used to instanciate file-like objects (from class inherited from class fichier_global, in order to read or write data to such file. The entrepot_local and fichier_local classes are the only one classes available from libdar to implement the entrepot and fichier classes interfaces respectively. External applications like webdar can implement entrepot_ftp and fichier_ftp classes to provide transparent access to dar backup localted on a remote ftp server. More can follow in the future
o*entrepot_local.hppDefines the implementation for local filesystem entrepot The entrepot_local is the only implementation of an entrepot class present in libdar. It correspond to local filesystems. The reason of existence of the entrepot stuff is to allow external application like webdar to drop/read slices over the network using FTP protocol for example. External applications only have to define Their own implementation of the entrepot interface and file-like objects they generates (inherited from class fichier_global), libdar uses them throught the generic interface. This avoids having network related stuff inside libdar, which for security reason and functions/roles separation would not be a good idea
o*erreurs.hppAll the excetion class thrown by libdar
o*erreurs_ext.hppSome additional exception class thrown by libdar
o*escape.hppClass escape definition, used for sequential reading of archivesThe class escape is used to insert escape sequences before each new file's data in an archive. The normal file's data is also rewritten if it contains such an escape sequence for it does not collide with real escape sequences At reading time, this class revert backs modification done to file's data containing escape sequences for they contain the original data. This class also provides the feature to skip to the next (real) escape sequence. This class inherits of generic files and its objects are to be used in a stack of generic file's objects. The object below contains modified data and escape sequences, the file over gets the normal file data and does never see escape sequences. Expected implementation is to have a compressor above an escape object and a sar or scrambler/blowfish/... object above it
o*escape_catalogue.hppClass escape_catalogue definition. Used for sequential writing to archives, as well as several other inherited classes from catalogue.hppThis class inherits from the class catalogue and implements the pre_add(...) method, which role is to add an escape sequence followed by an entry dump (usually used at the end of archive is the so called catalogue part of the archive). This sequence followed by entry dump is added before each file's data all along the archive. Other inherited classes, implement the escape specific part, used when performing sequential reading of the catalogue
o*etage.hppDefinition of the etage structure is done here
o*fichier_global.hppClass fichier_global definition. This class is a pure virtual class class fichier_global is an abstraction of files objects whatever is their localisation like local filesystem, remote ftp server, etc. inherited classes (like fichier_local) provide full implementation
o*fichier_local.hppClass fichier_global definition. This is a full implementation/inherited class of class fichier_global this type of object are generated by entrepot_local
o*filesystem.hppDefines several classes that realize the interface with the filesystem
o*filesystem_specific_attribute.hppFilesystem specific attributes
o*filtre.hppHere is all the core routines for the operations
o*fsa_family.hppFilesystem specific attributes available families and fsa_scope definition
o*generic_file.hppClass generic_file is defined here as well as class fichierthe generic_file interface is widely used in libdar it defines the standard way of transmitting data between different part of the library
o*generic_file_overlay_for_gpgme.hppAdaptation class from gpgme data buffer to libdar generic_file interface
o*generic_thread.hppClass generic_thread provides a way to interact with a generic_file ran in an other thread
o*generic_to_global_file.hppThis class provides an fichier_global interface for any type of generic_file object
o*getopt_decision.hSwitch routine to define which file to include based on the result of the configure script
o*gettext.h
o*hash_fichier.hppClass hash_fichier definition.This is an inherited class from class fichier Objects of that class are write-only objects that provide a hash of the written data other hash algorithm may be added in the future
o*header.hppSlice header structure is defined here
o*header_version.hppArchive global header/trailer structure is defined here
o*hide_file.hppClass of base to split files in words
o*infinint.hppSwitch module to limitint (32 ou 64 bits integers) or infinint
o*int_tools.hppElementary operation for infinint integers
o*integers.hppAre defined here basic integer types that tend to be portable
o*label.hppDefine the datastructure "label" used to identify slice membership to an archive
o*libdar.hppMain file of the libdar API definitions
o*limitint.hppReviewed implementation of infinint based on system limited integersthe limitint template class implementation defined in this module can handle positive integers and detect overflow. It shares with infinint the same interface, so it can be use in place of it, but throw Elimitint exceptions if overflow is detected
o*line_tools.hppSet of general command line targeted routines
o*list_entry.hppClass of objects describing an entry in the archive, used by archive::get_children_in_table
o*macro_tools.hppMacroscopic tools for libdar internals
o*mask.hppHere lies a collection of mask classes
o*mask_list.hppHere lies a mask that selects files present in a given listThe mask_list classes defined here is to be used for filtering files in the libdar API calls
o*mem_allocator.hppThis is the base class of object that can provide dynamically allocated memory blocks
o*mem_cluster.hppDefines mem_cluster class that holds a fixed set of fixed size allocatable memory blocks
o*mem_sized.hppDefines mem_sized class that holds a variable sized set of fixed sized blocks using class mem_cluster
o*mem_ui.hppClass mem_ui definition. This class is to be used as parent class to handle user_interaction object management
o*memory_check.hpp
o*memory_file.hppMemory_file is a generic_file class that only uses virtual memory
o*memory_pool.hppClass memory_pool allocates and recycles blocks of memory for better performances it is expected to be used with classes that inherit from class on_pool
o*messaging.hppMessaging_decode and messaging_encode are used to insert messages in a flow if data blocks
o*my_config.h
o*my_getopt_long.hMay lead to the definition of getopt_long to solve declaration conflicts in <unistd.h> and <getopt.h>
o*nls_swap.hppSet of macro to change the NLS from user application domaine to libdar domain and viceversa
o*no_comment.hppClass that transparently strips out the comments from configuration file
o*null_file.hpp/dev/null type file implementation under the generic_file interfacethis class is used in particular when doing dry-run execution
o*on_pool.hppThis is the base class of object that can be allocated on a memory pool
o*path.hppHere is the definition of the path classthe path class handle path and provide several operation on them
o*pile.hppClass pile definition. Used to manage a stack of generic_file objects
o*pile_descriptor.hppOptimization structure to quickly access some commonly used layers of a stack of generic_file
o*range.hppClass than provide a way to manipulate and represent range of integer numbers (infinint)
o*real_infinint.hppOriginal infinint class implementationthe infinint class implementation defined in this module can handle arbitrary large positive integer numbers
o*sar.hppSar and trivial_sar classes, they manage the slicing layer
o*sar_tools.hppSet of tools aims to help Segmentation And Reassemblement (sar) class
o*scrambler.hppDefinition of the scrambler class, a very weak encryption scheme
o*secu_memory_file.hppSecu_memory_file is a generic_file class that only uses secured memory (not swappable and zeroed after use)
o*secu_string.hppThis file contains the definition of secu_string class, a std::string like class but allocated in secure memorysecure memory is a allocated memory that is never swapped out (wrote to disk) the implementation relies on gcrypt_malloc_secure() call (libgcrypt) rather than relying on mlock()/munlock() posix system call. as the need for secure string is for strong encryption, there is no much interest in re-inventing the wheel as the need is dependent on gcrypt availability
o*semaphore.hppDefinition of class semaphore, used to manage invocation of backup hook for files
o*shell_interaction.hppUser_interaction class for command_line tools
o*slave_thread.hppClass slave_thread is runs a I/O operations on a given genercif_file in a separated thread
o*slice_layout.hppObject describing the slicing of an archive
o*sparse_file.hppClass sparse_file definition, used to handle holes in filesthis class is used to receive plain file's data to be written to the archive or to be read out from an archive. The class uses escape sequences to replace holes in files (long serie of zeros) by the number of zeros preceeded by a escape sequence mark. this class internally uses an escape object, with a modifed fixed escape sequence that optimizes the use of sparse_file objects with other escape objects
o*statistics.hppHandle the statistic structure that gives a summary of treated files after each operatio
o*storage.hppClass that permits arbitrary large data storage
o*terminateur.hppTerminateur class which defines the position of the cataloguethe terminateur is a byte sequence present as the last bytes of an archive which indicates how much byte backward libdar must skip back to find the beginning of the catalogue
o*thread_cancellation.hppTo be able to cancel libdar operation while running in a given thread.the class thread_cancellation implemented in this module permits to define checkpoints where is looked whether the current thread has been marked as to be canceled by the user The advantage of this class is that it then throws a Euser_abort exception which properly terminates the libdar operation in the thread freeing allocated memory and release mutex properly. Note that the thread is not canceled but libdar call in this thread returns as soon as a checkpoint is met during the execution
o*tlv.hppGeneric Type Length Value data structures
o*tlv_list.hppList of Generic Type Length Value data structures
o*tools.hppSet of general purpose routines
o*trivial_sar.hppTrivial_sar classes manages the slicing layer when single slice is used
o*tronc.hppDefines a limited segment over another generic_file.This is used to read a part of a file as if it was a real file generating end of file behavior when reaching the given length
o*tronconneuse.hppDefines a block structured file.Mainly used for strong encryption
o*trontextual.hppClass trontextual is a contextual variant of class tronc
o*tuyau.hppDefines the implementation of pipe under the generic_file interface.mainly used between zapette and slave_zapette, this is a full implementation of the generic_file interface that takes care of dead lock when two pipes needs to be openned between the same two entities, each having one for reading and the other for writing
o*user_group_bases.hppDefines class that speed up the uid to username and gid to group name lookup
o*user_interaction.hppDefines the interaction between libdar and the user.Three classes are defined
o*wrapperlib.hppLibz and libbz2 wrapper to have identical interface to these libraries.libz and libbz2 library differ in the way they return values in certain circumpstances. This module defines the wrapperlib class that make their use homogeneous
\*zapette.hppRemote control between dar and dar_slave.Two classes are defined in this module