v++
Учет настроек сравнения при сравнении пакетов сапфор
This commit is contained in:
@@ -9,7 +9,6 @@ import Common.UI.Menus_2023.VisualiserMenuBar;
|
||||
import Common.UI.UI;
|
||||
import Common.Utils.TextLog;
|
||||
import Common.Utils.Utils;
|
||||
import GlobalData.Settings.SettingName;
|
||||
import Visual_DVM_2021.Passes.Pass_2021;
|
||||
import javafx.util.Pair;
|
||||
import org.fife.ui.rsyntaxtextarea.RSyntaxTextAreaHighlighter;
|
||||
@@ -91,104 +90,13 @@ public abstract class ComparisonForm<T> {
|
||||
private void ShowCurrentDiff() {
|
||||
Body.gotoLine_(colors.get(current_diff_line).getKey());
|
||||
}
|
||||
public static boolean CompareLines(String line1_raw, String line2_raw) {
|
||||
String line1 = line1_raw;
|
||||
String line2 = line2_raw;
|
||||
if (!Global.db.settings.get(SettingName.RegisterOn).toBoolean()) {
|
||||
line1 = line1.toUpperCase();
|
||||
line2 = line2.toUpperCase();
|
||||
}
|
||||
if (!Global.db.settings.get(SettingName.SpacesOn).toBoolean()) {
|
||||
line1 = Utils.remove(line1, " ", "\t");
|
||||
line2 = Utils.remove(line2, " ", "\t");
|
||||
}
|
||||
return line1.equals(line2);
|
||||
}
|
||||
public static boolean Contains(Vector<String> list, String line, int max_index) {
|
||||
int last_index = -1;
|
||||
for (int i = 0; i < list.size(); ++i)
|
||||
if (CompareLines(list.get(i), line)) last_index = i;
|
||||
return (last_index >= max_index);
|
||||
}
|
||||
private void getLines() {
|
||||
lines.clear();
|
||||
visible_lines.clear();
|
||||
//1.прочитать весь текст.
|
||||
char[] chars = getText().toCharArray();
|
||||
//по символам получить строки.
|
||||
char c = 0; //текущий символ
|
||||
int i = 0; //индекс текущего символа.
|
||||
StringBuilder line = new StringBuilder(); //текущая строка
|
||||
StringBuilder v_line = new StringBuilder(); //текущая строка
|
||||
while (i < chars.length) {
|
||||
c = chars[i];
|
||||
//System.out.print("`"+c+"`");
|
||||
++i;
|
||||
switch (c) {
|
||||
case '\r': //возврат каретки, игнор
|
||||
break;
|
||||
case ' ':
|
||||
case '\t':
|
||||
if (Global.db.settings.get(SettingName.SpacesOn).toBoolean()) line.append(c);
|
||||
v_line.append(c);
|
||||
break;
|
||||
case '\n': //конец строки
|
||||
if (fortranWrapsOn()) {
|
||||
//оракул. лезем в начало следующей строки
|
||||
//и анализируем первые 5 символов
|
||||
boolean hasWrap = false;
|
||||
int wi;
|
||||
//------
|
||||
//System.out.println("checking wrap...");
|
||||
//с нуля потому что и уже увеличено.
|
||||
for (int j = 0; (j < 6) && ((wi = i + j) < chars.length); ++j) {
|
||||
char s = chars[wi];
|
||||
// System.out.print(s);
|
||||
if ((j == 0) && ((s == 'c') || (s == 'C') || (s == '!'))) {
|
||||
// System.out.println("next line is FL comment");
|
||||
break;
|
||||
}
|
||||
if ((j > 0) && (j < 5) && (s == '!')) {
|
||||
// System.out.println("next line is comment");
|
||||
break;
|
||||
}
|
||||
if ((j == 5) && (s != ' ')) {
|
||||
hasWrap = true;
|
||||
i = wi + 1;
|
||||
// System.out.println("next line is WRAP");
|
||||
break;
|
||||
}
|
||||
}
|
||||
// System.out.println();
|
||||
//-----
|
||||
if (hasWrap)
|
||||
break;
|
||||
}
|
||||
// System.out.println();
|
||||
//добавление строки в результат.
|
||||
if ((line.length() > 0) || Global.db.settings.get(SettingName.EmptyLinesOn).toBoolean() &&
|
||||
Global.db.settings.get(SettingName.SpacesOn).toBoolean()) {
|
||||
lines.add(line.toString());
|
||||
visible_lines.add(v_line.toString());
|
||||
}
|
||||
//сброс
|
||||
line = new StringBuilder();
|
||||
v_line = new StringBuilder();
|
||||
break;
|
||||
default:
|
||||
line.append(c);
|
||||
v_line.append(c);
|
||||
break;
|
||||
}
|
||||
}
|
||||
if ((i > 0) && (c != '\n')) {
|
||||
//строка оборвалась на EOF
|
||||
//добавление строки в результат.
|
||||
if ((line.length() > 0) || Global.db.settings.get(SettingName.EmptyLinesOn).toBoolean() && Global.db.settings.get(SettingName.SpacesOn).toBoolean()) {
|
||||
lines.add(line.toString());
|
||||
visible_lines.add(v_line.toString());
|
||||
}
|
||||
}
|
||||
//--
|
||||
Pair<Vector<String>, Vector<String>> p = Utils.getFortranLines(getText());
|
||||
lines = p.getKey();
|
||||
visible_lines = p.getValue();
|
||||
}
|
||||
protected void ClearText() {
|
||||
events_on = false;
|
||||
@@ -212,10 +120,10 @@ public abstract class ComparisonForm<T> {
|
||||
int old_j = 0;
|
||||
int j = 0;
|
||||
for (int i = 0; i < lines.size(); ++i) {
|
||||
if (Contains(slave.lines, lines.get(i), old_j)) {
|
||||
if (Utils.Contains(slave.lines, lines.get(i), old_j)) {
|
||||
for (int k = old_j; k < slave.lines.size(); ++k) {
|
||||
j = k;
|
||||
if (CompareLines(lines.get(i), slave.lines.get(k))) {
|
||||
if (Utils.CompareLines(lines.get(i), slave.lines.get(k))) {
|
||||
j++;
|
||||
t1.add(visible_lines.get(i));
|
||||
t2.add(slave.visible_lines.get(k));
|
||||
|
||||
Reference in New Issue
Block a user