aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py
diff options
context:
space:
mode:
authormonster <monster@ydb.tech>2022-07-07 14:41:37 +0300
committermonster <monster@ydb.tech>2022-07-07 14:41:37 +0300
commit06e5c21a835c0e923506c4ff27929f34e00761c2 (patch)
tree75efcbc6854ef9bd476eb8bf00cc5c900da436a2 /contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py
parent03f024c4412e3aa613bb543cf1660176320ba8f4 (diff)
downloadydb-06e5c21a835c0e923506c4ff27929f34e00761c2.tar.gz
fix ya.make
Diffstat (limited to 'contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py')
-rw-r--r--contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py43
1 files changed, 0 insertions, 43 deletions
diff --git a/contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py b/contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py
deleted file mode 100644
index 6ef95224a6c..00000000000
--- a/contrib/python/prompt-toolkit/py3/prompt_toolkit/completion/deduplicate.py
+++ /dev/null
@@ -1,43 +0,0 @@
-from typing import Iterable, Set
-
-from prompt_toolkit.document import Document
-
-from .base import CompleteEvent, Completer, Completion
-
-__all__ = ["DeduplicateCompleter"]
-
-
-class DeduplicateCompleter(Completer):
- """
- Wrapper around a completer that removes duplicates. Only the first unique
- completions are kept.
-
- Completions are considered to be a duplicate if they result in the same
- document text when they would be applied.
- """
-
- def __init__(self, completer: Completer) -> None:
- self.completer = completer
-
- def get_completions(
- self, document: Document, complete_event: CompleteEvent
- ) -> Iterable[Completion]:
- # Keep track of the document strings we'd get after applying any completion.
- found_so_far: Set[str] = set()
-
- for completion in self.completer.get_completions(document, complete_event):
- text_if_applied = (
- document.text[: document.cursor_position + completion.start_position]
- + completion.text
- + document.text[document.cursor_position :]
- )
-
- if text_if_applied == document.text:
- # Don't include completions that don't have any effect at all.
- continue
-
- if text_if_applied in found_so_far:
- continue
-
- found_so_far.add(text_if_applied)
- yield completion