4 * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 #include "arraylist.h"
26 #include "bcwindowbase.inc"
33 FileItem(char *path, char *name, int is_dir,
34 int64_t size, int month, int day, int year,
35 int64_t calendar_time, int item_no=-1);
38 int set_path(char *path);
39 int set_name(char *name);
42 const char *get_path() { return path; }
43 const char *get_name() { return name; }
44 int get_is_dir() { return is_dir; }
53 int64_t calendar_time;
60 // sets the working directory to the user
62 virtual ~FileSystem();
64 // Load the new directory and change current_dir to it.
65 // This does not complete the dir path.
66 // If any of the files failed to stat, it returns nonzero.
67 int scan_directory(const char*);
68 int update(const char *new_dir = 0);
71 // Complete the path in the string and change to the directory in the string.
72 // Does not change new_dir
73 // update - causes the directory to be loaded
74 int change_dir(const char *new_dir, int update = 1);
75 // Set the current_dir to something without completing the path.
76 int set_current_dir(const char *new_dir);
79 // Syntax of filter is
80 // single filter without [].
81 // multiple filters enclosed in [].
82 int set_filter(const char *new_filter);
83 int set_show_all(); // show hidden files
84 int set_want_directory();
85 int set_sort_order(int value);
86 int set_sort_field(int field);
87 int create_dir(const char *new_dir_); // create a new directory
88 int complete_path(char *filename); // use the filename and the current_dir to create a complete filename
89 // return 1 if the text is a directory
90 int is_dir(const char *new_dir_);
91 int extract_dir(char *out, const char *in); // extract the directory from the path
92 int extract_name(char *out, const char *in, int test_dir = 1); // extract the name from the path
93 int join_names(char *out, const char *dir_in, const char *name_in); // combine a directory and filename
94 static int64_t get_date(const char *path); // get the date of the filename modification
95 static void set_date(const char *path, int64_t value); // set the date of the file
96 static int64_t get_size(char *filename); // Get the number of bytes in the file.
97 int add_end_slash(char *new_dir);
99 int parse_tildas(char *new_dir); // expand tildas
100 int parse_directories(char *new_dir); // add directories
101 int parse_dots(char *new_dir); // move up directory tree after expanding tildas
102 static char *basepath(const char *path); // collapse ".", "..", "//" elements
104 // Array of files and directories in the directory pointed to by current_dir.
105 // Directories are first.
106 ArrayList<FileItem*> dir_list;
107 char *get_current_dir() { return current_dir; }
108 FileItem* get_entry(int entry) { return dir_list.values[entry]; }
109 int total_files() { return dir_list.total; }
110 void alphabetize() { sort_table(&dir_list); }
112 // Sorting order and sorting field. These are identical in BC_ListBox.
119 // Match column definitions in BC_FileBox.
129 int sort_table(ArrayList<FileItem*> *dir_list);
130 static int path_ascending(const void *ptr1, const void *ptr2);
131 static int path_descending(const void *ptr1, const void *ptr2);
132 static int size_ascending(const void *ptr1, const void *ptr2);
133 static int size_descending(const void *ptr1, const void *ptr2);
134 static int date_ascending(const void *ptr1, const void *ptr2);
135 static int date_descending(const void *ptr1, const void *ptr2);
136 static int ext_ascending(const void *ptr1, const void *ptr2);
137 static int ext_descending(const void *ptr1, const void *ptr2);
138 static int dot_reverse_filename(char *out, const char *in);
140 // Combine the directories and files into the master list, directories first.
141 int combine(ArrayList<FileItem*> *dir_list, ArrayList<FileItem*> *file_list);
142 // Whether or not the file passes the current filter.
143 int test_filter(FileItem *file);
144 int reset_parameters();
145 int delete_directory();
147 char filter[BCTEXTLEN]; // what filenames have to end in to get displayed
149 int show_all_files; // shows . files
150 char current_dir[BCTEXTLEN];
151 char string[BCTEXTLEN], string2[BCTEXTLEN];