Disk ARchive  2.5.2
Full featured and portable backup and archiving tool
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Defines
Public Member Functions | Protected Member Functions
libdar::filesystem_hard_link_write Class Reference

keep trace of already written inodes to restore hard links More...

#include <filesystem.hpp>

Inherits libdar::mem_ui, and libdar::on_pool.

Inherited by libdar::filesystem_restore.

List of all members.

Public Member Functions

 filesystem_hard_link_write (const user_interaction &dialog)
 filesystem_hard_link_write (const filesystem_hard_link_write &ref)
const filesystem_hard_link_writeoperator= (const filesystem_hard_link_write &ref)
void write_hard_linked_target_if_not_set (const cat_mirage *ref, const std::string &chemin)
bool known_etiquette (const infinint &eti)
void clear_corres_if_pointing_to (const infinint &ligne, const std::string &path)

Protected Member Functions

void corres_reset ()
void make_file (const cat_nomme *ref, const path &ou, bool dir_perm, cat_inode::comparison_fields what_to_check, const fsa_scope &scope)
bool raw_set_ea (const cat_nomme *e, const ea_attributs &list_ea, const std::string &spot, const mask &ea_mask)
 add the given EA matching the given mask to the file pointed to by "e" and spot
bool raw_clear_ea_set (const cat_nomme *e, const std::string &path)
 remove EA set from filesystem's file, allows subsequent raw_set_ea

Detailed Description

keep trace of already written inodes to restore hard links

Definition at line 224 of file filesystem.hpp.


Member Function Documentation

void libdar::filesystem_hard_link_write::clear_corres_if_pointing_to ( const infinint ligne,
const std::string &  path 
)

forget everything about a hard link if the path used to build subsequent hard links is the one given in argument

Parameters:
[in]ligneis the etiquette number for that hard link
[in]pathif the internaly recorded path to build subsequent hard link to that inode is equal to path, forget everything about this hard linked inode
bool libdar::filesystem_hard_link_write::raw_clear_ea_set ( const cat_nomme e,
const std::string &  path 
) [protected]

remove EA set from filesystem's file, allows subsequent raw_set_ea

Parameters:
[in]ethis object may be a hard link to or an inode
[in]paththe path in the filesystem where reside the object whose EA to clear
Returns:
true if EA could be cleared, false if "e" is a hard link to an inode that has its EA already restored previously
bool libdar::filesystem_hard_link_write::raw_set_ea ( const cat_nomme e,
const ea_attributs list_ea,
const std::string &  spot,
const mask ea_mask 
) [protected]

add the given EA matching the given mask to the file pointed to by "e" and spot

Parameters:
[in]emay be an inode or a hard link to an inode,
[in]list_eathe list of EA to restore
[in]spotthe path where to restore these EA (full path required, including the filename of 'e')
[in]ea_maskthe EA entry to restore from the list_ea (other entries are ignored)
Returns:
true if EA could be restored, false if "e" is a hard link to an inode that has its EA already restored previously
Note:
the list_ea EA are restored to spot path, the object e is only here to validate that this operation has not already been done through another hard linked inode to that same inode

The documentation for this class was generated from the following file:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Defines