Lua window: Fix inconsistency of 'parent directory' appearance. Now applies the 'show hidden files/dirs' settings too.

git-svn-id: svn://pulkomandy.tk/GrafX2/trunk@1760 416bcca6-2ee7-4201-b75f-2eb2f807beb1
This commit is contained in:
Yves Rizoud 2011-03-23 20:13:12 +00:00
parent 92b76f2126
commit 9f8dada2b0
5 changed files with 39 additions and 23 deletions

View File

@ -25,14 +25,11 @@
#include <proto/dos.h> #include <proto/dos.h>
#include <sys/types.h> #include <sys/types.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined(__WIN32__) #elif defined(__WIN32__)
#include <dirent.h> #include <dirent.h>
#include <windows.h> #include <windows.h>
#define isHidden(x) (GetFileAttributesA((x)->d_name)&FILE_ATTRIBUTE_HIDDEN)
#else #else
#include <dirent.h> #include <dirent.h>
#define isHidden(x) ((x)->d_name[0]=='.')
#endif #endif
#define _XOPEN_SOURCE 500 #define _XOPEN_SOURCE 500
@ -82,18 +79,14 @@
#if defined(__amigaos4__) || defined(__AROS__) || defined(__MORPHOS__) || defined(__amigaos__) #if defined(__amigaos4__) || defined(__AROS__) || defined(__MORPHOS__) || defined(__amigaos__)
#include <proto/dos.h> #include <proto/dos.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined(__MINT__) #elif defined(__MINT__)
#include <mint/sysbind.h> #include <mint/sysbind.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined(__WIN32__) #elif defined(__WIN32__)
#include <dirent.h> #include <dirent.h>
#include <windows.h> #include <windows.h>
#define isHidden(x) (GetFileAttributesA((x)->d_name)&FILE_ATTRIBUTE_HIDDEN)
#else #else
#include <dirent.h> #include <dirent.h>
#define isHidden(x) ((x)->d_name[0]=='.')
#endif #endif
extern char Program_version[]; // generated in pversion.c extern char Program_version[]; // generated in pversion.c

View File

@ -1388,8 +1388,8 @@ void Add_script(const char *name, byte is_file, byte is_directory, byte is_hidde
if (len<=4 || strcasecmp(file_name+len-4, ".lua")) if (len<=4 || strcasecmp(file_name+len-4, ".lua"))
return; return;
// Hidden // Hidden
//if (is_hidden && !Config.Show_hidden_files) if (is_hidden && !Config.Show_hidden_files)
// return; return;
Add_element_to_list(&Scripts_selector, file_name, Format_filename(file_name, NAME_WIDTH+1, 0), 0, ICON_NONE); Add_element_to_list(&Scripts_selector, file_name, Format_filename(file_name, NAME_WIDTH+1, 0), 0, ICON_NONE);
} }
@ -1398,9 +1398,12 @@ void Add_script(const char *name, byte is_file, byte is_directory, byte is_hidde
// Ignore current directory // Ignore current directory
if ( !strcmp(file_name, ".")) if ( !strcmp(file_name, "."))
return; return;
// Ignore parent directory entry
if (!strcmp(file_name, PARENT_DIR))
return;
// Hidden // Hidden
//if (is_hidden && !Config.Show_hidden_directories) if (is_hidden && !Config.Show_hidden_directories)
// return; return;
Add_element_to_list(&Scripts_selector, file_name, Format_filename(file_name, NAME_WIDTH+1, 1), 1, ICON_NONE); Add_element_to_list(&Scripts_selector, file_name, Format_filename(file_name, NAME_WIDTH+1, 1), 1, ICON_NONE);
} }
@ -1698,6 +1701,8 @@ void Button_Brush_Factory(void)
strcpy(scriptdir, Data_directory); strcpy(scriptdir, Data_directory);
strcat(scriptdir, "scripts/"); strcat(scriptdir, "scripts/");
strcat(scriptdir, sub_directory); strcat(scriptdir, sub_directory);
if (sub_directory[0]!='\0')
Add_element_to_list(&Scripts_selector, PARENT_DIR, Format_filename(PARENT_DIR, NAME_WIDTH+1, 1), 1, ICON_NONE);
// Add each found file to the list // Add each found file to the list
For_each_directory_entry(scriptdir, Add_script); For_each_directory_entry(scriptdir, Add_script);
// Sort it // Sort it
@ -1851,6 +1856,8 @@ void Button_Brush_Factory(void)
strcpy(scriptdir, Data_directory); strcpy(scriptdir, Data_directory);
strcat(scriptdir, "scripts/"); strcat(scriptdir, "scripts/");
strcat(scriptdir, sub_directory); strcat(scriptdir, sub_directory);
if (sub_directory[0]!='\0')
Add_element_to_list(&Scripts_selector, PARENT_DIR, Format_filename(PARENT_DIR, NAME_WIDTH+1, 1), 1, ICON_NONE);
// Add each found file to the list // Add each found file to the list
For_each_directory_entry(scriptdir, Add_script); For_each_directory_entry(scriptdir, Add_script);
// Sort it // Sort it

View File

@ -29,20 +29,15 @@
#include <proto/dos.h> #include <proto/dos.h>
#include <sys/types.h> #include <sys/types.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined (__MINT__) #elif defined (__MINT__)
#include <mint/sysbind.h> #include <mint/sysbind.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined(__WIN32__) #elif defined(__WIN32__)
#include <dirent.h> #include <dirent.h>
#include <windows.h> #include <windows.h>
#include <commdlg.h> #include <commdlg.h>
#define isHidden(x) (GetFileAttributesA((x)->d_name)&FILE_ATTRIBUTE_HIDDEN)
#else #else
#include <dirent.h> #include <dirent.h>
#define isHidden(x) ((x)->d_name[0]=='.')
#endif #endif
#include <stdlib.h> #include <stdlib.h>
@ -393,7 +388,7 @@ void Read_list_of_files(T_Fileselector *list, byte selected_format)
(!strcmp(entry->d_name, PARENT_DIR) || (!strcmp(entry->d_name, PARENT_DIR) ||
// ou qu'il n'est pas caché // ou qu'il n'est pas caché
Config.Show_hidden_directories || Config.Show_hidden_directories ||
!isHidden(entry))) !File_is_hidden(entry->d_name)))
{ {
// On rajoute le répertoire à la liste // On rajoute le répertoire à la liste
Add_element_to_list(list, entry->d_name, Format_filename(entry->d_name, 19, 1), 1, ICON_NONE); Add_element_to_list(list, entry->d_name, Format_filename(entry->d_name, 19, 1), 1, ICON_NONE);
@ -401,7 +396,7 @@ void Read_list_of_files(T_Fileselector *list, byte selected_format)
} }
else if (S_ISREG(Infos_enreg.st_mode) && //Il s'agit d'un fichier else if (S_ISREG(Infos_enreg.st_mode) && //Il s'agit d'un fichier
(Config.Show_hidden_files || //Il n'est pas caché (Config.Show_hidden_files || //Il n'est pas caché
!isHidden(entry))) File_is_hidden(entry->d_name)))
{ {
const char * ext = filter; const char * ext = filter;
while (ext!=NULL) while (ext!=NULL)

View File

@ -37,20 +37,16 @@
#include <proto/dos.h> #include <proto/dos.h>
#include <sys/types.h> #include <sys/types.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#elif defined(__WIN32__) #elif defined(__WIN32__)
#include <dirent.h> #include <dirent.h>
#include <windows.h> #include <windows.h>
//#include <commdlg.h> //#include <commdlg.h>
#define isHidden(x) (GetFileAttributesA((x)->d_name)&FILE_ATTRIBUTE_HIDDEN)
#elif defined(__MINT__) #elif defined(__MINT__)
#include <mint/osbind.h> #include <mint/osbind.h>
#include <mint/sysbind.h> #include <mint/sysbind.h>
#include <dirent.h> #include <dirent.h>
#define isHidden(x) (0)
#else #else
#include <dirent.h> #include <dirent.h>
#define isHidden(x) ((x)->d_name[0]=='.')
#endif #endif
#include "struct.h" #include "struct.h"
@ -242,6 +238,28 @@ int Directory_exists(char * directory)
} }
} }
#if defined(__amigaos4__) || defined(__AROS__) || defined(__MORPHOS__) || defined(__amigaos__) || defined(__MINT__)
#define FILE_IS_HIDDEN_ATTRIBUTE __attribute__((unused))
#else
#define FILE_IS_HIDDEN_ATTRIBUTE
#endif
/// Check if a file or directory is hidden.
int File_is_hidden(FILE_IS_HIDDEN_ATTRIBUTE const char *fname)
{
#if defined(__amigaos4__) || defined(__AROS__) || defined(__MORPHOS__) || defined(__amigaos__) || defined(__MINT__)
// False (unable to determine, or irrrelevent for platform)
return 0;
#elif defined(__WIN32__)
unsigned long att = GetFileAttributesA(fname);
if (att==INVALID_FILE_ATTRIBUTES)
return 0;
return att&FILE_ATTRIBUTE_HIDDEN?1:0;
#else
return fname[0]=='.';
#endif
}
// Taille de fichier, en octets // Taille de fichier, en octets
int File_length(const char * fname) int File_length(const char * fname)
{ {
@ -313,7 +331,7 @@ void For_each_directory_entry(const char * directory_name, void Callback(const c
full_filename, full_filename,
S_ISREG(Infos_enreg.st_mode), S_ISREG(Infos_enreg.st_mode),
S_ISDIR(Infos_enreg.st_mode), S_ISDIR(Infos_enreg.st_mode),
isHidden(entry)?1:0); File_is_hidden(entry->d_name));
} }
closedir(current_directory); closedir(current_directory);
} }

View File

@ -90,6 +90,9 @@ int File_exists(char * fname);
/// Returns true if a directory passed as a parameter exists in the current directory. /// Returns true if a directory passed as a parameter exists in the current directory.
int Directory_exists(char * directory); int Directory_exists(char * directory);
/// Check if a file or directory is hidden.
int File_is_hidden(const char *fname);
/// Scans a directory, calls Callback for each file in it, /// Scans a directory, calls Callback for each file in it,
void For_each_file(const char * directory_name, void Callback(const char *)); void For_each_file(const char * directory_name, void Callback(const char *));