mirror of https://github.com/odrling/Aegisub
Check for uses of styles other than "Default" in CanSave rather than customized styles
Customizable default styles makes the latter check awkward to implement, and the previous logic of comparing against the hardcoded default wrong.
This commit is contained in:
parent
bc2f862909
commit
562a2259f5
|
@ -86,14 +86,9 @@ bool SubtitleFormat::CanSave(const AssFile *subs) const {
|
||||||
if (!subs->Attachments.empty())
|
if (!subs->Attachments.empty())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
std::string defstyle = AssStyle().GetEntryData();
|
auto def = boost::flyweight<std::string>("Default");
|
||||||
for (auto const& line : subs->Styles) {
|
|
||||||
if (line.GetEntryData() != defstyle)
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto const& line : subs->Events) {
|
for (auto const& line : subs->Events) {
|
||||||
if (line.GetStrippedText() != line.Text)
|
if (line.Style != def || line.GetStrippedText() != line.Text)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -334,9 +334,7 @@ SRTSubtitleFormat::SRTSubtitleFormat()
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> SRTSubtitleFormat::GetReadWildcards() const {
|
std::vector<std::string> SRTSubtitleFormat::GetReadWildcards() const {
|
||||||
std::vector<std::string> formats;
|
return {"srt"};
|
||||||
formats.push_back("srt");
|
|
||||||
return formats;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> SRTSubtitleFormat::GetWriteWildcards() const {
|
std::vector<std::string> SRTSubtitleFormat::GetWriteWildcards() const {
|
||||||
|
@ -494,7 +492,11 @@ bool SRTSubtitleFormat::CanSave(const AssFile *file) const {
|
||||||
if (!file->Attachments.empty())
|
if (!file->Attachments.empty())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
auto def = boost::flyweight<std::string>("Default");
|
||||||
for (auto const& line : file->Events) {
|
for (auto const& line : file->Events) {
|
||||||
|
if (line.Style != def)
|
||||||
|
return false;
|
||||||
|
|
||||||
auto blocks = line.ParseTags();
|
auto blocks = line.ParseTags();
|
||||||
for (auto ovr : blocks | agi::of_type<AssDialogueBlockOverride>()) {
|
for (auto ovr : blocks | agi::of_type<AssDialogueBlockOverride>()) {
|
||||||
// Verify that all overrides used are supported
|
// Verify that all overrides used are supported
|
||||||
|
|
Loading…
Reference in New Issue