11f34732cfc762e977bf139ab9911e3ba6399cad
[blender.git] / source / blender / blenloader / BLO_readfile.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 #ifndef __BLO_READFILE_H__
28 #define __BLO_READFILE_H__
29
30 /** \file BLO_readfile.h
31  *  \ingroup blenloader
32  *  \brief external readfile function prototypes.
33  */
34
35 #ifdef __cplusplus
36 extern "C" {
37 #endif
38
39 struct BlendThumbnail;
40 struct bScreen;
41 struct LinkNode;
42 struct Main;
43 struct MemFile;
44 struct ReportList;
45 struct Scene;
46 struct UserDef;
47 struct View3D;
48 struct bContext;
49 struct BHead;
50 struct FileData;
51
52 typedef struct BlendHandle BlendHandle;
53
54 typedef enum eBlenFileType {
55         BLENFILETYPE_BLEND = 1,
56         BLENFILETYPE_PUB = 2,
57         BLENFILETYPE_RUNTIME = 3
58 } eBlenFileType;
59
60 typedef struct BlendFileData {
61         struct Main *main;
62         struct UserDef *user;
63
64         int fileflags;
65         int globalf;
66         char filename[1024];    /* 1024 = FILE_MAX */
67
68         struct bScreen *curscreen;
69         struct Scene *curscene;
70
71         eBlenFileType type;
72 } BlendFileData;
73
74
75 /* skip reading some data-block types (may want to skip screen data too). */
76 typedef enum eBLOReadSkip {
77         BLO_READ_SKIP_NONE          = 0,
78         BLO_READ_SKIP_USERDEF       = (1 << 0),
79         BLO_READ_SKIP_DATA          = (1 << 1),
80 } eBLOReadSkip;
81 #define BLO_READ_SKIP_ALL \
82         (BLO_READ_SKIP_USERDEF | BLO_READ_SKIP_DATA)
83
84 BlendFileData *BLO_read_from_file(
85         const char *filepath,
86         struct ReportList *reports, eBLOReadSkip skip_flag);
87 BlendFileData *BLO_read_from_memory(
88         const void *mem, int memsize,
89         struct ReportList *reports, eBLOReadSkip skip_flag);
90 BlendFileData *BLO_read_from_memfile(
91         struct Main *oldmain, const char *filename, struct MemFile *memfile,
92         struct ReportList *reports, eBLOReadSkip skip_flag);
93
94 void BLO_blendfiledata_free(BlendFileData *bfd);
95
96 BlendHandle *BLO_blendhandle_from_file(const char *filepath, struct ReportList *reports);
97 BlendHandle *BLO_blendhandle_from_memory(const void *mem, int memsize);
98
99 struct LinkNode *BLO_blendhandle_get_datablock_names(BlendHandle *bh, int ofblocktype, int *tot_names);
100 struct LinkNode *BLO_blendhandle_get_previews(BlendHandle *bh, int ofblocktype, int *tot_prev);
101 struct LinkNode *BLO_blendhandle_get_linkable_groups(BlendHandle *bh);
102
103 void BLO_blendhandle_close(BlendHandle *bh);
104
105 /***/
106
107 #define BLO_GROUP_MAX 32
108
109 bool BLO_has_bfile_extension(const char *str);
110 bool BLO_library_path_explode(const char *path, char *r_dir, char **r_group, char **r_name);
111
112 /* Options controlling behavior of append/link code.
113  * Note: merged with 'user-level' options from operators etc. in 16 lower bits
114  *       (see eFileSel_Params_Flag in DNA_space_types.h). */
115 typedef enum BLO_LibLinkFlags {
116         /* Generate a placeholder (empty ID) if not found in current lib file. */
117         BLO_LIBLINK_USE_PLACEHOLDERS = 1 << 16,
118         /* Force loaded ID to be tagged as LIB_TAG_INDIRECT (used in reload context only). */
119         BLO_LIBLINK_FORCE_INDIRECT   = 1 << 17,
120 } BLO_LinkFlags;
121
122 struct Main *BLO_library_link_begin(struct Main *mainvar, BlendHandle **bh, const char *filepath);
123 struct ID *BLO_library_link_named_part(struct Main *mainl, BlendHandle **bh, const short idcode, const char *name);
124 struct ID *BLO_library_link_named_part_ex(
125         struct Main *mainl, BlendHandle **bh,
126         const short idcode, const char *name, const int flag,
127         struct Scene *scene, struct View3D *v3d);
128 void BLO_library_link_end(struct Main *mainl, BlendHandle **bh, short flag, struct Scene *scene, struct View3D *v3d);
129
130 void BLO_library_link_copypaste(struct Main *mainl, BlendHandle *bh);
131
132 void *BLO_library_read_struct(struct FileData *fd, struct BHead *bh, const char *blockname);
133
134 BlendFileData *blo_read_blendafterruntime(int file, const char *name, int actualsize, struct ReportList *reports);
135
136 /* internal function but we need to expose it */
137 void blo_lib_link_screen_restore(struct Main *newmain, struct bScreen *curscreen, struct Scene *curscene);
138
139 typedef void (*BLOExpandDoitCallback) (void *fdhandle, struct Main *mainvar, void *idv);
140
141 void BLO_main_expander(BLOExpandDoitCallback expand_doit_func);
142 void BLO_expand_main(void *fdhandle, struct Main *mainvar);
143
144 /* Update defaults in startup.blend & userprefs.blend, without having to save and embed it */
145 void BLO_update_defaults_userpref_blend(void);
146 void BLO_update_defaults_startup_blend(struct Main *mainvar);
147
148 struct BlendThumbnail *BLO_thumbnail_from_file(const char *filepath);
149
150 struct Main *BLO_main_from_memfile(struct MemFile *memfile, struct Main *bmain, struct Scene **r_scene);
151
152 #ifdef __cplusplus
153 }
154 #endif
155
156 #endif  /* __BLO_READFILE_H__ */