Searching way of hidden files was changed
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
[ par2j.exe - version 1.3.2.7 or later ]
|
[ par2j.exe - version 1.3.2.8 or later ]
|
||||||
|
|
||||||
Type "par2j.exe" to see version, test integrity, and show usage below.
|
Type "par2j.exe" to see version, test integrity, and show usage below.
|
||||||
|
|
||||||
@@ -105,7 +105,8 @@ A short filename in a path will be converted to long filename.
|
|||||||
If it is "*", all files in the specified directory are searched.
|
If it is "*", all files in the specified directory are searched.
|
||||||
If these are "*.txt" and "*.doc", files with extensions ".txt" and ".doc"
|
If these are "*.txt" and "*.doc", files with extensions ".txt" and ".doc"
|
||||||
in the specified directory are searched.
|
in the specified directory are searched.
|
||||||
Hidden files are ignored by search. (you can add each by exact filename.)
|
When you don't see hidden files on Windows Explorer, they are ignored by search.
|
||||||
|
If you want to search hidden files, change Windows Explorer setting to see them.
|
||||||
|
|
||||||
[input files] can be folder, too.
|
[input files] can be folder, too.
|
||||||
If it is "folder_name", files in the folder are searched also.
|
If it is "folder_name", files in the folder are searched also.
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
// common2.c
|
// common2.c
|
||||||
// Copyright : 2022-10-13 Yutaka Sawada
|
// Copyright : 2023-03-14 Yutaka Sawada
|
||||||
// License : GPL
|
// License : GPL
|
||||||
|
|
||||||
#ifndef _UNICODE
|
#ifndef _UNICODE
|
||||||
@@ -16,6 +16,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
#include <shlobj.h>
|
||||||
#include <shlwapi.h>
|
#include <shlwapi.h>
|
||||||
#include <versionhelpers.h>
|
#include <versionhelpers.h>
|
||||||
|
|
||||||
@@ -2606,3 +2607,26 @@ int delete_file_recycle(wchar_t *file_path)
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// エクスプローラーで隠しファイルを表示する設定になってるか調べる
|
||||||
|
unsigned int get_show_hidden(void)
|
||||||
|
{
|
||||||
|
unsigned int rv;
|
||||||
|
SHELLSTATE ssf;
|
||||||
|
|
||||||
|
// Explorer の設定を調べる
|
||||||
|
SHGetSetSettings(&ssf, SSF_SHOWALLOBJECTS | SSF_SHOWSUPERHIDDEN, FALSE);
|
||||||
|
// 隠しファイルを表示するかどうか
|
||||||
|
if (ssf.fShowAllObjects){ // 表示する設定なら
|
||||||
|
// 保護されたオペレーティングシステムファイルを表示するかどうか
|
||||||
|
if (ssf.fShowSuperHidden){ // 表示する設定なら
|
||||||
|
rv = 0;
|
||||||
|
} else { // 隠し属性とシステム属性の両方で判定する
|
||||||
|
rv = FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM;
|
||||||
|
}
|
||||||
|
} else { // 隠しファイルを表示しない場合は、隠し属性だけで判定する
|
||||||
|
rv = FILE_ATTRIBUTE_HIDDEN;
|
||||||
|
}
|
||||||
|
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -393,6 +393,9 @@ void print_win32_err(void);
|
|||||||
// ファイルをゴミ箱に移す
|
// ファイルをゴミ箱に移す
|
||||||
int delete_file_recycle(wchar_t *file_path);
|
int delete_file_recycle(wchar_t *file_path);
|
||||||
|
|
||||||
|
// エクスプローラーで隠しファイルを表示する設定になってるか調べる
|
||||||
|
unsigned int get_show_hidden(void);
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
// par2_cmd.c
|
// par2_cmd.c
|
||||||
// Copyright : 2022-10-15 Yutaka Sawada
|
// Copyright : 2023-03-14 Yutaka Sawada
|
||||||
// License : GPL
|
// License : GPL
|
||||||
|
|
||||||
#ifndef _UNICODE
|
#ifndef _UNICODE
|
||||||
@@ -260,14 +260,22 @@ fclose(fp);
|
|||||||
static int search_files(
|
static int search_files(
|
||||||
wchar_t *search_path, // 検索するファイルのフル・パス、* ? も可
|
wchar_t *search_path, // 検索するファイルのフル・パス、* ? も可
|
||||||
int dir_len, // ディレクトリ部分の長さ
|
int dir_len, // ディレクトリ部分の長さ
|
||||||
int file_only, // 0以外 = ファイルのみにする
|
unsigned int filter, // 2, FILE_ATTRIBUTE_HIDDEN = 隠しファイルを無視する
|
||||||
|
// 4, FILE_ATTRIBUTE_SYSTEM = システムファイルを無視する
|
||||||
|
// 16, FILE_ATTRIBUTE_DIRECTORY = ディレクトリを無視する
|
||||||
int single_file) // -1 = *や?で検索指定、0~ = 単独指定
|
int single_file) // -1 = *や?で検索指定、0~ = 単独指定
|
||||||
{
|
{
|
||||||
int len, dir_len2, old_num;
|
int len, dir_len2, old_num;
|
||||||
|
unsigned int attrib_filter;
|
||||||
__int64 file_size;
|
__int64 file_size;
|
||||||
HANDLE hFind;
|
HANDLE hFind;
|
||||||
WIN32_FIND_DATA FindData;
|
WIN32_FIND_DATA FindData;
|
||||||
|
|
||||||
|
// 隠しファイルを見つけるかどうか
|
||||||
|
attrib_filter = filter & (FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM);
|
||||||
|
if (attrib_filter == 0)
|
||||||
|
attrib_filter = INVALID_FILE_ATTRIBUTES;
|
||||||
|
|
||||||
if (list_buf == NULL){
|
if (list_buf == NULL){
|
||||||
list_len = 0;
|
list_len = 0;
|
||||||
list_max = ALLOC_LEN;
|
list_max = ALLOC_LEN;
|
||||||
@@ -303,7 +311,7 @@ static int search_files(
|
|||||||
do {
|
do {
|
||||||
if ((wcscmp(FindData.cFileName, L".") == 0) || (wcscmp(FindData.cFileName, L"..") == 0))
|
if ((wcscmp(FindData.cFileName, L".") == 0) || (wcscmp(FindData.cFileName, L"..") == 0))
|
||||||
continue; // 自分や親のパスは無視する
|
continue; // 自分や親のパスは無視する
|
||||||
if ((single_file < 0) && (FindData.dwFileAttributes & FILE_ATTRIBUTE_HIDDEN))
|
if ((single_file < 0) && ((FindData.dwFileAttributes & attrib_filter) == attrib_filter))
|
||||||
continue; // 検索中は隠し属性が付いてるファイルを無視する
|
continue; // 検索中は隠し属性が付いてるファイルを無視する
|
||||||
|
|
||||||
len = (int)wcslen(FindData.cFileName); // 見つけたファイル名の文字数
|
len = (int)wcslen(FindData.cFileName); // 見つけたファイル名の文字数
|
||||||
@@ -317,7 +325,7 @@ static int search_files(
|
|||||||
|
|
||||||
// フォルダなら
|
// フォルダなら
|
||||||
if (FindData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY){
|
if (FindData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY){
|
||||||
if (file_only == 0){
|
if ((filter & FILE_ATTRIBUTE_DIRECTORY) == 0){
|
||||||
/*
|
/*
|
||||||
if (list2_buf){ // 途中のフォルダ名も比較して除外するなら
|
if (list2_buf){ // 途中のフォルダ名も比較して除外するなら
|
||||||
int off = 0;
|
int off = 0;
|
||||||
@@ -347,7 +355,7 @@ static int search_files(
|
|||||||
dir_len2 = (int)wcslen(search_path);
|
dir_len2 = (int)wcslen(search_path);
|
||||||
search_path[dir_len2 ] = '*'; // 末尾に「*」を追加する
|
search_path[dir_len2 ] = '*'; // 末尾に「*」を追加する
|
||||||
search_path[dir_len2 + 1] = 0;
|
search_path[dir_len2 + 1] = 0;
|
||||||
if (search_files(search_path, dir_len2, file_only, single_file)){
|
if (search_files(search_path, dir_len2, filter, single_file)){
|
||||||
FindClose(hFind);
|
FindClose(hFind);
|
||||||
printf("cannot search inner folder\n");
|
printf("cannot search inner folder\n");
|
||||||
return 1;
|
return 1;
|
||||||
@@ -1761,7 +1769,7 @@ return 0;
|
|||||||
while (search_path[dir_len] != '\\')
|
while (search_path[dir_len] != '\\')
|
||||||
dir_len--;
|
dir_len--;
|
||||||
dir_len++;
|
dir_len++;
|
||||||
if (search_files(search_path, dir_len, 1, 0)){ // ファイルだけを探す
|
if (search_files(search_path, dir_len, FILE_ATTRIBUTE_DIRECTORY, 0)){ // ファイルだけを探す
|
||||||
free(list_buf);
|
free(list_buf);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@@ -1779,6 +1787,11 @@ return 0;
|
|||||||
} else { // 入力ファイルの指定
|
} else { // 入力ファイルの指定
|
||||||
wchar_t search_path[MAX_LEN];
|
wchar_t search_path[MAX_LEN];
|
||||||
int dir_len;
|
int dir_len;
|
||||||
|
unsigned int filter;
|
||||||
|
// 隠しファイルやフォルダーを無視するかどうか
|
||||||
|
filter = get_show_hidden();
|
||||||
|
if (switch_v & 8)
|
||||||
|
filter |= FILE_ATTRIBUTE_DIRECTORY;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
if (list2_buf){
|
if (list2_buf){
|
||||||
@@ -1818,7 +1831,7 @@ return 0;
|
|||||||
while (search_path[dir_len] != '\\')
|
while (search_path[dir_len] != '\\')
|
||||||
dir_len--;
|
dir_len--;
|
||||||
dir_len++;
|
dir_len++;
|
||||||
if (search_files(search_path, dir_len, switch_v & 8, j)){
|
if (search_files(search_path, dir_len, filter, j)){
|
||||||
free(list_buf);
|
free(list_buf);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user