AnsiEscapeSequenceRequests.cs 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #nullable enable
  2. using System.Collections.Concurrent;
  3. namespace Terminal.Gui;
  4. /// <summary>
  5. /// Manages ANSI Escape Sequence requests and responses. The list of <see cref="AnsiEscapeSequenceRequestStatus"/>
  6. /// contains the
  7. /// status of the request. Each request is identified by the terminator (e.g. ESC[8t ... t is the terminator).
  8. /// </summary>
  9. public static class AnsiEscapeSequenceRequests
  10. {
  11. /// <summary>
  12. /// Adds a new request for the ANSI Escape Sequence defined by <paramref name="ansiRequest"/>. Adds a
  13. /// <see cref="AnsiEscapeSequenceRequestStatus"/> instance to <see cref="Statuses"/> list.
  14. /// </summary>
  15. /// <param name="ansiRequest">The <see cref="AnsiEscapeSequenceRequest"/> object.</param>
  16. public static void Add (AnsiEscapeSequenceRequest ansiRequest)
  17. {
  18. lock (ansiRequest._responseLock)
  19. {
  20. Statuses.Enqueue (new (ansiRequest));
  21. }
  22. System.Diagnostics.Debug.Assert (Statuses.Count > 0);
  23. }
  24. /// <summary>
  25. /// Clear the <see cref="Statuses"/> property.
  26. /// </summary>
  27. public static void Clear ()
  28. {
  29. lock (Statuses)
  30. {
  31. Statuses.Clear ();
  32. }
  33. }
  34. /// <summary>
  35. /// Indicates if a <see cref="AnsiEscapeSequenceRequestStatus"/> with the <paramref name="terminator"/> exists in the
  36. /// <see cref="Statuses"/> list.
  37. /// </summary>
  38. /// <param name="terminator"></param>
  39. /// <param name="seqReqStatus"></param>
  40. /// <returns><see langword="true"/> if exist, <see langword="false"/> otherwise.</returns>
  41. public static bool HasResponse (string terminator, out AnsiEscapeSequenceRequestStatus? seqReqStatus)
  42. {
  43. lock (Statuses)
  44. {
  45. Statuses.TryPeek (out seqReqStatus);
  46. return seqReqStatus?.AnsiRequest.Terminator == terminator;
  47. }
  48. }
  49. /// <summary>
  50. /// Removes a request defined by <paramref name="seqReqStatus"/>. If a matching
  51. /// <see cref="AnsiEscapeSequenceRequestStatus"/> is
  52. /// found and the number of outstanding requests is greater than 0, the number of outstanding requests is decremented.
  53. /// If the number of outstanding requests is 0, the <see cref="AnsiEscapeSequenceRequestStatus"/> is removed from
  54. /// <see cref="Statuses"/>.
  55. /// </summary>
  56. /// <param name="seqReqStatus">The <see cref="AnsiEscapeSequenceRequestStatus"/> object.</param>
  57. public static void Remove (AnsiEscapeSequenceRequestStatus? seqReqStatus)
  58. {
  59. lock (Statuses)
  60. {
  61. Statuses.TryDequeue (out AnsiEscapeSequenceRequestStatus? request);
  62. if (request != seqReqStatus)
  63. {
  64. throw new InvalidOperationException ("Both EscSeqReqStatus objects aren't equals.");
  65. }
  66. }
  67. }
  68. /// <summary>Gets the <see cref="AnsiEscapeSequenceRequestStatus"/> list.</summary>
  69. public static ConcurrentQueue<AnsiEscapeSequenceRequestStatus> Statuses { get; } = new ();
  70. }