Files
test/source/blender/sequencer/SEQ_sequencer.hh
Hans Goudey 8b9e667eab Revert "Sequencer: Avoid storing un-tracked pointers in blend files"
This reverts commit 58554964e4.
Caused unexpected test failures, may need more review.
2025-08-20 11:31:02 -04:00

180 lines
5.5 KiB
C++

/* SPDX-FileCopyrightText: 2004-2024 Blender Authors
*
* SPDX-License-Identifier: GPL-2.0-or-later */
#pragma once
/** \file
* \ingroup sequencer
*/
#include "DNA_scene_types.h"
struct BlendDataReader;
struct BlendWriter;
struct Depsgraph;
struct Editing;
struct Main;
struct MetaStack;
struct Scene;
struct SeqTimelineChannel;
struct Strip;
struct SequencerToolSettings;
namespace blender::seq {
constexpr int MAX_CHANNELS = 128;
/* RNA enums, just to be more readable */
enum {
SIDE_MOUSE = -1,
SIDE_NONE = 0,
SIDE_LEFT,
SIDE_RIGHT,
SIDE_BOTH,
SIDE_NO_CHANGE,
};
/* strip_duplicate' flags */
enum class StripDuplicate : uint8_t {
/* Note: Technically, the selected strips are duplicated when `All` is not set. */
Selected = 0,
/* Ensure strips have a unique name. */
UniqueName = (1 << 0),
/* Duplicate strips and the IDs they reference. */
Data = (1 << 1),
/* If this is set, duplicate all strips. If not set, duplicate selected strips. */
All = (1 << 3),
};
ENUM_OPERATORS(StripDuplicate, StripDuplicate::All);
SequencerToolSettings *tool_settings_init();
SequencerToolSettings *tool_settings_ensure(Scene *scene);
void tool_settings_free(SequencerToolSettings *tool_settings);
eSeqImageFitMethod tool_settings_fit_method_get(Scene *scene);
void tool_settings_fit_method_set(Scene *scene, eSeqImageFitMethod fit_method);
short tool_settings_snap_flag_get(Scene *scene);
short tool_settings_snap_mode_get(Scene *scene);
int tool_settings_snap_distance_get(Scene *scene);
eSeqOverlapMode tool_settings_overlap_mode_get(Scene *scene);
int tool_settings_pivot_point_get(Scene *scene);
SequencerToolSettings *tool_settings_copy(SequencerToolSettings *tool_settings);
Editing *editing_get(const Scene *scene);
Editing *editing_ensure(Scene *scene);
void editing_free(Scene *scene, bool do_id_user);
/**
* Get seqbase that is being viewed currently. This can be main seqbase or meta strip seqbase
*
* \param ed: sequence editor data
* \return pointer to active seqbase. returns NULL if ed is NULL
*/
ListBase *active_seqbase_get(const Editing *ed);
/**
* Set seqbase that is being viewed currently. This can be main seqbase or meta strip seqbase
*
* \param ed: sequence editor data
* \param seqbase: ListBase with strips
*/
void active_seqbase_set(Editing *ed, ListBase *seqbase);
Strip *strip_alloc(ListBase *lb, int timeline_frame, int channel, int type);
void strip_free(Scene *scene, Strip *strip);
/**
* Get #MetaStack that corresponds to current level that is being viewed
*
* \return pointer to meta stack
*/
MetaStack *meta_stack_active_get(const Editing *ed);
/**
* Open Meta strip content for editing.
*
* \param ed: sequence editor data
* \param dst: meta strip or NULL for top level view
*/
void meta_stack_set(const Scene *scene, Strip *dst);
/**
* Close last Meta strip open for editing.
*
* \param ed: sequence editor data
*/
Strip *meta_stack_pop(Editing *ed);
Strip *strip_duplicate_recursive(Main *bmain,
const Scene *scene_src,
Scene *scene_dst,
ListBase *new_seq_list,
Strip *strip,
StripDuplicate dupe_flag);
void seqbase_duplicate_recursive(Main *bmain,
const Scene *scene_src,
Scene *scene_dst,
ListBase *nseqbase,
const ListBase *seqbase,
StripDuplicate dupe_flag,
int flag);
bool is_valid_strip_channel(const Strip *strip);
/**
* Read and Write functions for `.blend` file data.
*/
void blend_write(BlendWriter *writer, ListBase *seqbase);
void blend_read(BlendDataReader *reader, ListBase *seqbase);
void doversion_250_sound_proxy_update(Main *bmain, Editing *ed);
/* Depsgraph update function. */
/**
* Evaluate parts of strips which needs to be done as a part of a dependency graph evaluation.
* This does NOT include actual rendering of the strips, but rather makes them up-to-date for
* animation playback and makes them ready for the sequencer's rendering pipeline to render them.
*/
void eval_strips(Depsgraph *depsgraph, Scene *scene, ListBase *seqbase);
/**
* Find a strip with a given name.
* If lookup hash doesn't exist, it will be created. If hash is tagged as invalid, it will be
* rebuilt.
*
* \param ed: Editing that owns lookup hash
* \param key: Strip name without SQ prefix (strip->name + 2)
*
* \return pointer to Strip
*/
Strip *lookup_strip_by_name(Editing *ed, const char *key);
/**
* Find a strips using provided scene as input
*
* \param ed: Editing that owns lookup hash
* \param key: Input Scene pointer
*
* \return Span of strips
*/
Span<Strip *> lookup_strips_by_scene(Editing *ed, const Scene *key);
/**
* Find which meta strip the given timeline channel belongs to. Returns nullptr if it is a global
* channel.
*/
Strip *lookup_strip_by_channel_owner(Editing *ed, const SeqTimelineChannel *channel);
/**
* Find meta strip, that contains strip `key`.
* If lookup hash doesn't exist, it will be created. If hash is tagged as invalid, it will be
* rebuilt.
*
* \param key: pointer to Strip inside of meta strip
*
* \return pointer to meta strip
*/
Strip *lookup_meta_by_strip(Editing *ed, const Strip *key);
/**
* Free lookup hash data.
*/
void strip_lookup_free(Editing *ed);
/**
* Mark strip lookup as invalid (i.e. will need rebuilding).
*/
void strip_lookup_invalidate(const Editing *ed);
} // namespace blender::seq