diff --git a/src/SIL.Machine/Corpora/ParatextProjectTextUpdaterBase.cs b/src/SIL.Machine/Corpora/ParatextProjectTextUpdaterBase.cs index 07c2ca6c..ea86eb60 100644 --- a/src/SIL.Machine/Corpora/ParatextProjectTextUpdaterBase.cs +++ b/src/SIL.Machine/Corpora/ParatextProjectTextUpdaterBase.cs @@ -23,8 +23,7 @@ public string UpdateUsfm( string bookId, IReadOnlyList<(IReadOnlyList, string)> rows, string fullName = null, - bool stripAllText = false, - bool preferExistingText = true + UpdateUsfmBehavior behavior = UpdateUsfmBehavior.PreferExisting ) { string fileName = _settings.GetBookFileName(bookId); @@ -37,12 +36,7 @@ public string UpdateUsfm( usfm = reader.ReadToEnd(); } - var handler = new UpdateUsfmParserHandler( - rows, - fullName is null ? null : $"- {fullName}", - stripAllText, - preferExistingText: preferExistingText - ); + var handler = new UpdateUsfmParserHandler(rows, fullName is null ? null : $"- {fullName}", behavior); try { UsfmParser.Parse(usfm, handler, _settings.Stylesheet, _settings.Versification); diff --git a/src/SIL.Machine/Corpora/UpdateUsfmParserHandler.cs b/src/SIL.Machine/Corpora/UpdateUsfmParserHandler.cs index ce16c03d..03c9bb12 100644 --- a/src/SIL.Machine/Corpora/UpdateUsfmParserHandler.cs +++ b/src/SIL.Machine/Corpora/UpdateUsfmParserHandler.cs @@ -4,6 +4,13 @@ namespace SIL.Machine.Corpora { + public enum UpdateUsfmBehavior + { + PreferExisting, + PreferNew, + StripExisting + } + /*** * This is a USFM parser handler that can be used to replace the existing text in a USFM file with the specified * text. @@ -14,8 +21,7 @@ public class UpdateUsfmParserHandler : ScriptureRefUsfmParserHandlerBase private readonly List _tokens; private readonly List _newTokens; private readonly string _idText; - private readonly bool _stripAllText; - private readonly bool _preferExistingText; + private readonly UpdateUsfmBehavior _behavior; private readonly Stack _replace; private int _rowIndex; private int _tokenIndex; @@ -23,17 +29,15 @@ public class UpdateUsfmParserHandler : ScriptureRefUsfmParserHandlerBase public UpdateUsfmParserHandler( IReadOnlyList<(IReadOnlyList, string)> rows = null, string idText = null, - bool stripAllText = false, - bool preferExistingText = false + UpdateUsfmBehavior behavior = UpdateUsfmBehavior.PreferExisting ) { _rows = rows ?? Array.Empty<(IReadOnlyList, string)>(); _tokens = new List(); _newTokens = new List(); _idText = idText; - _stripAllText = stripAllText; _replace = new Stack(); - _preferExistingText = preferExistingText; + _behavior = behavior; } public IReadOnlyList Tokens => _tokens; @@ -371,7 +375,10 @@ private bool ReplaceWithNewTokens(UsfmParserState state) break; } } - bool useNewTokens = _stripAllText || (newText && !existingText) || (newText && !_preferExistingText); + bool useNewTokens = + _behavior == UpdateUsfmBehavior.StripExisting + || (newText && !existingText) + || (newText && _behavior == UpdateUsfmBehavior.PreferNew); if (useNewTokens) _tokens.AddRange(_newTokens); diff --git a/tests/SIL.Machine.Tests/Corpora/UpdateUsfmParserHandlerTests.cs b/tests/SIL.Machine.Tests/Corpora/UpdateUsfmParserHandlerTests.cs index 51cde197..d27873d3 100644 --- a/tests/SIL.Machine.Tests/Corpora/UpdateUsfmParserHandlerTests.cs +++ b/tests/SIL.Machine.Tests/Corpora/UpdateUsfmParserHandlerTests.cs @@ -28,7 +28,7 @@ public void GetUsfm_IdText() [Test] public void GetUsfm_StripAllText() { - string target = UpdateUsfm(stripAllText: true); + string target = UpdateUsfm(behavior: UpdateUsfmBehavior.StripExisting); Assert.That(target, Contains.Substring("\\id MAT\r\n")); Assert.That(target, Contains.Substring("\\v 1\r\n")); Assert.That(target, Contains.Substring("\\s\r\n")); @@ -43,7 +43,7 @@ public void GetUsfm_PreferExisting() (ScrRef("MAT 1:6"), "Text 6"), (ScrRef("MAT 1:7"), "Text 7"), }; - string target = UpdateUsfm(rows, preferExistingText: true); + string target = UpdateUsfm(rows, behavior: UpdateUsfmBehavior.PreferExisting); Assert.That(target, Contains.Substring("\\id MAT - Test\r\n")); Assert.That(target, Contains.Substring("\\v 6 Verse 6 content.\r\n")); Assert.That(target, Contains.Substring("\\v 7 Text 7\r\n")); @@ -57,7 +57,7 @@ public void GetUsfm_PreferRows() (ScrRef("MAT 1:6"), "Text 6"), (ScrRef("MAT 1:7"), "Text 7"), }; - string target = UpdateUsfm(rows, preferExistingText: false); + string target = UpdateUsfm(rows, behavior: UpdateUsfmBehavior.PreferNew); Assert.That(target, Contains.Substring("\\id MAT - Test\r\n")); Assert.That(target, Contains.Substring("\\v 6 Text 6\r\n")); Assert.That(target, Contains.Substring("\\v 7 Text 7\r\n")); @@ -438,30 +438,18 @@ private static string UpdateUsfm( IReadOnlyList<(IReadOnlyList, string)>? rows = null, string? source = null, string? idText = null, - bool stripAllText = false, - bool preferExistingText = false + UpdateUsfmBehavior behavior = UpdateUsfmBehavior.PreferNew ) { if (source is null) { var updater = new FileParatextProjectTextUpdater(CorporaTestHelpers.UsfmTestProjectPath); - return updater.UpdateUsfm( - "MAT", - rows, - fullName: idText, - stripAllText: stripAllText, - preferExistingText: preferExistingText - ); + return updater.UpdateUsfm("MAT", rows, idText, behavior); } else { source = source.Trim().ReplaceLineEndings("\r\n") + "\r\n"; - var updater = new UpdateUsfmParserHandler( - rows, - idText, - stripAllText: stripAllText, - preferExistingText: preferExistingText - ); + var updater = new UpdateUsfmParserHandler(rows, idText, behavior); UsfmParser.Parse(source, updater); return updater.GetUsfm(); } diff --git a/tests/SIL.Machine.Tests/Corpora/UsfmManualTests.cs b/tests/SIL.Machine.Tests/Corpora/UsfmManualTests.cs index 88773c85..b2dbdcf3 100644 --- a/tests/SIL.Machine.Tests/Corpora/UsfmManualTests.cs +++ b/tests/SIL.Machine.Tests/Corpora/UsfmManualTests.cs @@ -49,7 +49,7 @@ string sfmFileName in Directory string bookId; if (!targetSettings.IsBookFileName(sfmFileName, out bookId)) continue; - string newUsfm = updater.UpdateUsfm(bookId, pretranslations, stripAllText: true, preferExistingText: false); + string newUsfm = updater.UpdateUsfm(bookId, pretranslations, behavior: UpdateUsfmBehavior.StripExisting); Assert.That(newUsfm, Is.Not.Null); } } @@ -150,8 +150,7 @@ async Task GetUsfmAsync(string projectPath) string newUsfm = updater.UpdateUsfm( bookId, pretranslations, - stripAllText: true, - preferExistingText: true + behavior: UpdateUsfmBehavior.StripExisting ); Assert.That(newUsfm, Is.Not.Null); }