I'm failing the last condition..
package com.codegym.task.task19.task1916;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
/*
Tracking changes
*/
public class Solution {
public static List<LineItem> lines = new ArrayList<>();
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String file1 = reader.readLine();
String file2 = reader.readLine();
reader.close();
BufferedReader file1Reader = new BufferedReader(new FileReader(file1));
BufferedReader file2Reader = new BufferedReader(new FileReader(file2));
ArrayList<String> file1List = new ArrayList<>();
ArrayList<String> file2List = new ArrayList<>();
String line;
while ((line = file1Reader.readLine()) != null) {
file1List.add(line);
}
file1Reader.close();
while ((line = file2Reader.readLine()) != null) {
file2List.add(line);
}
file2Reader.close();
ArrayList<String> mergedList = new ArrayList<>(file1List);
for (String s : file2List) {
if (!mergedList.contains(s)) {
mergedList.add(s);
}
}
TreeMap<String, Type> ordered = new TreeMap<String, Type>();
for (String s : mergedList) {
if (file1List.contains(s) && file2List.contains(s)) {
if (!ordered.containsKey(s)) {
ordered.put("SAME " + s, Type.SAME); }
}
if (file1List.contains(s) && !file2List.contains(s)) {
if (!ordered.containsKey(s)) {
ordered.put("REMOVED" + s, Type.REMOVED); }
}
if (!file1List.contains(s) && file2List.contains(s)) {
if (!ordered.containsKey(s)) {
ordered.put("ADDED" + s, Type.ADDED); }
}
}
for (Map.Entry<String, Type> entry : ordered.entrySet()) {
lines.add(new LineItem(entry.getValue(), entry.getKey()));
}
}
public static enum Type {
ADDED, // New line added
REMOVED, // Line deleted
SAME // No change
}
public static class LineItem {
public Type type;
public String line;
public LineItem(Type type, String line) {
this.type = type;
this.line = line;
}
}
}