Showing a better link count with -hardlinks on -lsl
This commit is contained in:
parent
1fe5898dc1
commit
d69acf1374
@ -16539,6 +16539,12 @@ no_memory:;
|
|||||||
patterns[i]= argv[i + *idx];
|
patterns[i]= argv[i + *idx];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if((flag & 1) && !(xorriso->ino_behavior & 1)) {
|
||||||
|
ret= Xorriso_make_hln_array(xorriso, 0); /* for stbuf.st_nlink */
|
||||||
|
if(ret < 0)
|
||||||
|
return(ret);
|
||||||
|
}
|
||||||
if(flag&2) {
|
if(flag&2) {
|
||||||
ret= Xorriso_ls_filev(xorriso, xorriso->wdi, nump, argv + (*idx), mem,
|
ret= Xorriso_ls_filev(xorriso, xorriso->wdi, nump, argv + (*idx), mem,
|
||||||
flag&(1|4|8));
|
flag&(1|4|8));
|
||||||
|
@ -1 +1 @@
|
|||||||
#define Xorriso_timestamP "2009.07.23.103339"
|
#define Xorriso_timestamP "2009.07.23.103728"
|
||||||
|
@ -99,6 +99,9 @@ int Xorriso_path_from_lba(struct XorrisO *xorriso, IsoNode *node, int lba,
|
|||||||
|
|
||||||
int Xorriso__node_lba_cmp(const void *node1, const void *node2);
|
int Xorriso__node_lba_cmp(const void *node1, const void *node2);
|
||||||
|
|
||||||
|
int Xorriso_search_hardlinks(struct XorrisO *xorriso, IsoNode *node,
|
||||||
|
int *node_idx, int *min_hl, int *max_hl, int flag);
|
||||||
|
|
||||||
|
|
||||||
#define LIBISO_ISDIR(node) (iso_node_get_type(node) == LIBISO_DIR)
|
#define LIBISO_ISDIR(node) (iso_node_get_type(node) == LIBISO_DIR)
|
||||||
#define LIBISO_ISREG(node) (iso_node_get_type(node) == LIBISO_FILE)
|
#define LIBISO_ISREG(node) (iso_node_get_type(node) == LIBISO_FILE)
|
||||||
@ -384,20 +387,6 @@ int Xorriso__get_di(IsoNode *node, dev_t *dev, ino_t *ino, int flag)
|
|||||||
i_end= i + vpt[i] + 1;
|
i_end= i + vpt[i] + 1;
|
||||||
for(i++; i < i_end && i < value_length; i++)
|
for(i++; i < i_end && i < value_length; i++)
|
||||||
*ino= ((*ino) << 8) | vpt[i];
|
*ino= ((*ino) << 8) | vpt[i];
|
||||||
|
|
||||||
#ifdef NIX
|
|
||||||
/* <<< */
|
|
||||||
if(*ino > 10000000 || *ino < 0) {
|
|
||||||
fprintf(stderr,
|
|
||||||
"xorriso_DEBUG: name= '%s' , vl= %lu , i_end= %d\n",
|
|
||||||
iso_node_get_name(node), (unsigned long) value_length, i_end);
|
|
||||||
fprintf(stderr, " ");
|
|
||||||
for(i= 0; i < value_length; i++)
|
|
||||||
fprintf(stderr, " %-3.3u", (unsigned int) vpt[i]);
|
|
||||||
fprintf(stderr, "\n");
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
free(value);
|
free(value);
|
||||||
return(1);
|
return(1);
|
||||||
}
|
}
|
||||||
@ -2163,7 +2152,7 @@ int Xorriso_pacifier_loop(struct XorrisO *xorriso, struct burn_drive *drive,
|
|||||||
current_time-start_time);
|
current_time-start_time);
|
||||||
else
|
else
|
||||||
sprintf(xorriso->info_text,
|
sprintf(xorriso->info_text,
|
||||||
"Thank you for being patient for %.f seconds",
|
"Thank you for being patient. Working since %.f seconds.",
|
||||||
current_time-start_time);
|
current_time-start_time);
|
||||||
Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "UPDATE", 0);
|
Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "UPDATE", 0);
|
||||||
|
|
||||||
@ -2420,11 +2409,14 @@ int Xorriso_node_get_dev(struct XorrisO *xorriso, IsoNode *node,
|
|||||||
bit1= add extra block for size estimation
|
bit1= add extra block for size estimation
|
||||||
bit2= complain loudely if path is missing in image
|
bit2= complain loudely if path is missing in image
|
||||||
bit3= stbuf is to be used without eventual ACL
|
bit3= stbuf is to be used without eventual ACL
|
||||||
|
bit4= try to obtain a better st_nlink count if hardlinks
|
||||||
|
are enabled
|
||||||
*/
|
*/
|
||||||
int Xorriso_fake_stbuf(struct XorrisO *xorriso, char *path, struct stat *stbuf,
|
int Xorriso_fake_stbuf(struct XorrisO *xorriso, char *path, struct stat *stbuf,
|
||||||
IsoNode **node, int flag)
|
IsoNode **node, int flag)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, min_hl, max_hl, node_idx, i;
|
||||||
|
char img_path[SfileadrL];
|
||||||
IsoImage *volume;
|
IsoImage *volume;
|
||||||
|
|
||||||
memset((char *) stbuf, 0, sizeof(struct stat));
|
memset((char *) stbuf, 0, sizeof(struct stat));
|
||||||
@ -2467,6 +2459,7 @@ int Xorriso_fake_stbuf(struct XorrisO *xorriso, char *path, struct stat *stbuf,
|
|||||||
|
|
||||||
/* >>> With directories this should be : number of subdirs + 2 */
|
/* >>> With directories this should be : number of subdirs + 2 */
|
||||||
/* >>> ??? How to obtain RR hardlink number for other types ? */
|
/* >>> ??? How to obtain RR hardlink number for other types ? */
|
||||||
|
/* This may get overriden farther down */
|
||||||
stbuf->st_nlink= 1;
|
stbuf->st_nlink= 1;
|
||||||
|
|
||||||
stbuf->st_uid= iso_node_get_uid(*node);
|
stbuf->st_uid= iso_node_get_uid(*node);
|
||||||
@ -2485,6 +2478,27 @@ int Xorriso_fake_stbuf(struct XorrisO *xorriso, char *path, struct stat *stbuf,
|
|||||||
stbuf->st_atime= iso_node_get_atime(*node);
|
stbuf->st_atime= iso_node_get_atime(*node);
|
||||||
stbuf->st_mtime= iso_node_get_mtime(*node);
|
stbuf->st_mtime= iso_node_get_mtime(*node);
|
||||||
stbuf->st_ctime= iso_node_get_ctime(*node);
|
stbuf->st_ctime= iso_node_get_ctime(*node);
|
||||||
|
|
||||||
|
if(LIBISO_ISDIR(*node) || (xorriso->ino_behavior & 1) || (!(flag & 16)) ||
|
||||||
|
xorriso->hln_array == NULL)
|
||||||
|
return(1);
|
||||||
|
|
||||||
|
/* Try to obtain a better link count */
|
||||||
|
ret= Xorriso_search_hardlinks(xorriso, *node, &node_idx, &min_hl, &max_hl, 0);
|
||||||
|
if(ret < 0)
|
||||||
|
return(ret);
|
||||||
|
if(ret > 0 && node_idx >= 0) {
|
||||||
|
for(i= min_hl; i <= max_hl; i++) {
|
||||||
|
if(i == node_idx)
|
||||||
|
continue;
|
||||||
|
/* Check whether node is still valid */
|
||||||
|
ret= Xorriso_path_from_node(xorriso, xorriso->hln_array[i], img_path, 0);
|
||||||
|
if(ret < 0)
|
||||||
|
return(ret);
|
||||||
|
if(ret > 0)
|
||||||
|
stbuf->st_nlink++;
|
||||||
|
}
|
||||||
|
}
|
||||||
return(1);
|
return(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2709,7 +2723,6 @@ int Xorriso_add_tree(struct XorrisO *xorriso, IsoDir *dir,
|
|||||||
{
|
{
|
||||||
IsoImage *volume;
|
IsoImage *volume;
|
||||||
IsoNode *node;
|
IsoNode *node;
|
||||||
IsoSymlink *iso_symlink;
|
|
||||||
int ret, target_is_dir, source_is_dir, source_is_link, fret, was_failure= 0;
|
int ret, target_is_dir, source_is_dir, source_is_link, fret, was_failure= 0;
|
||||||
int do_not_dive, target_is_split= 0;
|
int do_not_dive, target_is_split= 0;
|
||||||
struct DirseQ *dirseq= NULL;
|
struct DirseQ *dirseq= NULL;
|
||||||
@ -2886,34 +2899,9 @@ cannot_lstat:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(node==NULL) {
|
if(node==NULL) {
|
||||||
|
ret= Xorriso_tree_graft_node(xorriso, volume, dir, srcpt, img_name,
|
||||||
/* A90516 : <<< iso_tree_add_new_symlink does not record the disk inode
|
"", img_path, (off_t) 0, (off_t) 0,
|
||||||
number.
|
&node, 0);
|
||||||
So now iso_tree_add_new_node() must take care of symlinks.
|
|
||||||
*/
|
|
||||||
if(0 && S_ISLNK(stbuf.st_mode)) {
|
|
||||||
|
|
||||||
/* ??? NG : A80107 : is this solved now ? */
|
|
||||||
/* <<< One should rather change libisofs so that iso_tree_add_node()
|
|
||||||
adds a disk_link as RR link, if RR is enabled */
|
|
||||||
|
|
||||||
ret= iso_tree_add_new_symlink(dir, img_name, link_target, &iso_symlink);
|
|
||||||
node= (IsoNode *) iso_symlink;
|
|
||||||
if(ret>0) {
|
|
||||||
ret= Xorriso_transfer_properties(xorriso, &stbuf, srcpt, node, 2 | 4);
|
|
||||||
if(ret<=0)
|
|
||||||
goto was_problem;
|
|
||||||
} else {
|
|
||||||
Xorriso_report_iso_error(xorriso, stbuf_src, ret,
|
|
||||||
"Cannot create symbolic link", 0, "FAILURE", 1|2);
|
|
||||||
{ret= 0; goto was_problem;}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
|
|
||||||
ret= Xorriso_tree_graft_node(xorriso, volume, dir, srcpt, img_name,
|
|
||||||
"", img_path, (off_t) 0, (off_t) 0,
|
|
||||||
&node, 0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if(node==NULL) {
|
if(node==NULL) {
|
||||||
Xorriso_process_msg_queues(xorriso,0);
|
Xorriso_process_msg_queues(xorriso,0);
|
||||||
@ -6588,7 +6576,7 @@ int Xorriso_ls_filev(struct XorrisO *xorriso, char *wd,
|
|||||||
ret= Xorriso_make_abs_adr(xorriso, wd, filev[i], path, 1|2|4);
|
ret= Xorriso_make_abs_adr(xorriso, wd, filev[i], path, 1|2|4);
|
||||||
if(ret<=0)
|
if(ret<=0)
|
||||||
continue;
|
continue;
|
||||||
ret= Xorriso_fake_stbuf(xorriso, path, &stbuf, &node, (flag&4)>>1);
|
ret= Xorriso_fake_stbuf(xorriso, path, &stbuf, &node, ((flag&4) >> 1) | 16);
|
||||||
if(ret<=0)
|
if(ret<=0)
|
||||||
continue;
|
continue;
|
||||||
if(LIBISO_ISDIR(node) && !(flag&(4|8))) {
|
if(LIBISO_ISDIR(node) && !(flag&(4|8))) {
|
||||||
@ -11368,12 +11356,7 @@ int Xorriso_set_filter(struct XorrisO *xorriso, void *in_node,
|
|||||||
ret= 0; goto ex;
|
ret= 0; goto ex;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* <<< Adding a filter is an initial image change only if node in
|
|
||||||
old image and indev!=outdev
|
|
||||||
xorriso->volset_change_pending= 1;
|
|
||||||
*/
|
|
||||||
ret= filter_ret;
|
ret= filter_ret;
|
||||||
|
|
||||||
ex:;
|
ex:;
|
||||||
if(old_name != NULL)
|
if(old_name != NULL)
|
||||||
free(old_name);
|
free(old_name);
|
||||||
@ -11877,12 +11860,6 @@ int Xorriso_hardlink_update(struct XorrisO *xorriso, int *compare_result,
|
|||||||
dev_t old_dev;
|
dev_t old_dev;
|
||||||
ino_t old_ino;
|
ino_t old_ino;
|
||||||
|
|
||||||
#ifdef Xorriso_hardlink_update_direcT
|
|
||||||
/* <<< */
|
|
||||||
int node_result;
|
|
||||||
char node_path[SfileadrL];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if(xorriso->di_array == NULL)
|
if(xorriso->di_array == NULL)
|
||||||
return(1);
|
return(1);
|
||||||
follow_links= xorriso->do_follow_links ||
|
follow_links= xorriso->do_follow_links ||
|
||||||
@ -11983,35 +11960,7 @@ int Xorriso_hardlink_update(struct XorrisO *xorriso, int *compare_result,
|
|||||||
}
|
}
|
||||||
#endif /* Xorriso_hardlink_update_debuG */
|
#endif /* Xorriso_hardlink_update_debuG */
|
||||||
|
|
||||||
#ifdef Xorriso_hardlink_update_direcT
|
|
||||||
/* <<< */
|
|
||||||
|
|
||||||
/* Is the alleged sibling still a valid mirror of disk_path ? */
|
|
||||||
ret= Xorriso_path_from_node(xorriso, xorriso->di_array[i], node_path, 0);
|
|
||||||
if(ret < 0)
|
|
||||||
goto ex;
|
|
||||||
if(ret == 0)
|
|
||||||
continue; /* Node is deleted from tree */
|
|
||||||
|
|
||||||
node_result= 0;
|
|
||||||
ret= Xorriso_compare_2_files(xorriso, disk_path, node_path, "",
|
|
||||||
&node_result, 2 | follow_links | (7 << 29));
|
|
||||||
if(ret >= 0) {
|
|
||||||
/* Overwrite sibling if it would *not* be overwritten by itself.
|
|
||||||
(If it would be overwritten then it might be not a valid hardlink
|
|
||||||
sibling.) */
|
|
||||||
ret= Xorriso_update_interpreter(xorriso, NULL, node_result, disk_path,
|
|
||||||
node_path, 1 | 4);
|
|
||||||
if(ret < 0)
|
|
||||||
goto ex;
|
|
||||||
}
|
|
||||||
|
|
||||||
#else /* Xorriso_hardlink_update_direcT */
|
|
||||||
|
|
||||||
xorriso->di_do_widen[i / 8]|= 1 << (i % 8);
|
xorriso->di_do_widen[i / 8]|= 1 << (i % 8);
|
||||||
|
|
||||||
#endif /* ! Xorriso_hardlink_update_direcT */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret= 1;
|
ret= 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user