mirror of
https://github.com/Palm1r/QodeAssist.git
synced 2025-06-04 01:28:58 -04:00
fix: Properly omit copyright information (#103)
This commit ensures that copyright information is always excluded and that context is always split into prefix and suffix at correct position.
This commit is contained in:
parent
8a167bf248
commit
61ca5c9a1b
@ -84,18 +84,22 @@ QString DocumentContextReader::getLineText(int lineNumber, int cursorPosition) c
|
|||||||
QString DocumentContextReader::getContextBefore(
|
QString DocumentContextReader::getContextBefore(
|
||||||
int lineNumber, int cursorPosition, int linesCount) const
|
int lineNumber, int cursorPosition, int linesCount) const
|
||||||
{
|
{
|
||||||
int effectiveStartLine = qMax(0, lineNumber - linesCount + 1);
|
int startLine = lineNumber - linesCount + 1;
|
||||||
if (m_copyrightInfo.found) {
|
if (m_copyrightInfo.found) {
|
||||||
effectiveStartLine = qMax(m_copyrightInfo.endLine + 1, effectiveStartLine);
|
startLine = qMax(m_copyrightInfo.endLine + 1, startLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
return getContextBetween(effectiveStartLine, -1, lineNumber, cursorPosition);
|
return getContextBetween(startLine, -1, lineNumber, cursorPosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString DocumentContextReader::getContextAfter(
|
QString DocumentContextReader::getContextAfter(
|
||||||
int lineNumber, int cursorPosition, int linesCount) const
|
int lineNumber, int cursorPosition, int linesCount) const
|
||||||
{
|
{
|
||||||
int endLine = qMin(m_document->blockCount() - 1, lineNumber + linesCount - 1);
|
int endLine = lineNumber + linesCount - 1;
|
||||||
|
if (m_copyrightInfo.found && m_copyrightInfo.endLine >= lineNumber) {
|
||||||
|
lineNumber = m_copyrightInfo.endLine + 1;
|
||||||
|
cursorPosition = -1;
|
||||||
|
}
|
||||||
return getContextBetween(lineNumber, cursorPosition, endLine, -1);
|
return getContextBetween(lineNumber, cursorPosition, endLine, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,14 +110,17 @@ QString DocumentContextReader::readWholeFileBefore(int lineNumber, int cursorPos
|
|||||||
startLine = m_copyrightInfo.endLine + 1;
|
startLine = m_copyrightInfo.endLine + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
startLine = qMin(startLine, lineNumber);
|
|
||||||
|
|
||||||
return getContextBetween(startLine, -1, lineNumber, cursorPosition);
|
return getContextBetween(startLine, -1, lineNumber, cursorPosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString DocumentContextReader::readWholeFileAfter(int lineNumber, int cursorPosition) const
|
QString DocumentContextReader::readWholeFileAfter(int lineNumber, int cursorPosition) const
|
||||||
{
|
{
|
||||||
return getContextBetween(lineNumber, cursorPosition, m_document->blockCount() - 1, -1);
|
int endLine = m_document->blockCount() - 1;
|
||||||
|
if (m_copyrightInfo.found && m_copyrightInfo.endLine >= lineNumber) {
|
||||||
|
lineNumber = m_copyrightInfo.endLine + 1;
|
||||||
|
cursorPosition = -1;
|
||||||
|
}
|
||||||
|
return getContextBetween(lineNumber, cursorPosition, endLine, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString DocumentContextReader::getLanguageAndFileInfo() const
|
QString DocumentContextReader::getLanguageAndFileInfo() const
|
||||||
@ -173,6 +180,9 @@ QString DocumentContextReader::getContextBetween(
|
|||||||
{
|
{
|
||||||
QString context;
|
QString context;
|
||||||
|
|
||||||
|
startLine = qMax(startLine, 0);
|
||||||
|
endLine = qMin(endLine, m_document->blockCount() - 1);
|
||||||
|
|
||||||
if (startLine > endLine) {
|
if (startLine > endLine) {
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
|
@ -81,6 +81,11 @@ private:
|
|||||||
QTextDocument *m_document;
|
QTextDocument *m_document;
|
||||||
QString m_mimeType;
|
QString m_mimeType;
|
||||||
QString m_filePath;
|
QString m_filePath;
|
||||||
|
|
||||||
|
// Used to omit copyright headers from context. If context would otherwise include copyright
|
||||||
|
// header it is excluded by deleting it from the returned context. This means, that the
|
||||||
|
// returned context may contain less information than requested. If the cursor is within copyright
|
||||||
|
// header, then the context may be empty if the context window is small.
|
||||||
CopyrightInfo m_copyrightInfo;
|
CopyrightInfo m_copyrightInfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ TEST_F(DocumentContextReaderTest, testGetContextWithCopyright)
|
|||||||
|
|
||||||
// Unknown cursor position
|
// Unknown cursor position
|
||||||
EXPECT_EQ(reader.getContextBefore(0, -1, 2), "");
|
EXPECT_EQ(reader.getContextBefore(0, -1, 2), "");
|
||||||
EXPECT_EQ(reader.getContextAfter(0, -1, 2), "/* Copyright (C) 2024 */\nLine 0");
|
EXPECT_EQ(reader.getContextAfter(0, -1, 2), "Line 0");
|
||||||
|
|
||||||
EXPECT_EQ(reader.getContextBefore(1, -1, 2), "Line 0");
|
EXPECT_EQ(reader.getContextBefore(1, -1, 2), "Line 0");
|
||||||
EXPECT_EQ(reader.getContextAfter(1, -1, 2), "Line 0\nLine 1");
|
EXPECT_EQ(reader.getContextAfter(1, -1, 2), "Line 0\nLine 1");
|
||||||
@ -179,7 +179,7 @@ TEST_F(DocumentContextReaderTest, testGetContextWithCopyright)
|
|||||||
|
|
||||||
// Known cursor position
|
// Known cursor position
|
||||||
EXPECT_EQ(reader.getContextBefore(0, 1, 2), "");
|
EXPECT_EQ(reader.getContextBefore(0, 1, 2), "");
|
||||||
EXPECT_EQ(reader.getContextAfter(0, 1, 2), "* Copyright (C) 2024 */\nLine 0");
|
EXPECT_EQ(reader.getContextAfter(0, 1, 2), "Line 0");
|
||||||
|
|
||||||
EXPECT_EQ(reader.getContextBefore(1, 1, 2), "L");
|
EXPECT_EQ(reader.getContextBefore(1, 1, 2), "L");
|
||||||
EXPECT_EQ(reader.getContextAfter(1, 1, 2), "ine 0\nLine 1");
|
EXPECT_EQ(reader.getContextAfter(1, 1, 2), "ine 0\nLine 1");
|
||||||
@ -232,10 +232,8 @@ TEST_F(DocumentContextReaderTest, testReadWholeFileWithCopyright)
|
|||||||
{
|
{
|
||||||
auto reader = createTestReader("/* Copyright (C) 2024 */\nLine 0\nLine 1\nLine 2\nLine 3");
|
auto reader = createTestReader("/* Copyright (C) 2024 */\nLine 0\nLine 1\nLine 2\nLine 3");
|
||||||
// Unknown cursor position
|
// Unknown cursor position
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, -1), "/* Copyright (C) 2024 */");
|
EXPECT_EQ(reader.readWholeFileBefore(0, -1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(0, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, -1),
|
|
||||||
"/* Copyright (C) 2024 */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, -1), "Line 0");
|
EXPECT_EQ(reader.readWholeFileBefore(1, -1), "Line 0");
|
||||||
EXPECT_EQ(reader.readWholeFileAfter(1, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileAfter(1, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
@ -248,8 +246,7 @@ TEST_F(DocumentContextReaderTest, testReadWholeFileWithCopyright)
|
|||||||
|
|
||||||
// Known cursor position
|
// Known cursor position
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(0, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(0, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, 0), "/* Copyright (C) 2024 */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(1, 0), "");
|
||||||
EXPECT_EQ(reader.readWholeFileAfter(1, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileAfter(1, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
@ -260,9 +257,8 @@ TEST_F(DocumentContextReaderTest, testReadWholeFileWithCopyright)
|
|||||||
EXPECT_EQ(reader.readWholeFileBefore(3, 0), "Line 0\nLine 1\n");
|
EXPECT_EQ(reader.readWholeFileBefore(3, 0), "Line 0\nLine 1\n");
|
||||||
EXPECT_EQ(reader.readWholeFileAfter(3, 0), "Line 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileAfter(3, 0), "Line 2\nLine 3");
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, 1), "/");
|
EXPECT_EQ(reader.readWholeFileBefore(0, 1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(0, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, 1), "* Copyright (C) 2024 */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, 1), "L");
|
EXPECT_EQ(reader.readWholeFileBefore(1, 1), "L");
|
||||||
EXPECT_EQ(reader.readWholeFileAfter(1, 1), "ine 0\nLine 1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileAfter(1, 1), "ine 0\nLine 1\nLine 2\nLine 3");
|
||||||
@ -281,72 +277,87 @@ TEST_F(DocumentContextReaderTest, testReadWholeFileWithMultilineCopyright)
|
|||||||
"Line 0\nLine 1\nLine 2\nLine 3");
|
"Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
// Unknown cursor position
|
// Unknown cursor position
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, -1), "/*");
|
EXPECT_EQ(reader.readWholeFileBefore(0, -1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(0, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, -1),
|
|
||||||
"/*\n * Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine "
|
|
||||||
"1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, -1), " * Copyright (C) 2024");
|
EXPECT_EQ(reader.readWholeFileBefore(1, -1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(1, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(1, -1),
|
|
||||||
" * Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine "
|
|
||||||
"1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(2, -1), " * ");
|
EXPECT_EQ(reader.readWholeFileBefore(2, -1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(2, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(2, -1),
|
|
||||||
" * \n * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(3, -1), " * This file is part of QodeAssist.");
|
EXPECT_EQ(reader.readWholeFileBefore(3, -1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(3, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(3, -1),
|
|
||||||
" * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileBefore(4, -1), "");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(4, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(5, -1), "Line 0");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(5, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(6, -1), "Line 0\nLine 1");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(6, -1), "Line 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(7, -1), "Line 0\nLine 1\nLine 2");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(7, -1), "Line 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(8, -1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(8, -1), "Line 3");
|
||||||
|
|
||||||
// Known cursor position
|
// Known cursor position
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(0, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(0, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, 0),
|
|
||||||
"/*\n * Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine "
|
|
||||||
"1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(1, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(1, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(1, 0),
|
|
||||||
" * Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine "
|
|
||||||
"1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(2, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(2, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(2, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(2, 0),
|
|
||||||
" * \n * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(3, 0), "");
|
EXPECT_EQ(reader.readWholeFileBefore(3, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(3, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(3, 0),
|
|
||||||
" * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(0, 1), "/");
|
EXPECT_EQ(reader.readWholeFileBefore(4, 0), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(4, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(0, 1),
|
|
||||||
"*\n * Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine "
|
EXPECT_EQ(reader.readWholeFileBefore(5, 0), "");
|
||||||
"1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileAfter(5, 0), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(6, 0), "Line 0\n");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(6, 0), "Line 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(7, 0), "Line 0\nLine 1\n");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(7, 0), "Line 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(8, 0), "Line 0\nLine 1\nLine 2\n");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(8, 0), "Line 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(0, 1), "");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(0, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(1, 1), "");
|
EXPECT_EQ(reader.readWholeFileBefore(1, 1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(1, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(1, 1),
|
|
||||||
"* Copyright (C) 2024\n * \n * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine "
|
|
||||||
"2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(2, 1), "");
|
EXPECT_EQ(reader.readWholeFileBefore(2, 1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(2, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(2, 1),
|
|
||||||
"* \n * This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
|
||||||
|
|
||||||
EXPECT_EQ(reader.readWholeFileBefore(3, 1), "");
|
EXPECT_EQ(reader.readWholeFileBefore(3, 1), "");
|
||||||
EXPECT_EQ(
|
EXPECT_EQ(reader.readWholeFileAfter(3, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
reader.readWholeFileAfter(3, 1),
|
|
||||||
"* This file is part of QodeAssist.\n */\nLine 0\nLine 1\nLine 2\nLine 3");
|
EXPECT_EQ(reader.readWholeFileBefore(4, 1), "");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(4, 1), "Line 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(5, 1), "L");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(5, 1), "ine 0\nLine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(6, 1), "Line 0\nL");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(6, 1), "ine 1\nLine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(7, 1), "Line 0\nLine 1\nL");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(7, 1), "ine 2\nLine 3");
|
||||||
|
|
||||||
|
EXPECT_EQ(reader.readWholeFileBefore(8, 1), "Line 0\nLine 1\nLine 2\nL");
|
||||||
|
EXPECT_EQ(reader.readWholeFileAfter(8, 1), "ine 3");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(DocumentContextReaderTest, testFindCopyrightSingleLine)
|
TEST_F(DocumentContextReaderTest, testFindCopyrightSingleLine)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user