forked from intitni/CopilotForXcode
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUnknownLanguageFocusCodeFinder.swift
More file actions
85 lines (70 loc) · 3.01 KB
/
UnknownLanguageFocusCodeFinder.swift
File metadata and controls
85 lines (70 loc) · 3.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import Foundation
import Preferences
import SuggestionModel
/// Used when the language is not supported by the app
/// or that the code is too long to be returned by a focused code finder.
public struct UnknownLanguageFocusedCodeFinder: FocusedCodeFinderType {
let proposedSearchRange: Int
public init(proposedSearchRange: Int) {
self.proposedSearchRange = proposedSearchRange
}
public func findFocusedCode(
in document: Document,
containingRange: CursorRange
) -> CodeContext {
guard !document.lines.isEmpty else { return .empty }
// when user is not selecting any code.
if containingRange.start == containingRange.end {
// search up and down for up to `proposedSearchRange * 2 + 1` lines.
let lines = document.lines
let proposedLineCount = proposedSearchRange * 2 + 1
let startLineIndex = max(containingRange.start.line - proposedSearchRange, 0)
let endLineIndex = max(
startLineIndex,
min(startLineIndex + proposedLineCount - 1, lines.count - 1)
)
if lines.endIndex <= endLineIndex { return .empty }
let focusedLines = lines[startLineIndex...endLineIndex]
let contextStartLine = max(startLineIndex - 5, 0)
let contextEndLine = min(endLineIndex + 5, lines.count - 1)
let contextRange = CursorRange(
start: .init(line: contextStartLine, character: 0),
end: .init(line: contextEndLine, character: lines[contextEndLine].count)
)
return .init(
scope: .top,
contextRange: contextRange,
smallestContextRange: contextRange,
focusedRange: .init(
start: .init(line: startLineIndex, character: 0),
end: .init(line: endLineIndex, character: lines[endLineIndex].count)
),
focusedCode: focusedLines.joined(),
imports: [],
includes: []
)
}
let startLine = max(containingRange.start.line, 0)
let endLine = min(containingRange.end.line, document.lines.count - 1)
if endLine < startLine { return .empty }
let focusedLines = document.lines[startLine...endLine]
let contextStartLine = max(startLine - 3, 0)
let contextEndLine = min(endLine + 3, document.lines.count - 1)
let contextRange = CursorRange(
start: .init(line: contextStartLine, character: 0),
end: .init(
line: contextEndLine,
character: document.lines[contextEndLine].count
)
)
return CodeContext(
scope: .top,
contextRange: contextRange,
smallestContextRange: contextRange,
focusedRange: containingRange,
focusedCode: focusedLines.joined(),
imports: [],
includes: []
)
}
}