PhotoRec: fix file descriptor leak when bruteforce mode is enabled
This commit is contained in:
parent
3e91667fb2
commit
319e5b55cb
2 changed files with 15 additions and 2 deletions
|
@ -28,6 +28,9 @@
|
||||||
#ifdef HAVE_STDLIB_H
|
#ifdef HAVE_STDLIB_H
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h> /* unlink */
|
||||||
|
#endif
|
||||||
#ifdef HAVE_STRING_H
|
#ifdef HAVE_STRING_H
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -289,6 +292,12 @@ pstatus_t photorec_bf(struct ph_param *params, const struct ph_options *options,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(file_recovery.handle!=NULL)
|
||||||
|
{
|
||||||
|
fclose(file_recovery.handle);
|
||||||
|
file_recovery.handle=NULL;
|
||||||
|
unlink(file_recovery.filename);
|
||||||
|
}
|
||||||
search_walker=p;
|
search_walker=p;
|
||||||
if(go_backward==0)
|
if(go_backward==0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -618,6 +618,11 @@ int file_finish_bf(file_recovery_t *file_recovery, struct ph_param *params,
|
||||||
if(file_recovery->offset_error!=0)
|
if(file_recovery->offset_error!=0)
|
||||||
return -1;
|
return -1;
|
||||||
file_block_truncate_zero(file_recovery, list_search_space);
|
file_block_truncate_zero(file_recovery, list_search_space);
|
||||||
|
if(file_recovery->handle!=NULL)
|
||||||
|
{
|
||||||
|
fclose(file_recovery->handle);
|
||||||
|
unlink(file_recovery->filename);
|
||||||
|
}
|
||||||
reset_file_recovery(file_recovery);
|
reset_file_recovery(file_recovery);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -627,7 +632,6 @@ int file_finish_bf(file_recovery_t *file_recovery, struct ph_param *params,
|
||||||
xml_log_file_recovered(file_recovery);
|
xml_log_file_recovered(file_recovery);
|
||||||
#endif
|
#endif
|
||||||
file_block_free(&file_recovery->location);
|
file_block_free(&file_recovery->location);
|
||||||
reset_file_recovery(file_recovery);
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -647,7 +651,7 @@ int file_finish2(file_recovery_t *file_recovery, struct ph_param *params, const
|
||||||
if(file_recovery->file_stat==NULL)
|
if(file_recovery->file_stat==NULL)
|
||||||
return 0;
|
return 0;
|
||||||
if(file_recovery->handle)
|
if(file_recovery->handle)
|
||||||
file_finish_aux(file_recovery, params, paranoid);
|
file_finish_aux(file_recovery, params, (paranoid==0?0:1));
|
||||||
if(file_recovery->file_size==0)
|
if(file_recovery->file_size==0)
|
||||||
{
|
{
|
||||||
file_block_truncate_zero(file_recovery, list_search_space);
|
file_block_truncate_zero(file_recovery, list_search_space);
|
||||||
|
|
Loading…
Reference in a new issue