/* SPDX-License-Identifier: GPL-2.0-or-later * Copyright 2001-2002 NaN Holding BV. All rights reserved. */ #pragma once /** \file * \ingroup blenloader * \brief external `writefile.c` function prototypes. */ #ifdef __cplusplus extern "C" { #endif struct BlendThumbnail; struct Main; struct MemFile; struct ReportList; /* -------------------------------------------------------------------- */ /** \name BLO Write File API * * \see #BLO_read_from_file for file reading. * \{ */ /** * Adjust paths when saving (kept unless #BlendFileWriteParams.use_save_as_copy is set). */ typedef enum eBLO_WritePathRemap { /** No path manipulation. */ BLO_WRITE_PATH_REMAP_NONE = 0, /** Remap existing relative paths (default). */ BLO_WRITE_PATH_REMAP_RELATIVE = 1, /** Remap paths making all paths relative to the new location. */ BLO_WRITE_PATH_REMAP_RELATIVE_ALL = 2, /** Make all paths absolute. */ BLO_WRITE_PATH_REMAP_ABSOLUTE = 3, } eBLO_WritePathRemap; /** Similar to #BlendFileReadParams. */ struct BlendFileWriteParams { eBLO_WritePathRemap remap_mode; /** Save `.blend1`, `.blend2`... etc. */ uint use_save_versions : 1; /** On write, restore paths after editing them (see #BLO_WRITE_PATH_REMAP_RELATIVE). */ uint use_save_as_copy : 1; uint use_userdef : 1; const struct BlendThumbnail *thumb; }; /** * \return Success. */ extern bool BLO_write_file(struct Main *mainvar, const char *filepath, int write_flags, const struct BlendFileWriteParams *params, struct ReportList *reports); /** * \return Success. */ extern bool BLO_write_file_mem(struct Main *mainvar, struct MemFile *compare, struct MemFile *current, int write_flags); /** \} */ #ifdef __cplusplus } #endif