Skip to content

Commit

Permalink
Fix #348. Исправлен расчет длины токена.
Browse files Browse the repository at this point in the history
Вместо String#length используется String#codepoints#count, позволяющий корректно обрабатывать длинные юникодные символы
  • Loading branch information
nixel2007 committed Dec 1, 2024
1 parent 5435c7f commit 07be91a
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -227,7 +227,7 @@ private void saveCpd(InputFile inputFile, DocumentContext documentContext) {
line,
charPositionInLine,
line,
charPositionInLine + tokenText.length(),
charPositionInLine + (int) tokenText.codePoints().count(),
tokenText
);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ public void highlightToken(
line,
charPositionInLine,
line,
charPositionInLine + tokenText.length()
charPositionInLine + (int) tokenText.codePoints().count()
);

var data = new HighlightingData(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ void testComplexity() {
// todo надо как-то нормально ключ компонента определить
var componentKey = "moduleKey:" + FILE_NAME;
assertThat(context.measures(componentKey)).isNotEmpty();
assertThat(context.measure(componentKey, CoreMetrics.COMPLEXITY).value()).isEqualTo(3);
assertThat(context.measure(componentKey, CoreMetrics.COMPLEXITY).value()).isEqualTo(5);
assertThat(context.measure(componentKey, CoreMetrics.COGNITIVE_COMPLEXITY).value()).isEqualTo(1);

}
Expand All @@ -225,7 +225,7 @@ void testCPD() {
var componentKey = "moduleKey:" + FILE_NAME;
assertThat(context.cpdTokens(componentKey))
.isNotNull()
.hasSize(13);
.hasSize(19);
assertThat(context.cpdTokens(componentKey))
.filteredOn(tok -> tok.getValue().startsWith("ОставшийсяТокен"))
.hasSize(1);
Expand Down
8 changes: 8 additions & 0 deletions src/test/resources/examples/src/test.bsl
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,14 @@
#КонецВставки
КонецПроцедуры

Функция ФункцияКотораяДолжнаНеУпасть()
Возврат "🟡";
КонецФункции

Функция ФункцияКотораяНеУпадет()
Возврат "✅";
КонецФункции

#Область Тест

Проверка = Истина;
Expand Down

0 comments on commit 07be91a

Please sign in to comment.