Skip to content

Commit

Permalink
Add command to show conflicts in current text
Browse files Browse the repository at this point in the history
  • Loading branch information
jtmaxwell3 committed May 2, 2024
1 parent c351ca8 commit bbe91be
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@
<command id="CmdParseWordsInCurrentText" label="Parse Words in Te_xt" message="ParseWordsInCurrentText"/>
<command id="CmdClearSelectedWordParserAnalyses" label="Clear Current Parser _Analyses" message="ClearSelectedWordParserAnalyses"/>
<command id="CmdReInitializeParser" label="Re_load Grammar / Lexicon" message="ReInitParser" tooltip="Reloads data from the Grammar and Lexicon, so the parser uses your latest changes."/>
<command id="CmdImportWordSet" label="_Import Word Set..." message="ImportWordSet"/>
<command id="CmdShowConflictsInCurrentText" label="Show Conflicts in Text" message="ShowConflictsInCurrentText" tooltip="Parses text and shows conflicts between user approval and parser approval."/>
<command id="CmdImportWordSet" label="_Import Word Set..." message="ImportWordSet"/>
<command id="CmdChooseXAmpleParser" label="Default Parser (XAmple)" message="ChooseParser">
<parameters parser="XAmple"/>
</command>
Expand Down Expand Up @@ -276,10 +277,11 @@
<item command="CmdChooseXAmpleParser"/>
<item command="CmdChooseHCParser"/>
</menu>
<item command="CmdEditParserParameters"/>
<item command="CmdShowConflictsInCurrentText"/>
<item command="CmdEditParserParameters"/>
</menu>
<include path="Extensions/*/AreaConfigurationExtension.xml" query="root/menubar/*"/>
</menubar>
</menubar>
<!-- ********************************************************** -->
<!-- ************************ menuAddOn *********************** -->
<!-- ********************************************************** -->
Expand Down
24 changes: 23 additions & 1 deletion Src/LexText/ParserCore/ParserScheduler.cs
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,7 @@ public override void DoWork()
private readonly int[] m_queueCounts = new int[5];
private volatile bool m_tryAWordDialogRunning;
private TaskReport m_TaskReport;
private Dictionary<IWfiWordform, bool> m_wordformProcessed = null;

/// -----------------------------------------------------------------------------------
/// <summary>
Expand Down Expand Up @@ -287,10 +288,20 @@ public void ScheduleOneWordformForUpdate(IWfiWordform wordform, ParserPriority p
m_thread.EnqueueWork(priority, new UpdateWordformWork(this, priority, wordform));
}

public void ScheduleWordformsForUpdate(IEnumerable<IWfiWordform> wordforms, ParserPriority priority)
public void ScheduleWordformsForUpdate(IEnumerable<IWfiWordform> wordforms, ParserPriority priority, bool showConflicts)
{
CheckDisposed();

m_wordformProcessed = null;
if (showConflicts)
{
// Keep track of which wordforms have been processed.
m_wordformProcessed = new Dictionary<IWfiWordform, bool>();
foreach (var wordform in wordforms)
{
m_wordformProcessed[wordform] = false;
}
}
foreach (var wordform in wordforms)
ScheduleOneWordformForUpdate(wordform, priority);
}
Expand All @@ -316,6 +327,17 @@ private void HandleTaskUpdate(TaskReport task)
private void ParseFiler_WordformUpdated(object sender, WordformUpdatedEventArgs e)
{
DecrementQueueCount(e.Priority);
if (m_wordformProcessed != null && m_wordformProcessed.ContainsKey(e.Wordform))
{
m_wordformProcessed[e.Wordform] = true;
// See if we are done.
foreach (var key in m_wordformProcessed.Keys)
{
if (!m_wordformProcessed[key])
return;
}
// Display the wordforms in the Wordforms window.
}
}

/// <summary>
Expand Down
4 changes: 2 additions & 2 deletions Src/LexText/ParserUI/ParserConnection.cs
Original file line number Diff line number Diff line change
Expand Up @@ -96,10 +96,10 @@ public IAsyncResult BeginTryAWord(string sForm, bool fDoTrace, int[] sSelectTrac
return this;
}

public void UpdateWordforms(IEnumerable<IWfiWordform> wordforms, ParserPriority priority)
public void UpdateWordforms(IEnumerable<IWfiWordform> wordforms, ParserPriority priority, bool showConflicts = false)
{
CheckDisposed();
m_scheduler.ScheduleWordformsForUpdate(wordforms, priority);
m_scheduler.ScheduleWordformsForUpdate(wordforms, priority, showConflicts);
}

public void UpdateWordform(IWfiWordform wordform, ParserPriority priority)
Expand Down
7 changes: 4 additions & 3 deletions Src/LexText/ParserUI/ParserListener.cs
Original file line number Diff line number Diff line change
Expand Up @@ -481,19 +481,20 @@ public bool OnDisplayParseWordsInCurrentText(object commandObject, ref UIItemDis
return true; //we handled this.
}

public bool OnParseWordsInCurrentText(object argument)
public bool OnShowConflictsInCurrentText(object argument)
{
CheckDisposed();

if (ConnectToParser())
{
IStText text = CurrentText;
IEnumerable<IWfiWordform> wordforms = text.UniqueWordforms();
m_parserConnection.UpdateWordforms(wordforms, ParserPriority.Medium);
m_parserConnection.UpdateWordforms(wordforms, ParserPriority.Medium, true);
}

return true; //we handled this.
return true; //we handled this.
}

public bool OnParseAllWords(object argument)
{
CheckDisposed();
Expand Down

0 comments on commit bbe91be

Please sign in to comment.