Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for XML embedded in chains #1047

Merged
merged 2 commits into from
Dec 18, 2024
Merged

Add support for XML embedded in chains #1047

merged 2 commits into from
Dec 18, 2024

Conversation

bmatherly
Copy link
Member

No description provided.

Comment on lines 42 to 43
// Always use a producer-consumer for xml so that the profile can be changed
source = mlt_factory_producer(profile.get_profile(), "consumer", service);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I noticed when recently debugging a related issue in Shotcut that the XML as Clip already gets a consumer producer if the profiles mismatch (a feature of the loader producer). Is that different when using a chain? It is not very desirable to add knowledge about certain modules within the framework proper. It is not a hard rule but rather a goal to minimize it.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I noticed this too. When encapsulating XML producer in a chain, the problem becomes that sometimes that producer would be wrapped in consumer producer and sometimes it would not. The chain needs to be able to change the profile on the encapsulated producer. The XML producer does not support this very well because it does not propagate the profile change down to the producers inside of it. Forcing it to always use the producer_consumer works around that problem.

It is not very desirable to add knowledge about certain modules within the framework proper.

I agree - and I would prefer a generic way to do this. Another option would be to add a private property to producers called "_mutable_profile". If the profile can be changed (like avformat), then the property would be true. If the profile can not be changed (like xml), the property would be false. That could be the condition to decide if a producer_consumer should be used.

@bmatherly
Copy link
Member Author

All great comments. Thanks.

@ddennedy ddennedy added this to the v7.28.0 milestone Dec 18, 2024
@ddennedy ddennedy merged commit 71c4dfd into master Dec 18, 2024
12 checks passed
@ddennedy ddennedy deleted the nested_chain branch December 18, 2024 05:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants