The `lib_link` callback cannot always be fully replaced/removed, as in some case it is also doing some validation checks, or data editing based on the result of lib_linking internal ID pointers. The callback has been renamed for that purpose, from `read_lib` to `read_after_liblink`. It is now called after all ID pointers have been fully lib-linked for the current ID, but still before the call to `do_versions_after_linking`. This change should not have any behavioral effect. Although in theory the side-effect of this commit (to split lib linking itself, and the validation/further processing code) into two completely separated steps could have some effects, in practice none are expected, and tests did not show any changes in behavior either.. Part of implementing #105134: Removal of readfile's lib_link & expand code.
71 lines
2.3 KiB
C
71 lines
2.3 KiB
C
/* SPDX-FileCopyrightText: 2004 Blender Authors
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
#pragma once
|
|
|
|
/** \file
|
|
* \ingroup sequencer
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
struct BlendDataReader;
|
|
struct BlendLibReader;
|
|
struct BlendWriter;
|
|
struct ImBuf;
|
|
struct ListBase;
|
|
struct Scene;
|
|
struct SeqRenderData;
|
|
struct Sequence;
|
|
struct SequenceModifierData;
|
|
|
|
typedef struct SequenceModifierTypeInfo {
|
|
/* default name for the modifier */
|
|
char name[64]; /* MAX_NAME */
|
|
|
|
/* DNA structure name used on load/save filed */
|
|
char struct_name[64]; /* MAX_NAME */
|
|
|
|
/* size of modifier data structure, used by allocation */
|
|
int struct_size;
|
|
|
|
/* data initialization */
|
|
void (*init_data)(struct SequenceModifierData *smd);
|
|
|
|
/* free data used by modifier,
|
|
* only modifier-specific data should be freed, modifier descriptor would
|
|
* be freed outside of this callback
|
|
*/
|
|
void (*free_data)(struct SequenceModifierData *smd);
|
|
|
|
/* copy data from one modifier to another */
|
|
void (*copy_data)(struct SequenceModifierData *smd, struct SequenceModifierData *target);
|
|
|
|
/* apply modifier on a given image buffer */
|
|
void (*apply)(struct SequenceModifierData *smd, struct ImBuf *ibuf, struct ImBuf *mask);
|
|
} SequenceModifierTypeInfo;
|
|
|
|
const struct SequenceModifierTypeInfo *SEQ_modifier_type_info_get(int type);
|
|
struct SequenceModifierData *SEQ_modifier_new(struct Sequence *seq, const char *name, int type);
|
|
bool SEQ_modifier_remove(struct Sequence *seq, struct SequenceModifierData *smd);
|
|
void SEQ_modifier_clear(struct Sequence *seq);
|
|
void SEQ_modifier_free(struct SequenceModifierData *smd);
|
|
void SEQ_modifier_unique_name(struct Sequence *seq, struct SequenceModifierData *smd);
|
|
struct SequenceModifierData *SEQ_modifier_find_by_name(struct Sequence *seq, const char *name);
|
|
struct ImBuf *SEQ_modifier_apply_stack(const struct SeqRenderData *context,
|
|
struct Sequence *seq,
|
|
struct ImBuf *ibuf,
|
|
int timeline_frame);
|
|
void SEQ_modifier_list_copy(struct Sequence *seqn, struct Sequence *seq);
|
|
int SEQ_sequence_supports_modifiers(struct Sequence *seq);
|
|
|
|
void SEQ_modifier_blend_write(struct BlendWriter *writer, struct ListBase *modbase);
|
|
void SEQ_modifier_blend_read_data(struct BlendDataReader *reader, struct ListBase *lb);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|