Ensure BLI_stat() return value is checked.
[blender.git] / source / blender / blenlib / BLI_fileops.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): none yet.
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27
28 /** \file BLI_fileops.h
29  *  \ingroup bli
30  *  \brief File and directory operations.
31  * */
32
33 #ifndef __BLI_FILEOPS_H__
34 #define __BLI_FILEOPS_H__
35
36 #include <stdio.h>
37 #include <sys/stat.h>
38
39 #ifdef __cplusplus
40 extern "C" {
41 #endif
42
43 /* for size_t (needed on windows) */
44 #include <stddef.h>
45
46 #include <limits.h>  /* for PATH_MAX */
47
48 #include "BLI_compiler_attrs.h"
49
50 #ifndef PATH_MAX
51 #  define PATH_MAX 4096
52 #endif
53
54 struct gzFile;
55
56 /* Common */
57
58 int    BLI_exists(const char *path) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
59 int    BLI_copy(const char *path, const char *to) ATTR_NONNULL();
60 int    BLI_rename(const char *from, const char *to) ATTR_NONNULL();
61 int    BLI_delete(const char *path, bool dir, bool recursive) ATTR_NONNULL();
62 int    BLI_move(const char *path, const char *to) ATTR_NONNULL();
63 int    BLI_create_symlink(const char *path, const char *to) ATTR_NONNULL();
64
65 /* keep in sync with the definition of struct direntry in BLI_fileops_types.h */
66 #ifdef WIN32
67 #  if defined(_MSC_VER) || defined(__MINGW64__)
68 typedef struct _stat64 BLI_stat_t;
69 #  elif defined(__MINGW32__)
70 typedef struct _stati64 BLI_stat_t;
71 #  else
72 typedef struct _stat BLI_stat_t;
73 #  endif
74 #else
75 typedef struct stat BLI_stat_t;
76 #endif
77
78 int    BLI_stat(const char *path, BLI_stat_t *buffer) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
79 #ifdef WIN32
80 int    BLI_wstat(const wchar_t *path, BLI_stat_t *buffer);
81 #endif
82
83 /* Directories */
84
85 struct direntry;
86
87 bool   BLI_is_dir(const char *path) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
88 bool   BLI_is_file(const char *path) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
89 void   BLI_dir_create_recursive(const char *dir) ATTR_NONNULL();
90 double BLI_dir_free_space(const char *dir) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
91 char  *BLI_current_working_dir(char *dir, const size_t maxlen) ATTR_NONNULL();
92
93 /* Filelist */
94
95 unsigned int BLI_filelist_dir_contents(const char *dir, struct direntry **filelist);
96 void BLI_filelist_duplicate(
97         struct direntry **dest_filelist, struct direntry *src_filelist, unsigned int nrentries,
98         void *(*dup_poin)(void *));
99 void BLI_filelist_free(struct direntry *filelist, unsigned int nrentries, void (*free_poin)(void *));
100
101 /* Files */
102
103 FILE  *BLI_fopen(const char *filename, const char *mode) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
104 void  *BLI_gzopen(const char *filename, const char *mode) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
105 int    BLI_open(const char *filename, int oflag, int pmode) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
106 int    BLI_access(const char *filename, int mode) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
107
108 bool   BLI_file_is_writable(const char *file) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
109 bool   BLI_file_touch(const char *file) ATTR_NONNULL();
110
111 #if 0  /* UNUSED */
112 int    BLI_file_gzip(const char *from, const char *to) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
113 #endif
114 char  *BLI_file_ungzip_to_mem(const char *from_file, int *r_size) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
115
116 size_t BLI_file_descriptor_size(int file) ATTR_WARN_UNUSED_RESULT;
117 size_t BLI_file_size(const char *file) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
118
119 /* compare if one was last modified before the other */
120 bool   BLI_file_older(const char *file1, const char *file2) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
121
122 /* read ascii file as lines, empty list if reading fails */
123 struct LinkNode *BLI_file_read_as_lines(const char *file) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL();
124 void   BLI_file_free_lines(struct LinkNode *lines) ATTR_NONNULL();
125
126 /* this weirdo pops up in two places ... */
127 #if !defined(WIN32)
128 #  ifndef O_BINARY
129 #    define O_BINARY 0
130 #  endif
131 #else
132 void BLI_get_short_name(char short_name[256], const char *filename);
133 #endif
134
135 #ifdef __cplusplus
136 }
137 #endif
138
139 #endif  /* __BLI_FILEOPS_H__ */