Flow.Launcher/Flow.Launcher.Plugin/Query.cs

115 lines
4.1 KiB
C#
Raw Permalink Normal View History

2023-04-25 12:04:08 +00:00
using System;
using System.Collections.Generic;
2015-10-31 16:02:56 +00:00
using System.Linq;
2022-09-01 02:34:47 +00:00
using System.Text.Json.Serialization;
2013-12-19 15:51:20 +00:00
2020-04-21 09:12:17 +00:00
namespace Flow.Launcher.Plugin
2013-12-19 15:51:20 +00:00
{
public class Query
{
2020-03-02 01:22:26 +00:00
public Query() { }
2019-10-17 09:19:52 +00:00
[Obsolete("Use the default Query constructor.")]
public Query(string rawQuery, string search, string[] terms, string[] searchTerms, string actionKeyword = "")
2019-10-17 09:19:52 +00:00
{
Search = search;
RawQuery = rawQuery;
SearchTerms = searchTerms;
2019-10-17 09:19:52 +00:00
ActionKeyword = actionKeyword;
}
/// <summary>
/// Raw query, this includes action keyword if it has
/// We didn't recommend use this property directly. You should always use Search property.
/// </summary>
public string RawQuery { get; internal init; }
/// <summary>
/// Determines whether the query was forced to execute again.
/// For example, the value will be true when the user presses Ctrl + R.
/// When this property is true, plugins handling this query should avoid serving cached results.
/// </summary>
public bool IsReQuery { get; internal set; } = false;
/// <summary>
/// Search part of a query.
2015-02-06 10:13:22 +00:00
/// This will not include action keyword if exclusive plugin gets it, otherwise it should be same as RawQuery.
2023-06-18 19:29:40 +00:00
/// Since we allow user to switch a exclusive plugin to generic plugin,
2015-10-31 16:02:56 +00:00
/// so this property will always give you the "real" query part of the query
/// </summary>
public string Search { get; internal init; }
2015-10-31 16:02:56 +00:00
/// <summary>
/// The search string split into a string array.
2023-06-18 19:29:40 +00:00
/// Does not include the <see cref="ActionKeyword"/>.
2015-10-31 16:02:56 +00:00
/// </summary>
public string[] SearchTerms { get; init; }
2021-09-21 02:51:07 +00:00
/// <summary>
/// Query can be splited into multiple terms by whitespace
/// </summary>
public const string TermSeparator = " ";
/// <summary>
/// User can set multiple action keywords seperated by ';'
/// </summary>
public const string ActionKeywordSeparator = ";";
2021-09-21 02:51:07 +00:00
2015-10-31 16:02:56 +00:00
2015-11-02 00:09:42 +00:00
/// <summary>
2023-06-18 19:29:40 +00:00
/// Wildcard action keyword. Plugins using this value will be queried on every search.
2015-11-02 00:09:42 +00:00
/// </summary>
public const string GlobalPluginWildcardSign = "*";
2015-11-02 00:09:42 +00:00
2023-06-18 19:29:40 +00:00
/// <summary>
/// The action keyword part of this query.
/// For global plugins this value will be empty.
/// </summary>
public string ActionKeyword { get; init; }
2022-09-01 02:34:47 +00:00
[JsonIgnore]
/// <summary>
2023-06-18 19:29:40 +00:00
/// Splits <see cref="SearchTerms"/> by spaces and returns the first item.
/// </summary>
2023-06-18 19:29:40 +00:00
/// <remarks>
/// returns an empty string when <see cref="SearchTerms"/> does not have enough items.
/// </remarks>
2015-10-31 16:02:56 +00:00
public string FirstSearch => SplitSearch(0);
2022-09-01 02:34:47 +00:00
[JsonIgnore]
private string _secondToEndSearch;
2022-09-01 02:34:47 +00:00
/// <summary>
/// strings from second search (including) to last search
/// </summary>
2022-09-01 02:34:47 +00:00
[JsonIgnore]
public string SecondToEndSearch => SearchTerms.Length > 1 ? (_secondToEndSearch ??= string.Join(' ', SearchTerms[1..])) : "";
/// <summary>
2023-06-18 19:29:40 +00:00
/// Splits <see cref="SearchTerms"/> by spaces and returns the second item.
/// </summary>
2023-06-18 19:29:40 +00:00
/// <remarks>
/// returns an empty string when <see cref="SearchTerms"/> does not have enough items.
/// </remarks>
2022-09-01 02:34:47 +00:00
[JsonIgnore]
2015-10-31 16:02:56 +00:00
public string SecondSearch => SplitSearch(1);
/// <summary>
2023-06-18 19:29:40 +00:00
/// Splits <see cref="SearchTerms"/> by spaces and returns the third item.
/// </summary>
2023-06-18 19:29:40 +00:00
/// <remarks>
/// returns an empty string when <see cref="SearchTerms"/> does not have enough items.
/// </remarks>
2022-09-01 02:34:47 +00:00
[JsonIgnore]
2015-10-31 16:02:56 +00:00
public string ThirdSearch => SplitSearch(2);
private string SplitSearch(int index)
{
return index < SearchTerms.Length ? SearchTerms[index] : string.Empty;
}
2023-06-18 19:29:40 +00:00
/// <inheritdoc />
2015-10-31 16:02:56 +00:00
public override string ToString() => RawQuery;
2013-12-19 15:51:20 +00:00
}
}