Disk ARchive 2.7.16
Full featured and portable backup and archiving tool
tools.hpp
Go to the documentation of this file.
1/*********************************************************************/
2// dar - disk archive - a backup/restoration program
3// Copyright (C) 2002-2024 Denis Corbin
4//
5// This program is free software; you can redistribute it and/or
6// modify it under the terms of the GNU General Public License
7// as published by the Free Software Foundation; either version 2
8// of the License, or (at your option) any later version.
9//
10// This program is distributed in the hope that it will be useful,
11// but WITHOUT ANY WARRANTY; without even the implied warranty of
12// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13// GNU General Public License for more details.
14//
15// You should have received a copy of the GNU General Public License
16// along with this program; if not, write to the Free Software
17// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18//
19// to contact the author, see the AUTHOR file
20/*********************************************************************/
21
25
26
27#ifndef TOOLS_HPP
28#define TOOLS_HPP
29
30#include "../my_config.h"
31
32extern "C"
33{
34#if STDC_HEADERS
35#include <stdarg.h>
36#endif
37#if HAVE_SIGNAL_H
38#include <signal.h>
39#endif
40#if HAVE_GPGME_H
41#include <gpgme.h>
42#endif
43}
44
45#include <string>
46#include <vector>
47#include <deque>
48#include <map>
49#include <set>
50#include "path.hpp"
51#include "infinint.hpp"
52#include "generic_file.hpp"
53#include "integers.hpp"
54#include "tlv_list.hpp"
55#include "datetime.hpp"
56#include "entrepot.hpp"
57
58namespace libdar
59{
60
63
64
66 extern void tools_init();
68 extern void tools_end();
69
71
74 extern void tools_write_string(generic_file & f, const std::string & s);
75
77
80 extern void tools_read_string(generic_file & f, std::string & s);
81
83
86 extern void tools_write_string_all(generic_file & f, const std::string & s);
87
89
93 extern void tools_read_string_size(generic_file & f, std::string & s, infinint taille);
94
96
100
106 extern std::string tools_display_integer_in_metric_system(infinint number, const std::string & unit, bool binary);
107
109
115 extern std::string::iterator tools_find_last_char_of(std::string &s, unsigned char v);
116
118
121 extern void tools_blocking_read(int fd, bool mode);
122
124
127 extern std::string tools_name_of_uid(const infinint & uid);
128
130
133 extern std::string tools_name_of_gid(const infinint & gid);
134
136
139 extern std::string tools_uword2str(U_16 x);
140
142
145 extern std::string tools_int2str(S_I x);
146 extern std::string tools_uint2str(U_I x);
147
149
153 extern std::string tools_addspacebefore(std::string s, U_I expected_size);
154
156
159 extern std::string tools_display_date(const datetime & date);
160
162
167 extern char *tools_str2charptr(const std::string &x);
168
170
173 extern U_I tools_str2int(const std::string & x);
174
176
179 extern void tools_system(user_interaction & dialog, const std::vector<std::string> & argvector);
180
182
188 extern void tools_system_with_pipe(const std::shared_ptr<user_interaction> & dialog,
189 const std::string & dar_cmd,
190 const std::vector<std::string> & argvpipe);
191
193
196 extern void tools_write_vector(generic_file & f, const std::vector<std::string> & x);
197
199
202 extern void tools_read_vector(generic_file & f, std::vector<std::string> & x);
203
205
209 extern std::string tools_concat_vector(const std::string & separator,
210 const std::vector<std::string> & x);
211
213
217 std::vector<std::string> operator + (std::vector<std::string> a, std::vector<std::string> b);
218
219
221
226 extern bool tools_is_equal_with_hourshift(const infinint & hourshift, const datetime & date1, const datetime & date2);
227
229
230 template <class T> std::vector<T> operator +=(std::vector<T> & a, const std::vector<T> & b)
231 {
232 a = a + b;
233 return a;
234 }
235
236
237
239
243 extern std::string tools_readlink(const char *root);
244
246
252 extern void tools_noexcept_make_date(const std::string & chem, bool symlink, const datetime & last_acc, const datetime & last_mod, const datetime & birth);
253
255
262 extern void tools_make_date(const std::string & chemin, bool symlink, const datetime & access, const datetime & modif, const datetime & birth);
263
265
269 extern bool tools_is_case_insensitive_equal(const std::string & a, const std::string & b);
270
277 extern void tools_to_upper(const std::string & r, std::string & uppered);
278
279#if HAVE_WCTYPE_H
286 extern void tools_to_wupper(std::wstring & r);
287#endif
288
290
300 extern std::string tools_printf(const char *format, ...);
301
303
312 extern std::string tools_vprintf(const char *format, va_list ap);
313
315
320 const std::string & file_mask);
321
322
324
331 const entrepot & ent,
332 const std::string & file_mask,
333 bool info_details);
334
335
337
348 const entrepot & ent,
349 const std::string & basename,
350 const std::string & extension,
351 bool info_details,
352 bool allow_overwriting,
353 bool warn_overwriting,
354 bool dry_run);
355
357
363 extern bool tools_are_on_same_filesystem(const std::string & file1, const std::string & file2);
364
366
370 extern path tools_relative2absolute_path(const path & src, const path & cwd);
371
373
376 extern void tools_block_all_signals(sigset_t &old_mask);
377
379
382 extern void tools_set_back_blocked_signals(sigset_t old_mask);
383
385
389 extern U_I tools_count_in_string(const std::string & s, const char a);
390
392
402 const std::string & s,
403 bool auto_zeroing,
404 bool silent,
405 const std::set<std::string> & ignored_as_symlink = std::set<std::string>());
406
408
411 extern infinint tools_get_size(const std::string & s);
412
414
418 extern infinint tools_get_extended_size(std::string s, U_I base);
419
421
425 extern std::string tools_substitute(const std::string & hook,
426 const std::map<char, std::string> & corres);
427
428
430
441 extern std::string tools_hook_substitute(const std::string & hook,
442 const std::string & path,
443 const std::string & basename,
444 const std::string & num,
445 const std::string & padded_num,
446 const std::string & ext,
447 const std::string & context,
448 const std::string & base_url);
449
450
452
456 const std::string & cmd_line);
457
458
460
471 const std::string & hook,
472 const std::string & path,
473 const std::string & basename,
474 const std::string & num,
475 const std::string & padded_num,
476 const std::string & ext,
477 const std::string & context,
478 const std::string & base_url);
479
480
482
485 extern std::string tools_output2xml(const std::string & src);
486
488
491 extern U_I tools_octal2int(const std::string & perm);
492
493
495
498 extern std::string tools_int2octal(const U_I & perm);
499
501
502 extern char tools_cast_type_to_unix_type(char type);
503
505
506 extern std::string tools_get_permission_string(char type, U_32 perm, bool hard);
507
509
512 extern void tools_set_permission(S_I fd, U_I perm);
513
515
519 extern U_I tools_get_permission(S_I fd);
520
522
524
527 extern uid_t tools_ownership2uid(const std::string & user);
528
530
533 extern uid_t tools_ownership2gid(const std::string & group);
534
536
541 extern void tools_set_ownership(S_I filedesc, const std::string & slice_user, const std::string & slice_group);
542
544
549 extern void tools_memxor(void *dest, const void *src, U_I n);
550
552
557 extern tlv_list tools_string2tlv_list(user_interaction & dialog, const U_16 & type, const std::vector<std::string> & data);
558
559
560
562
565 extern U_I tools_pseudo_random(U_I max);
566
567
569
576
577 template <class N, class B> std::deque<B> tools_number_base_decomposition_in_big_endian(N number, const B & base)
578 {
579 std::deque<B> ret;
580
581 if(base <= 0)
582 throw Erange("tools_number_decoupe_in_big_endian", "base must be strictly positive");
583
584 while(number != 0)
585 {
586 ret.push_back(number % base);
587 number /= base;
588 }
589
590 return ret;
591 }
592
594
597 extern std::string tools_unsigned_char_to_hexa(unsigned char x);
598
600
603
604 extern std::string tools_string_to_hexa(const std::string & input);
605
607
611
613 extern std::string tools_getcwd();
614
616 extern std::string tools_get_compression_ratio(const infinint & storage_size, const infinint & file_size, bool compressed);
617
619 extern std::string tools_strerror_r(int errnum);
620
621#ifdef GPGME_SUPPORT
623 extern std::string tools_gpgme_strerror_r(gpgme_error_t err);
624#endif
625
626#if HAVE_WCHAR_H
628 extern std::wstring tools_string_to_wstring(const std::string & val);
629
631 extern std::string tools_wstring_to_string(const std::wstring & val);
632#endif
633
635 extern void tools_secu_string_show(user_interaction & dialog, const std::string & msg, const secu_string & key);
636
637 template <class T> T tools_max(T a, T b) { return a > b ? a : b; }
638 template <class T> T tools_min(T a, T b) { return a > b ? b : a; }
639
641 void tools_unlink(const std::string & filename);
642
644 extern std::string tools_escape_chars_in_string(const std::string & val, const char *to_escape);
645
647
649 extern bool tools_infinint2U_64(infinint val, U_64 & res);
650
652
658 extern bool tools_my_atoi(const char *a, U_I & val);
659
661 extern infinint tools_double2infinint(double arg);
662
664
671 template <class T> void tools_check_negative_date(T & val,
672 user_interaction & ui,
673 const char *inode_path,
674 const char *nature,
675 bool ask_before,
676 bool silent)
677 {
678 if(val < 0)
679 {
680 if(!silent)
681 {
682 std::string msg = tools_printf(gettext("Found negative date (%s) for inode %s ."),
683 nature,
684 inode_path);
685 if(ask_before)
686 ui.pause(tools_printf(gettext("%S Can we read it as if it was zero (1st January 1970 at 00:00:00 UTC)?"),
687 &msg));
688 else // just warn
689 ui.message(msg + gettext("Considering date as if it was zero (Jan 1970)"));
690 }
691
692 val = 0;
693 }
694 }
695
696
698
700
701
703
705
706
708
710
711
713
715
717
718}
719
720#endif
exception used to signal range error
Definition: erreurs.hpp:220
stores time information
Definition: datetime.hpp:59
the Entrepot interface
Definition: entrepot.hpp:56
this is the interface class from which all other data transfer classes inherit
the arbitrary large positive integer class
the class path is here to manipulate paths in the Unix notation: using'/'
Definition: path.hpp:51
class secu_string
Definition: secu_string.hpp:54
This is a pure virtual class that is used by libdar when interaction with the user is required.
this file contains the definition of class datetime that stores unix times in a portable way
defines the entrepot interface.
class generic_file is defined here as well as class fichier
bool tools_is_equal_with_hourshift(const infinint &hourshift, const datetime &date1, const datetime &date2)
test if two dates are equal taking care of a integer hour of difference
void tools_check_negative_date(T &val, user_interaction &ui, const char *inode_path, const char *nature, bool ask_before, bool silent)
check the value is not negative, and if asked set it to zero
Definition: tools.hpp:671
void tools_secu_string_show(user_interaction &dialog, const std::string &msg, const secu_string &key)
display the content of a secu_string, this function is only for trouble shooting!
void tools_set_back_blocked_signals(sigset_t old_mask)
unblock signals according to given mask
void tools_system(user_interaction &dialog, const std::vector< std::string > &argvector)
wrapper to the "system" system call.
std::string tools_escape_chars_in_string(const std::string &val, const char *to_escape)
escape with a anti-slash character a set of chars found in the given string
std::string tools_get_compression_ratio(const infinint &storage_size, const infinint &file_size, bool compressed)
return the string about compression ratio
void tools_unlink(const std::string &filename)
remove from filesystem the file which path is given
std::string tools_uword2str(U_16 x)
convert unsigned word to string
void tools_read_string(generic_file &f, std::string &s)
read a string from a file expecting it to terminate by '\0'
bool tools_infinint2U_64(infinint val, U_64 &res)
convert an infinint to U_64 (aka "uint64_t" or yet "unsigned long long")
bool tools_are_on_same_filesystem(const std::string &file1, const std::string &file2)
tells whether two files are on the same mounted filesystem
std::string tools_addspacebefore(std::string s, U_I expected_size)
prepend spaces before the given string
std::deque< B > tools_number_base_decomposition_in_big_endian(N number, const B &base)
Template for the decomposition of any number in any base (decimal, octal, hexa, etc....
Definition: tools.hpp:577
void tools_to_upper(const std::string &r, std::string &uppered)
convert a string to upper case
void tools_write_string_all(generic_file &f, const std::string &s)
write a string to a file, '\0' has no special meaning nor is added at the end
void tools_avoid_slice_overwriting_regex(user_interaction &dialog, const entrepot &ent, const std::string &basename, const std::string &extension, bool info_details, bool allow_overwriting, bool warn_overwriting, bool dry_run)
prevents slice overwriting: check the presence of slice and if necessary ask the user if they can be ...
std::string tools_display_integer_in_metric_system(infinint number, const std::string &unit, bool binary)
void tools_read_string_size(generic_file &f, std::string &s, infinint taille)
read a string if given size from a file '\0' has no special meaning
infinint tools_get_extended_size(std::string s, U_I base)
convert the given string to infinint taking care of multiplication suffixes like k,...
void tools_set_permission(S_I fd, U_I perm)
change the permission of the file which descriptor is given
infinint tools_double2infinint(double arg)
convert a double (float) to infinint (integer) taking care of rounding it to the closest value
std::string tools_int2octal(const U_I &perm)
convert a number to a string corresponding to its octal representation
void tools_block_all_signals(sigset_t &old_mask)
block all signals (based on POSIX sigprocmask)
bool tools_is_case_insensitive_equal(const std::string &a, const std::string &b)
compare two string in case insensitive manner
U_I tools_count_in_string(const std::string &s, const char a)
counts the number of a given char in a given string
uid_t tools_ownership2gid(const std::string &group)
convert string group name or gid to numeric gid value
void tools_write_vector(generic_file &f, const std::vector< std::string > &x)
write a list of string to file
infinint tools_get_size(const std::string &s)
returns the size of the given plain file
void tools_end()
libdar internal use only: it is launched from close_and_clean() and releases tools internal variables
std::string tools_string_to_hexa(const std::string &input)
convert a string into its hexadecima representation
std::string tools_strerror_r(int errnum)
wrapper routine to strerror_r
infinint tools_file_size_to_crc_size(const infinint &size)
Defines the CRC size to use for a given filesize.
uid_t tools_ownership2uid(const std::string &user)
change ownership of the file which descriptor is given
void tools_hook_execute(user_interaction &ui, const std::string &cmd_line)
execute and retries at user will a given command line
void tools_memxor(void *dest, const void *src, U_I n)
Produces in "dest" the XORed value of "dest" and "src".
void tools_noexcept_make_date(const std::string &chem, bool symlink, const datetime &last_acc, const datetime &last_mod, const datetime &birth)
set dates of a given file, no exception thrown
path tools_relative2absolute_path(const path &src, const path &cwd)
transform a relative path to an absolute one given the current directory value
std::string tools_display_date(const datetime &date)
convert a date in second to its human readable representation
std::string tools_readlink(const char *root)
returns the file pointed to by a symbolic link (or transparent if the file is not a symlink).
infinint tools_upper_rounded_log2(const infinint &ref)
compute an approximate log2 of the argument
char * tools_str2charptr(const std::string &x)
convert a string to a char *
U_I tools_get_permission(S_I fd)
obtain the permission of the file which descriptor is given
std::string tools_getcwd()
get current working directory
U_I tools_octal2int(const std::string &perm)
convert octal string to integer
datetime tools_get_mtime(user_interaction &dialog, const std::string &s, bool auto_zeroing, bool silent, const std::set< std::string > &ignored_as_symlink=std::set< std::string >())
returns the last modification date of the given file
void tools_blocking_read(int fd, bool mode)
set blocking/not blocking mode for reading on a file descriptor
std::string tools_output2xml(const std::string &src)
convert string for xml output
U_I tools_pseudo_random(U_I max)
Produces a pseudo random number x, where 0 <= x < max.
char tools_cast_type_to_unix_type(char type)
change the libdar internal type representation to the usual unix char type
void tools_hook_substitute_and_execute(user_interaction &ui, const std::string &hook, const std::string &path, const std::string &basename, const std::string &num, const std::string &padded_num, const std::string &ext, const std::string &context, const std::string &base_url)
subsititue and execute command line
infinint tools_rounded_square_root(const infinint &ref)
compute an approximate square root of the argument
void tools_system_with_pipe(const std::shared_ptr< user_interaction > &dialog, const std::string &dar_cmd, const std::vector< std::string > &argvpipe)
wrapper to the "system" system call using anonymous pipe to tranmit arguments to the child process
std::string tools_hook_substitute(const std::string &hook, const std::string &path, const std::string &basename, const std::string &num, const std::string &padded_num, const std::string &ext, const std::string &context, const std::string &base_url)
produces the string resulting from the substitution of %... macro
std::string::iterator tools_find_last_char_of(std::string &s, unsigned char v)
give a pointer to the last character of the given value in the given string
infinint tools_rounded_cube_root(const infinint &ref)
compute an approximate cube root of the argument
std::string tools_name_of_gid(const infinint &gid)
convert gid to name in regards of the current system's configuration
void tools_unlink_file_mask_regex(user_interaction &dialog, const entrepot &ent, const std::string &file_mask, bool info_details)
remove files from a given directory
void tools_write_string(generic_file &f, const std::string &s)
write a string to a file with a '\0' at then end
std::string tools_concat_vector(const std::string &separator, const std::vector< std::string > &x)
concatenate a vectors of strings in a single string
infinint tools_lower_rounded_exp2(const infinint &ref)
compute an approximate exp2 of the argument
void tools_set_ownership(S_I filedesc, const std::string &slice_user, const std::string &slice_group)
change ownership of the file which descriptor is given
std::string tools_printf(const char *format,...)
make printf-like formating to a std::string
bool tools_my_atoi(const char *a, U_I &val)
ascii to integer conversion
std::string tools_int2str(S_I x)
convert integer to string
std::string tools_get_permission_string(char type, U_32 perm, bool hard)
convert a permission number into its string representation (rwxrwxrwx)
std::string tools_substitute(const std::string &hook, const std::map< char, std::string > &corres)
produce the string resulting from the substition of % macro defined in the map
U_I tools_str2int(const std::string &x)
convert an integer written in decimal notation to the corresponding value
std::vector< T > operator+=(std::vector< T > &a, const std::vector< T > &b)
template function to add two vectors
Definition: tools.hpp:230
bool tools_do_some_files_match_mask_regex(const entrepot &ent, const std::string &file_mask)
test the presence of files corresponding to a given mask in a directory (regex mask)
void tools_init()
libdar internal use only: it is launched from get_version() and initializes tools internal variables
std::string tools_unsigned_char_to_hexa(unsigned char x)
convert a unsigned char into its hexa decima representation
infinint tools_get_filesize(const path &p)
retrieve the size in byte of a file
tlv_list tools_string2tlv_list(user_interaction &dialog, const U_16 &type, const std::vector< std::string > &data)
Produces a list of TLV from a constant type and a list of string.
std::string tools_vprintf(const char *format, va_list ap)
make printf-like formating to a std::string
std::string tools_name_of_uid(const infinint &uid)
convert uid to name in regards to the current system's configuration
void tools_make_date(const std::string &chemin, bool symlink, const datetime &access, const datetime &modif, const datetime &birth)
set dates of a given file, may throw exception
void tools_read_vector(generic_file &f, std::vector< std::string > &x)
read a list of string from a file
switch module to limitint (32 ou 64 bits integers) or infinint
are defined here basic integer types that tend to be portable
libdar namespace encapsulate all libdar symbols
Definition: archive.hpp:47
here is the definition of the path class
List of Generic Type Length Value data structures.