diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/.~lock.mp5-binary-files-1.odt# b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/.~lock.mp5-binary-files-1.odt#
deleted file mode 100644
index dfab56d..0000000
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/.~lock.mp5-binary-files-1.odt#
+++ /dev/null
@@ -1 +0,0 @@
-,caleb,caleb-gaming-laptop-archlinux,20.10.2023 21:26,file:///home/caleb/.config/libreoffice/4;
\ No newline at end of file
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Exercise17_01.txt b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Exercise17_01.txt
new file mode 100644
index 0000000..8cfb7e4
Binary files /dev/null and b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Exercise17_01.txt differ
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/AddressBookFX.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/AddressBookFX.html
new file mode 100644
index 0000000..2a835f7
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/AddressBookFX.html
@@ -0,0 +1,286 @@
+
+
+
+AddressBookFX.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/AddressBookFX.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.ObjectInputStream;
+import java.io.ObjectOutputStream;
+import java.io.Serializable;
+import java.util.ArrayList;
+import javafx.application.Application;
+
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.Button;
+import javafx.scene.control.Label;
+import javafx.scene.control.TextField;
+import javafx.scene.layout.ColumnConstraints;
+import javafx.scene.layout.GridPane;
+import javafx.scene.layout.BorderPane;
+
+import javafx.stage.Stage;
+
+
+
+
+
+public class AddressBookFX extends Application {
+
+ static File addressBook = new File("AddressBookFX.dat");
+ static int addressArrayPointer = 0;
+ static ArrayList<AddressBookEntry> addressArray = new ArrayList<>();
+ static TextField nameTextField = new TextField();
+ static TextField streetTextField = new TextField();
+ static TextField cityTextField = new TextField();
+ static TextField stateTextField = new TextField();
+ static TextField zipTextField = new TextField();
+ static Label addressBookCounter = new Label("Items in address book:");
+ static Label indexLabel = new Label();
+
+ @Override
+ public void start(Stage stage) throws Exception
+ {
+ getData();
+ BorderPane primaryBorderPane = new BorderPane();
+ GridPane textFieldGridPane = new GridPane();
+ GridPane addressFieldPane = new GridPane();
+ GridPane buttonFieldPane = new GridPane();
+
+
+ textFieldGridPane.add(new Label("Name"), 0, 0);
+ textFieldGridPane.add(new Label("Street"), 0, 1);
+ textFieldGridPane.add(new Label("City"), 0, 2);
+ addressFieldPane.add(new Label("State"), 2, 0);
+ addressFieldPane.add(new Label("ZIP"), 4, 0);
+ textFieldGridPane.add(nameTextField, 1, 0);
+ textFieldGridPane.add(streetTextField, 1, 1);
+ textFieldGridPane.add(addressFieldPane, 1, 2);
+ addressFieldPane.add(cityTextField, 1, 0);
+ addressFieldPane.add(stateTextField, 3, 0);
+ addressFieldPane.add(zipTextField, 5, 0);
+ textFieldGridPane.getColumnConstraints().add(new ColumnConstraints(50));
+ primaryBorderPane.setTop(textFieldGridPane);
+
+
+ Button addButton = new Button("Add");
+ Button firstButton = new Button("First");
+ Button nextButton = new Button("Next");
+ Button previousButton = new Button("Previous");
+ Button lastButton = new Button("Last");
+ Button updateButton = new Button("Update");
+ buttonFieldPane.add(indexLabel, 0, 0);
+ buttonFieldPane.add(addButton, 1, 0);
+ buttonFieldPane.add(firstButton, 2, 0);
+ buttonFieldPane.add(nextButton, 3, 0);
+ buttonFieldPane.add(previousButton, 4, 0);
+ buttonFieldPane.add(lastButton, 5, 0);
+ buttonFieldPane.add(updateButton, 6, 0);
+ buttonFieldPane.add(addressBookCounter, 7, 0);
+
+ primaryBorderPane.setBottom(buttonFieldPane);
+ buttonFieldPane.setAlignment(Pos.CENTER);
+ buttonFieldPane.setHgap(10);
+
+ addButton.setOnAction(e -> {
+ addressArray.add(new AddressBookEntry());
+ updateData();
+ });
+ firstButton.setOnAction(e -> {
+ addressArrayPointer = 0;
+ getEntry(addressArrayPointer);
+ });
+ nextButton.setOnAction(e -> {
+ if (addressArrayPointer >= addressArray.size() - 1) {
+ addressArrayPointer = 0;
+ } else {
+ addressArrayPointer++;
+ }
+ getEntry(addressArrayPointer);
+ });
+ previousButton.setOnAction(e -> {
+ if (addressArrayPointer > 0) {
+ addressArrayPointer--;
+ } else {
+ addressArrayPointer = addressArray.size() - 1;
+ }
+ getEntry(addressArrayPointer);
+ });
+ lastButton.setOnAction(e -> {
+ addressArrayPointer = addressArray.size() - 1;
+ getEntry(addressArrayPointer);
+ });
+ updateButton.setOnAction(e -> {
+ AddressBookEntry entry = addressArray.get(addressArrayPointer);
+ entry.setName(nameTextField.getText());
+ entry.setCity(nameTextField.getText());
+ entry.setStreet(streetTextField.getText());
+ entry.setCity(cityTextField.getText());
+ entry.setState(stateTextField.getText());
+ entry.setZip(zipTextField.getText());
+ updateData();
+ });
+
+
+ getEntry(0);
+
+ Scene scene = new Scene(primaryBorderPane);
+ stage.setScene(scene);
+ stage.show();
+ }
+
+ public static AddressBookEntry getEntry(int index)
+ {
+ AddressBookEntry entry = addressArray.get(index);
+ indexLabel.setText("Current index: " + index);
+ addressBookCounter.setText("Items in address book: " + addressArray.size());
+ nameTextField.setText(entry.getName());
+ streetTextField.setText(entry.getStreet());
+ cityTextField.setText(entry.getCity());
+ stateTextField.setText(entry.getState());
+ zipTextField.setText(entry.getZip());
+ return entry;
+ }
+
+ public static void updateData()
+ {
+ try (ObjectOutputStream fileStream = new ObjectOutputStream(new FileOutputStream(addressBook))) {
+ fileStream.writeObject(addressArray);
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ }
+
+ public static void getData()
+ {
+ if (!addressBook.exists()) {
+ addressArray.add(new AddressBookEntry());
+ updateData();
+ } else {
+ try (ObjectInputStream fileStream = new ObjectInputStream(new FileInputStream(addressBook))) {
+ addressArray = (ArrayList<AddressBookEntry>) fileStream.readObject();
+ } catch (IOException ex) {
+ System.out.println(ex);
+ } catch (ClassNotFoundException ex) {
+ System.out.println(ex);
+ }
+ }
+ }
+
+ public static void main(String[] args)
+ {
+ launch();
+ }
+}
+
+class AddressBookEntry implements Serializable {
+
+ private String name;
+ private String street;
+ private String city;
+ private String state;
+ private String zip;
+
+ public AddressBookEntry()
+ {
+ this.name = "Enter a name here.";
+ this.street = "Enter a street here.";
+ this.city = "Enter a city here.";
+ this.state = "Enter a state here.";
+ this.zip = "Enter a zip here.";
+ }
+
+ public AddressBookEntry(String name, String street, String city, String state, String zip)
+ {
+ this.name = name;
+ this.street = street;
+ this.city = city;
+ this.state = state;
+ this.zip = zip;
+ }
+
+ public String getZip()
+ {
+ return zip;
+ }
+
+ public void setZip(String zip)
+ {
+ this.zip = zip;
+ }
+
+ public String getState()
+ {
+ return state;
+ }
+
+ public void setState(String state)
+ {
+ this.state = state;
+ }
+
+ public String getCity()
+ {
+ return city;
+ }
+
+ public void setCity(String city)
+ {
+ this.city = city;
+ }
+
+ public String getStreet()
+ {
+ return street;
+ }
+
+ public void setStreet(String street)
+ {
+ this.street = street;
+ }
+
+ public String getName()
+ {
+ return name;
+ }
+
+ public void setName(String name)
+ {
+ this.name = name;
+ }
+
+}
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/CombineFilesFX.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/CombineFilesFX.html
new file mode 100644
index 0000000..b6afb2e
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/CombineFilesFX.html
@@ -0,0 +1,160 @@
+
+
+
+CombineFilesFX.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/CombineFilesFX.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.List;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import javafx.application.Application;
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.Alert;
+import javafx.scene.control.Alert.AlertType;
+import javafx.scene.control.Button;
+import javafx.scene.control.Label;
+
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.GridPane;
+import javafx.stage.FileChooser;
+import javafx.stage.Stage;
+
+
+
+
+
+public class CombineFilesFX extends Application {
+
+ static ArrayList<File> files = new ArrayList<File>();
+ final FileChooser fileChooser = new FileChooser();
+
+ @Override
+ public void start(final Stage stage) throws Exception {
+ fileChooser.setTitle("Open File to Split...");
+ BorderPane primaryBorderPane = new BorderPane();
+ GridPane textFieldGridPane = new GridPane();
+
+ Label infoLabel = new Label("Point me at the files that were output by SplitFilesFX.java.");
+ Label chooseFile = new Label("Choose files to combine: ");
+ Button openFilePicker = new Button("Choose...");
+ Button run = new Button("Start");
+ textFieldGridPane.add(chooseFile, 0, 0);
+ textFieldGridPane.add(openFilePicker, 1, 0);
+ primaryBorderPane.setAlignment(run, Pos.CENTER);
+
+ primaryBorderPane.setTop(infoLabel);
+ primaryBorderPane.setCenter(textFieldGridPane);
+ primaryBorderPane.setBottom(run);
+
+ openFilePicker.setOnAction(e -> {
+
+ files.addAll(fileChooser.showOpenMultipleDialog(openFilePicker.getScene().getWindow()));
+
+ Collections.sort(files, new Comparator<File>() {
+ public int compare(File o1, File o2) {
+ return extractInt(o1.getName()) - extractInt(o2.getName());
+ }
+
+ String findMatch(String s) {
+ Pattern findNum = Pattern.compile("\\d+$");
+ Matcher match = findNum.matcher(s);
+ while (match.find()) {
+ return match.group();
+ }
+ return "";
+ }
+
+ int extractInt(String s) {
+ String num = findMatch(s);
+ System.out.println(num);
+
+ return num.isEmpty() ? 0 : Integer.parseInt(num);
+ }
+ });
+ });
+
+ run.setOnAction(e -> {
+ if (files == null) {
+ e.consume();
+ }
+ combineFiles(files);
+ });
+
+ Scene scene = new Scene(primaryBorderPane);
+ stage.setScene(scene);
+ stage.show();
+ }
+
+ public static void combineFiles(List<File> filesToCombine) {
+ String outputPath = filesToCombine.get(0).getParent();
+ try (FileOutputStream dataOut = new FileOutputStream(outputPath + "/" + "reconstructed_" + filesToCombine.get(0).getName().substring(0, (filesToCombine.get(0).getName().length() - 2)))) {
+ System.out.println("Writing to " + outputPath + "/" + "reconstructed_" + filesToCombine.get(0).getName().substring(0, (filesToCombine.get(0).getName().length() - 2)));
+ for (File file : filesToCombine) {
+ try (FileInputStream dataIn = new FileInputStream(file)) {
+ System.out.println("Opening the source file " + file.getName() + "!");
+ byte[] buffer = new byte[4096];
+ int bytesRead = -1;
+
+ while ((bytesRead = dataIn.read(buffer)) != -1) {
+ dataOut.write(buffer, 0, bytesRead);
+ }
+ }
+ catch (IOException ex) {
+ System.out.println(ex);
+ }
+ }
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ Alert alert = new Alert(AlertType.INFORMATION);
+ alert.setTitle("Success!");
+ alert.setContentText("Successfully combined the files!");
+
+ alert.showAndWait();
+ }
+
+
+
+ public static void main(String[] args) {
+ launch();
+ }
+}
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_01.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_01.html
new file mode 100644
index 0000000..b7c7b78
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_01.html
@@ -0,0 +1,80 @@
+
+
+
+Exercise17_01.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/Exercise17_01.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import java.io.EOFException;
+
+import java.io.RandomAccessFile;
+
+
+
+
+
+public class Exercise17_01 {
+
+ public static void main(String[] args)
+ {
+ try (RandomAccessFile fileIO = new RandomAccessFile("Exercise17_01.txt", "rw")) {
+ int random = 0;
+ System.out.println("Writing data to file...");
+ for (int i = 1; i < 100 + 1; ++i) {
+ random = (int) (Math.random() * 9) + 1;
+ System.out.print(random + " ");
+ if (i != 0 && i % 10 == 0) {
+ System.out.println();
+ }
+ fileIO.writeInt(random);
+ }
+ System.out.println("Wrote to the file successfully!");
+ System.out.println("File contents:");
+ fileIO.seek(0);
+ int readIterator = 1;
+ while (true) {
+ try {
+ System.out.print(fileIO.readInt() + " ");
+ if (readIterator != 0 && readIterator % 10 == 0) {
+ System.out.println();
+ }
+ ++readIterator;
+ } catch (EOFException e) {
+ break;
+ }
+
+ }
+
+ } catch (Exception ex) {
+ System.out.println(ex);
+ }
+
+ }
+}
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_03.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_03.html
new file mode 100644
index 0000000..396259c
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_03.html
@@ -0,0 +1,94 @@
+
+
+
+Exercise17_03.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/Exercise17_03.java |
+
+
+
+
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import java.io.DataInputStream;
+import java.io.DataOutputStream;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+
+
+
+
+
+public class Exercise17_03 {
+
+ static int fileSize = Math.abs((int) (Math.random() * 1024));
+
+ public static void writeData()
+ {
+ try (FileOutputStream fileWrite = new FileOutputStream("Exercise17_03.dat")) {
+
+
+ int randInt = 0;
+ for (int i = 0; i < fileSize; ++i) {
+ randInt = (int) (Math.random() * 10);
+ fileWrite.write(randInt);
+ }
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ System.out.println("Wrote data to the file!");
+ }
+
+ public static int[] readData()
+ {
+ int[] fileData = new int[fileSize];
+ try (FileInputStream fileRead = new FileInputStream("Exercise17_03.dat")) {
+
+ int dataIterator = 0;
+ int dataStream = 0;
+ while (fileRead.available() > 0) {
+ dataStream = fileRead.read();
+ fileData[dataIterator++] = dataStream;
+ System.out.print(dataStream + " ");
+ if ((dataIterator + 1) % 10 == 0) {
+ System.out.println();
+ }
+ }
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ return fileData;
+ }
+
+ public static void main(String[] args)
+ {
+ System.out.println("Ints to write: " + fileSize);
+ writeData();
+ int[] fileData = readData();
+
+ int sum = 0;
+ for (int i: fileData) {
+ sum += i;
+ }
+ System.out.println("\nThe sum of the integers in the file is: " + sum);
+ }
+}
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_05.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_05.html
new file mode 100644
index 0000000..afde774
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/Exercise17_05.html
@@ -0,0 +1,107 @@
+
+
+
+Exercise17_05.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/Exercise17_05.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import java.io.File;
+import java.io.FileInputStream;
+
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.ObjectInputStream;
+import java.io.Serializable;
+import java.io.ObjectOutputStream;
+import java.util.Date;
+
+
+
+
+
+public class Exercise17_05 {
+ public static void main(String[] args) {
+ File dataFile = new File("Exercise17_05.dat");
+ if(!dataFile.exists()) {
+ try (ObjectOutputStream fileStream = new ObjectOutputStream(new FileOutputStream(dataFile))) {
+ fileStream.writeObject(new DataContainer());
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ }
+ DataContainer data = null;
+ try (ObjectInputStream fileStream = new ObjectInputStream(new FileInputStream(dataFile))) {
+ data = (DataContainer) fileStream.readObject();
+ } catch (IOException ex) {
+ System.out.println(ex);
+ } catch (ClassNotFoundException ex) {
+ System.out.println(ex);
+ }
+
+ System.out.println("We got the data from the file!");
+ System.out.println(data.toString());
+ }
+}
+
+class DataContainer implements Serializable {
+ int[] intArray = {1, 2, 3, 4};
+ Date currentDate = new Date();
+ double doubleMoment = 5.5;
+
+ public int[] getIntArray()
+ {
+ return intArray;
+ }
+
+ public Date getCurrentDate()
+ {
+ return currentDate;
+ }
+
+ public double getDoubleMoment()
+ {
+ return doubleMoment;
+ }
+
+ @Override
+ public String toString()
+ {
+ String intString = "[";
+ for (int i = 0; i < intArray.length - 1; ++i) {
+ intString += intArray[i];
+ if (i == (intArray.length - 2)) {
+ intString += "]";
+ } else {
+ intString += ", ";
+ }
+ }
+ return "DataContainer{" + "intArray=" + intString + ", currentDate=" + currentDate + ", doubleMoment=" + doubleMoment + '}';
+ }
+}
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/HexEditorFX.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/HexEditorFX.html
new file mode 100644
index 0000000..0230190
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/HexEditorFX.html
@@ -0,0 +1,177 @@
+
+
+
+HexEditorFX.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/HexEditorFX.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import static com.calebfontenot.mp5.files_calebfontenot.SplitFilesFX.alert;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+
+import javafx.application.Application;
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.Button;
+import javafx.scene.control.Label;
+import javafx.scene.control.TextArea;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.GridPane;
+import javafx.stage.FileChooser;
+import javafx.stage.Stage;
+
+
+
+
+
+public class HexEditorFX extends Application {
+
+ final FileChooser fileChooser = new FileChooser();
+ static File file = null;
+
+ @Override
+ public void start(Stage stage) throws Exception {
+ Label label = new Label("Open a file...");
+ Button openFileButton = new Button("Choose...");
+ TextArea editorWindow = new TextArea();
+ Button saveFileButton = new Button("Save");
+
+ editorWindow.setWrapText(true);
+
+ BorderPane bp = new BorderPane();
+ GridPane openFileGridPane = new GridPane();
+
+ openFileGridPane.add(label, 0, 0);
+ openFileGridPane.add(openFileButton, 1, 0);
+
+ bp.setTop(openFileGridPane);
+ bp.setCenter(editorWindow);
+ bp.setBottom(saveFileButton);
+ bp.setAlignment(saveFileButton, Pos.CENTER);
+
+ openFileButton.setOnAction(e -> {
+ file = fileChooser.showOpenDialog(openFileButton.getScene().getWindow());
+ byte[] data = null;
+ System.out.println("Getting data from fileand encoding it as hex...");
+ try (FileInputStream dataIn = new FileInputStream(file)) {
+ data = dataIn.readAllBytes();
+ } catch (FileNotFoundException ex) {
+ ex.printStackTrace();
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ }
+ String dataString = encodeHexString(data);
+ editorWindow.setText(dataString);
+ });
+
+ saveFileButton.setOnAction(e -> {
+ if (file == null) {
+ alert.setTitle("No file selected!");
+ alert.setHeaderText("No file selected!");
+ alert.setContentText("You have to open a file first, silly!");
+ alert.showAndWait();
+ }
+ System.out.println("Re-encoding hex back into a byte array...");
+
+ try (FileOutputStream dataOut = new FileOutputStream(file)) {
+ byte[] bytesToSave = decodeHexString(editorWindow.getText());
+ dataOut.write(bytesToSave);
+ } catch (FileNotFoundException ex) {
+ ex.printStackTrace();
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ } catch (IllegalArgumentException ex) {
+ alert.setTitle("Invalid Hex!");
+ alert.setContentText("Invalid hex entered into the text box, unable to save.");
+ alert.showAndWait();
+ }
+ alert.setTitle("Save successful!");
+ alert.setContentText("File saved successfully.");
+ alert.showAndWait();
+ });
+
+ Scene scene = new Scene(bp);
+ stage.setScene(scene);
+ stage.show();
+
+ }
+
+ private int toDigit(char hexChar) {
+ int digit = Character.digit(hexChar, 16);
+ if (digit == -1) {
+ throw new IllegalArgumentException(
+ "Invalid Hexadecimal Character: " + hexChar);
+ }
+ return digit;
+ }
+
+ public byte hexToByte(String hexString) {
+ int firstDigit = toDigit(hexString.charAt(0));
+ int secondDigit = toDigit(hexString.charAt(1));
+ return (byte) ((firstDigit << 4) + secondDigit);
+ }
+
+ public byte[] decodeHexString(String hexString) {
+ if (hexString.length() % 2 == 1) {
+ throw new IllegalArgumentException(
+ "Invalid hexadecimal String supplied.");
+ }
+ byte[] bytes = new byte[hexString.length() / 2];
+ for (int i = 0; i < hexString.length(); i += 2) {
+ bytes[i / 2] = hexToByte(hexString.substring(i, i + 2));
+ }
+ return bytes;
+ }
+
+ public String byteToHex(byte num) {
+ char[] hexDigits = new char[2];
+ hexDigits[0] = Character.forDigit((num >> 4) & 0xF, 16);
+ hexDigits[1] = Character.forDigit((num & 0xF), 16);
+ return new String(hexDigits);
+ }
+
+ public String encodeHexString(byte[] byteArray) {
+ StringBuffer hexStringBuffer = new StringBuffer();
+ for (int i = 0; i < byteArray.length; i++) {
+ hexStringBuffer.append(byteToHex(byteArray[i]));
+ }
+ return hexStringBuffer.toString();
+ }
+
+ public static void main(String[] args) {
+ launch(args);
+ }
+}
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/SplitFilesFX.html b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/SplitFilesFX.html
new file mode 100644
index 0000000..4320332
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/Printed HTMLs/SplitFilesFX.html
@@ -0,0 +1,152 @@
+
+
+
+SplitFilesFX.java
+
+
+
+
+/home/caleb/ASDV-Java/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/SplitFilesFX.java |
+
+
+nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt
+nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java
+
+package com.calebfontenot.mp5.files_calebfontenot;
+
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import javafx.application.Application;
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.Alert;
+import javafx.scene.control.Button;
+import javafx.scene.control.Label;
+import javafx.scene.control.ProgressBar;
+import javafx.scene.control.TextField;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.GridPane;
+import javafx.stage.FileChooser;
+import javafx.stage.Stage;
+
+
+
+
+
+public class SplitFilesFX extends Application {
+ static File file = null;
+ final FileChooser fileChooser = new FileChooser();
+ static ProgressBar pb = new ProgressBar();
+ static Alert alert = new Alert(Alert.AlertType.INFORMATION);
+ @Override
+ public void start(final Stage stage) throws Exception
+ {
+ fileChooser.setTitle("Open File to Split...");
+ BorderPane primaryBorderPane = new BorderPane();
+ BorderPane secondaryBoarderPane = new BorderPane();
+ GridPane textFieldGridPane = new GridPane();
+
+ pb.prefWidthProperty().bind(stage.widthProperty());
+
+ Label infoLabel = new Label("If you split a file named tmp into 3 smaller files,\n the three smaller files are temp.txt.1, temp.txt.2, and temp.txt.3. ");
+ Label chooseFile = new Label("Choose a file to split: ");
+ Button openFilePicker = new Button("Choose...");
+ Label splitCountLabel = new Label("Enter the amount of files to split into: ");
+ TextField splitCount = new TextField();
+ Button run = new Button("Start");
+ textFieldGridPane.add(chooseFile, 0, 0);
+ textFieldGridPane.add(openFilePicker, 1, 0);
+ textFieldGridPane.add(splitCountLabel, 0, 1);
+ textFieldGridPane.add(splitCount, 1, 1);
+ secondaryBoarderPane.setAlignment(run, Pos.CENTER);
+
+ primaryBorderPane.setTop(infoLabel);
+ primaryBorderPane.setCenter(textFieldGridPane);
+
+ secondaryBoarderPane.setBottom(run);
+ secondaryBoarderPane.setTop(pb);
+
+ primaryBorderPane.setBottom(secondaryBoarderPane);
+
+ openFilePicker.setOnAction(e -> {
+ file = fileChooser.showOpenDialog(openFilePicker.getScene().getWindow());
+ });
+
+ run.setOnAction(e -> {
+ if (file == null) {
+ e.consume();
+ }
+ splitFile(file, Integer.parseInt(splitCount.getText()));
+ });
+
+ Scene scene = new Scene(primaryBorderPane);
+ stage.setScene(scene);
+ stage.show();
+ }
+
+ public static void splitFile(File fileToSplit, int splitCount) {
+ int outputFileSize = (int) fileToSplit.length() / splitCount;
+ System.out.println("output file size will be: " + outputFileSize);
+ if (outputFileSize < 0) {
+ alert.setTitle("Output files too large");
+ alert.setHeaderText("Output files too large");
+ alert.setContentText("Please increase the amount of files to split!");
+
+ alert.showAndWait();
+ return;
+ }
+
+ double progress = 0;
+ String outputPath = fileToSplit.getParent();
+
+ try (FileInputStream dataIn = new FileInputStream(fileToSplit)) {
+ System.out.println("Opening the source file!");
+ for (int i = 0; i < splitCount; ++i) {
+ progress = (i * 100) / splitCount;
+ System.out.println(progress);
+ pb.setProgress(progress);
+ dataIn.mark(outputFileSize * (i + 1));
+ try (FileOutputStream dataOut = new FileOutputStream(outputPath + "/" + fileToSplit.getName() + "." + (i + 1))) {
+ dataOut.write(dataIn.readNBytes(outputFileSize), 0, outputFileSize);
+ System.out.println("Writing to " + outputPath + "/" + fileToSplit.getName() + "." + (i + 1));
+ }
+ }
+
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+
+ }
+
+
+ public static void main(String[] args)
+ {
+ launch();
+ }
+}
+
+
+
+
+
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/build-impl.xml b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/build-impl.xml
index 22ab97e..fde7389 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/build-impl.xml
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/build-impl.xml
@@ -119,7 +119,43 @@ is divided into following sections:
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Must set platform.home
+ Must set platform.bootcp
+ Must set platform.java
+ Must set platform.javac
+
+ The J2SE Platform is not correctly set up.
+ Your active platform is: ${platform.active}, but the corresponding property "platforms.${platform.active}.home" is not found in the project's properties files.
+ Either open the project in the IDE and setup the Platform with the same name or add it manually.
+ For example like this:
+ ant -Duser.properties.file=<path_to_property_file> jar (where you put the property "platforms.${platform.active}.home" in a .properties file)
+ or ant -Dplatforms.${platform.active}.home=<path_to_JDK_home> jar (where no properties file is used)
+
@@ -242,20 +278,6 @@ is divided into following sections:
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -343,7 +365,7 @@ is divided into following sections:
-
+
@@ -394,7 +416,7 @@ is divided into following sections:
-
+
@@ -436,7 +458,7 @@ is divided into following sections:
-
+
@@ -515,7 +537,7 @@ is divided into following sections:
-
+
@@ -543,7 +565,7 @@ is divided into following sections:
-
+
@@ -619,7 +641,7 @@ is divided into following sections:
-
+
@@ -850,6 +872,9 @@ is divided into following sections:
+
+
+
@@ -899,7 +924,7 @@ is divided into following sections:
-
+
@@ -933,7 +958,7 @@ is divided into following sections:
-
+
@@ -965,7 +990,7 @@ is divided into following sections:
-
+
@@ -1199,7 +1224,7 @@ is divided into following sections:
To run this application from the command line without Ant, try:
- java -jar "${dist.jar.resolved}"
+ ${platform.java} -jar "${dist.jar.resolved}"
@@ -1301,8 +1326,8 @@ is divided into following sections:
-
-
+
+
@@ -1495,16 +1520,19 @@ is divided into following sections:
+
+
+
-
+
-
+
-
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/genfiles.properties b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/genfiles.properties
index 5585d25..de9648f 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/genfiles.properties
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/genfiles.properties
@@ -1,8 +1,8 @@
-build.xml.data.CRC32=a0844a83
+build.xml.data.CRC32=5b3e797d
build.xml.script.CRC32=dee8d968
build.xml.stylesheet.CRC32=f85dc8f2@1.108.0.48
# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml.
# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you.
-nbproject/build-impl.xml.data.CRC32=a0844a83
-nbproject/build-impl.xml.script.CRC32=025ed557
+nbproject/build-impl.xml.data.CRC32=5b3e797d
+nbproject/build-impl.xml.script.CRC32=7cb0beee
nbproject/build-impl.xml.stylesheet.CRC32=12e0a6c2@1.108.0.48
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.properties b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.properties
index ded35af..4ba8d76 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.properties
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.properties
@@ -49,7 +49,7 @@ javac.compilerargs=
javac.deprecation=false
javac.external.vm=true
javac.modulepath=\
- ${libs.JavaFX20.classpath}
+ ${libs.JavaFX_20.classpath}
javac.processormodulepath=
javac.processorpath=\
${javac.classpath}
@@ -101,7 +101,7 @@ manifest.custom.permissions=
manifest.file=manifest.mf
meta.inf.dir=${src.dir}/META-INF
mkdist.disabled=false
-platform.active=default_platform
+platform.active=Graal_JDK_20
run.classpath=\
${javac.classpath}:\
${build.classes.dir}:\
@@ -109,7 +109,7 @@ run.classpath=\
# Space-separated list of JVM arguments used when running the project.
# You may also define separate properties like run-sys-prop.name=value instead of -Dname=value.
# To set system properties for unit tests define test-sys-prop.name=value:
-run.jvmargs=-XX:+UnlockExperimentalVMOptions -XX:+EagerJVMCI -XX:+EnableJVMCI -XX:+UseJVMCICompiler -XX:+UseJVMCINativeLibrary
+run.jvmargs=--module-path=/usr/lib --add-modules javafx.controls -XX:+UnlockExperimentalVMOptions -XX:+EagerJVMCI -XX:+EnableJVMCI -XX:+UseJVMCICompiler -XX:+UseJVMCINativeLibrary
run.modulepath=\
${javac.modulepath}
run.test.classpath=\
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.xml b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.xml
index 464cc39..f73fb1b 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.xml
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/nbproject/project.xml
@@ -4,6 +4,7 @@
MP5-Binary-Files_CalebFontenot
+
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/CombineFilesFX.java b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/CombineFilesFX.java
index 4523d2b..b61b7c0 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/CombineFilesFX.java
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/CombineFilesFX.java
@@ -10,10 +10,16 @@ import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
import java.util.List;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
+import javafx.scene.control.Alert;
+import javafx.scene.control.Alert.AlertType;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
@@ -28,12 +34,11 @@ import javafx.stage.Stage;
*/
public class CombineFilesFX extends Application {
- static List files = null;
+ static ArrayList files = new ArrayList();
final FileChooser fileChooser = new FileChooser();
@Override
- public void start(final Stage stage) throws Exception
- {
+ public void start(final Stage stage) throws Exception {
fileChooser.setTitle("Open File to Split...");
BorderPane primaryBorderPane = new BorderPane();
GridPane textFieldGridPane = new GridPane();
@@ -51,7 +56,30 @@ public class CombineFilesFX extends Application {
primaryBorderPane.setBottom(run);
openFilePicker.setOnAction(e -> {
- files = fileChooser.showOpenMultipleDialog(openFilePicker.getScene().getWindow());
+ // When we initially get the files from the file chooser, it returns an unsortable list. Because of this, we need to create a new List with its data.
+ files.addAll(fileChooser.showOpenMultipleDialog(openFilePicker.getScene().getWindow()));
+ // The file picker appears to return files in a random order, so we need to sort them by file name.
+ Collections.sort(files, new Comparator() {
+ public int compare(File o1, File o2) {
+ return extractInt(o1.getName()) - extractInt(o2.getName());
+ }
+
+ String findMatch(String s) {
+ Pattern findNum = Pattern.compile("\\d+$");
+ Matcher match = findNum.matcher(s);
+ while (match.find()) {
+ return match.group();
+ }
+ return "";
+ }
+
+ int extractInt(String s) {
+ String num = findMatch(s);
+ System.out.println(num);
+ // return 0 if no digits found
+ return num.isEmpty() ? 0 : Integer.parseInt(num);
+ }
+ });
});
run.setOnAction(e -> {
@@ -66,33 +94,37 @@ public class CombineFilesFX extends Application {
stage.show();
}
- public static void combineFiles(List filesToCombine)
- {
+ public static void combineFiles(List filesToCombine) {
String outputPath = filesToCombine.get(0).getParent();
- try (FileOutputStream dataOut = new FileOutputStream(outputPath + "/" + "reconstructed_" +filesToCombine.get(0).getName().substring( 0, (filesToCombine.get(0).getName().length() - 2)))) {
- System.out.println("Writing to " + outputPath + "/" + "reconstructed_" +filesToCombine.get(0).getName().substring( 0, ( filesToCombine.get(0).getName().length() - 2)));
+ try (FileOutputStream dataOut = new FileOutputStream(outputPath + "/" + "reconstructed_" + filesToCombine.get(0).getName().substring(0, (filesToCombine.get(0).getName().length() - 2)))) {
+ System.out.println("Writing to " + outputPath + "/" + "reconstructed_" + filesToCombine.get(0).getName().substring(0, (filesToCombine.get(0).getName().length() - 2)));
for (File file : filesToCombine) {
try (FileInputStream dataIn = new FileInputStream(file)) {
- System.out.println("Opening the source file!");
- byte[] buffer = new byte[4096]; // You can adjust the buffer size as needed
+ System.out.println("Opening the source file " + file.getName() + "!");
+ byte[] buffer = new byte[4096];
+ int bytesRead = -1;
- int bytesRead;
- while ((bytesRead = dataIn.read(buffer)) != -1) {
- dataOut.write(buffer, 0, bytesRead);
+ while ((bytesRead = dataIn.read(buffer)) != -1) {
+ dataOut.write(buffer, 0, bytesRead);
+ }
}
- }
+ catch (IOException ex) {
+ System.out.println(ex);
}
- } catch (IOException ex) {
- System.out.println(ex);
- }
- }
+ }
+ } catch (IOException ex) {
+ System.out.println(ex);
+ }
+ Alert alert = new Alert(AlertType.INFORMATION);
+ alert.setTitle("Success!");
+ alert.setContentText("Successfully combined the files!");
+
+ alert.showAndWait();
+ }
+
- public static void main(String[] args)
- {
+ public static void main(String[] args) {
launch();
}
}
-/*
-
- */
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/HexEditorFX.java b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/HexEditorFX.java
new file mode 100644
index 0000000..5b7946e
--- /dev/null
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/HexEditorFX.java
@@ -0,0 +1,147 @@
+/*
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
+ */
+package com.calebfontenot.mp5.files_calebfontenot;
+
+import static com.calebfontenot.mp5.files_calebfontenot.SplitFilesFX.alert;
+import static com.calebfontenot.mp5.files_calebfontenot.SplitFilesFX.file;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.util.ArrayList;
+import javafx.application.Application;
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.Button;
+import javafx.scene.control.Label;
+import javafx.scene.control.TextArea;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.GridPane;
+import javafx.stage.FileChooser;
+import javafx.stage.Stage;
+
+/**
+ *
+ * @author caleb
+ */
+public class HexEditorFX extends Application {
+
+ final FileChooser fileChooser = new FileChooser();
+ static File file = null;
+
+ @Override
+ public void start(Stage stage) throws Exception {
+ Label label = new Label("Open a file...");
+ Button openFileButton = new Button("Choose...");
+ TextArea editorWindow = new TextArea();
+ Button saveFileButton = new Button("Save");
+
+ editorWindow.setWrapText(true);
+
+ BorderPane bp = new BorderPane();
+ GridPane openFileGridPane = new GridPane();
+
+ openFileGridPane.add(label, 0, 0);
+ openFileGridPane.add(openFileButton, 1, 0);
+
+ bp.setTop(openFileGridPane);
+ bp.setCenter(editorWindow);
+ bp.setBottom(saveFileButton);
+ bp.setAlignment(saveFileButton, Pos.CENTER);
+
+ openFileButton.setOnAction(e -> {
+ file = fileChooser.showOpenDialog(openFileButton.getScene().getWindow());
+ byte[] data = null;
+ System.out.println("Getting data from fileand encoding it as hex...");
+ try (FileInputStream dataIn = new FileInputStream(file)) {
+ data = dataIn.readAllBytes();
+ } catch (FileNotFoundException ex) {
+ ex.printStackTrace();
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ }
+ String dataString = encodeHexString(data);
+ editorWindow.setText(dataString);
+ });
+
+ saveFileButton.setOnAction(e -> {
+ if (file == null) {
+ alert.setTitle("No file selected!");
+ alert.setHeaderText("No file selected!");
+ alert.setContentText("You have to open a file first, silly!");
+ alert.showAndWait();
+ }
+ System.out.println("Re-encoding hex back into a byte array...");
+
+ try (FileOutputStream dataOut = new FileOutputStream(file)) {
+ byte[] bytesToSave = decodeHexString(editorWindow.getText());
+ dataOut.write(bytesToSave);
+ } catch (FileNotFoundException ex) {
+ ex.printStackTrace();
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ } catch (IllegalArgumentException ex) {
+ alert.setTitle("Invalid Hex!");
+ alert.setContentText("Invalid hex entered into the text box, unable to save.");
+ alert.showAndWait();
+ }
+ alert.setTitle("Save successful!");
+ alert.setContentText("File saved successfully.");
+ alert.showAndWait();
+ });
+
+ Scene scene = new Scene(bp);
+ stage.setScene(scene);
+ stage.show();
+
+ }
+
+ private int toDigit(char hexChar) {
+ int digit = Character.digit(hexChar, 16);
+ if (digit == -1) {
+ throw new IllegalArgumentException(
+ "Invalid Hexadecimal Character: " + hexChar);
+ }
+ return digit;
+ }
+
+ public byte hexToByte(String hexString) {
+ int firstDigit = toDigit(hexString.charAt(0));
+ int secondDigit = toDigit(hexString.charAt(1));
+ return (byte) ((firstDigit << 4) + secondDigit);
+ }
+
+ public byte[] decodeHexString(String hexString) {
+ if (hexString.length() % 2 == 1) {
+ throw new IllegalArgumentException(
+ "Invalid hexadecimal String supplied.");
+ }
+ byte[] bytes = new byte[hexString.length() / 2];
+ for (int i = 0; i < hexString.length(); i += 2) {
+ bytes[i / 2] = hexToByte(hexString.substring(i, i + 2));
+ }
+ return bytes;
+ }
+
+ public String byteToHex(byte num) {
+ char[] hexDigits = new char[2];
+ hexDigits[0] = Character.forDigit((num >> 4) & 0xF, 16);
+ hexDigits[1] = Character.forDigit((num & 0xF), 16);
+ return new String(hexDigits);
+ }
+
+ public String encodeHexString(byte[] byteArray) {
+ StringBuffer hexStringBuffer = new StringBuffer();
+ for (int i = 0; i < byteArray.length; i++) {
+ hexStringBuffer.append(byteToHex(byteArray[i]));
+ }
+ return hexStringBuffer.toString();
+ }
+
+ public static void main(String[] args) {
+ launch(args);
+ }
+}
diff --git a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/SplitFilesFX.java b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/SplitFilesFX.java
index 0c79ce5..5e062af 100644
--- a/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/SplitFilesFX.java
+++ b/Semester 3/Assignments/MP5-Binary-Files_CalebFontenot/src/com/calebfontenot/mp5/files_calebfontenot/SplitFilesFX.java
@@ -12,8 +12,10 @@ import java.io.IOException;
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
+import javafx.scene.control.Alert;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
+import javafx.scene.control.ProgressBar;
import javafx.scene.control.TextField;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.GridPane;
@@ -27,12 +29,17 @@ import javafx.stage.Stage;
public class SplitFilesFX extends Application {
static File file = null;
final FileChooser fileChooser = new FileChooser();
+ static ProgressBar pb = new ProgressBar();
+ static Alert alert = new Alert(Alert.AlertType.INFORMATION);
@Override
public void start(final Stage stage) throws Exception
{
fileChooser.setTitle("Open File to Split...");
BorderPane primaryBorderPane = new BorderPane();
+ BorderPane secondaryBoarderPane = new BorderPane();
GridPane textFieldGridPane = new GridPane();
+
+ pb.prefWidthProperty().bind(stage.widthProperty());
Label infoLabel = new Label("If you split a file named tmp into 3 smaller files,\n the three smaller files are temp.txt.1, temp.txt.2, and temp.txt.3. ");
Label chooseFile = new Label("Choose a file to split: ");
@@ -44,11 +51,15 @@ public class SplitFilesFX extends Application {
textFieldGridPane.add(openFilePicker, 1, 0);
textFieldGridPane.add(splitCountLabel, 0, 1);
textFieldGridPane.add(splitCount, 1, 1);
- primaryBorderPane.setAlignment(run, Pos.CENTER);
+ secondaryBoarderPane.setAlignment(run, Pos.CENTER);
primaryBorderPane.setTop(infoLabel);
primaryBorderPane.setCenter(textFieldGridPane);
- primaryBorderPane.setBottom(run);
+
+ secondaryBoarderPane.setBottom(run);
+ secondaryBoarderPane.setTop(pb);
+
+ primaryBorderPane.setBottom(secondaryBoarderPane);
openFilePicker.setOnAction(e -> {
file = fileChooser.showOpenDialog(openFilePicker.getScene().getWindow());
@@ -68,12 +79,26 @@ public class SplitFilesFX extends Application {
public static void splitFile(File fileToSplit, int splitCount) {
int outputFileSize = (int) fileToSplit.length() / splitCount;
+ System.out.println("output file size will be: " + outputFileSize);
+ if (outputFileSize < 0) {
+ alert.setTitle("Output files too large");
+ alert.setHeaderText("Output files too large");
+ alert.setContentText("Please increase the amount of files to split!");
+
+ alert.showAndWait();
+ return;
+ }
+
+ double progress = 0;
String outputPath = fileToSplit.getParent();
// Open the original file
try (FileInputStream dataIn = new FileInputStream(fileToSplit)) {
System.out.println("Opening the source file!");
for (int i = 0; i < splitCount; ++i) {
- //dataIn.mark(outputFileSize * (i + 1));
+ progress = (i * 100) / splitCount;
+ System.out.println(progress);
+ pb.setProgress(progress);
+ dataIn.mark(outputFileSize * (i + 1));
try (FileOutputStream dataOut = new FileOutputStream(outputPath + "/" + fileToSplit.getName() + "." + (i + 1))) {
dataOut.write(dataIn.readNBytes(outputFileSize), 0, outputFileSize);
System.out.println("Writing to " + outputPath + "/" + fileToSplit.getName() + "." + (i + 1));
diff --git a/Semester 3/Assignments/MP6_CalebFontenot/src/main/java/edu/slcc/asdv/caleb/mp6_calebfontenot/PriorityQueueASDV.java b/Semester 3/Assignments/MP6_CalebFontenot/src/main/java/edu/slcc/asdv/caleb/mp6_calebfontenot/PriorityQueueASDV.java
index cf74ce0..fc7f90c 100644
--- a/Semester 3/Assignments/MP6_CalebFontenot/src/main/java/edu/slcc/asdv/caleb/mp6_calebfontenot/PriorityQueueASDV.java
+++ b/Semester 3/Assignments/MP6_CalebFontenot/src/main/java/edu/slcc/asdv/caleb/mp6_calebfontenot/PriorityQueueASDV.java
@@ -18,14 +18,12 @@ import java.util.Queue;
import java.util.function.Consumer;
public class PriorityQueueASDV>
- implements Queue, Cloneable
-{
+ implements Queue, Cloneable {
private Node head;//head
private Node tail;//tail
- class Node
- {
+ class Node {
E e;
Node l;
@@ -33,78 +31,56 @@ public class PriorityQueueASDV>
}
/**
- * Inserts the specified element into this queue if it is possible to do so
- * immediately without violating capacity restrictions, returning true upon
- * success and throwing an IllegalStateException if no space is currently
- * available.
+ * Inserts the specified element into this queue if it is possible to do so immediately without violating capacity restrictions, returning true upon success and throwing an IllegalStateException if no space is currently available.
*
* Specified by: add in interface Collection
- * Parameters: e - the element to add Returns: true (as specified by
- * Collection.add(E)) Throws: IllegalStateException - if the element cannot
- * be added at this time due to capacity restrictions ClassCastException -
- * if the class of the specified element prevents it from being added to
- * this queue NullPointerException - if the specified element is null and
- * this queue does not permit null elements IllegalArgumentException - if
- * some property of this element prevents it from being added to this queue
+ * Parameters: e - the element to add Returns: true (as specified by Collection.add(E)) Throws: IllegalStateException - if the element cannot be added at this time due to capacity restrictions ClassCastException - if the class of the specified element prevents it from being added to this queue NullPointerException - if the specified element is null and this queue does not permit null elements IllegalArgumentException - if some property of this element prevents it from being added to this queue
*
* @param e - the element to add
* @return true if this collection changed as a result of the call
- * @throws IllegalStateException - if the element cannot be added at this
- * time due to capacity restrictions
+ * @throws IllegalStateException - if the element cannot be added at this time due to capacity restrictions
* @throws ClassCastException - if the class of the specified element
- * @throws NullPointerException - if the specified element is null and this
- * queue does not permit null elements
- * @throws IllegalArgumentException - if some property of this element
- * prevents it from being added to this queue
+ * @throws NullPointerException - if the specified element is null and this queue does not permit null elements
+ * @throws IllegalArgumentException - if some property of this element prevents it from being added to this queue
*/
@Override
- public boolean add(E e)
- {
- if (e == null)
- {
+ public boolean add(E e) {
+ if (e == null) {
throw new NullPointerException("NULL elements not allowed!");
- }
+ }
Node newNode = new Node();
newNode.e = e;
//1. empty queue
- if (this.head == null && this.tail == null)
- {
+ if (this.head == null && this.tail == null) {
this.head = this.tail = newNode;
return true;
- }
+ }
int index = findCorrectPositionToInsertElement(e);
//int index = findCorrectPositionToInsertElementHashCode(e);
//2. we add at size ( last node)
- if (index == size())
- {
+ if (index == size()) {
tail.r = newNode;//1
newNode.l = tail;//2
tail = newNode;//3
- }
- //3. we add at 0 in the front
- else if (index == 0)
- {
+ } //3. we add at 0 in the front
+ else if (index == 0) {
newNode.r = head;
this.head.l = newNode;
this.head = newNode;
- if (size() == 1)
- {
+ if (size() == 1) {
tail = head;
- }
- }
- //4. we add in the middle
- else
- {
+ }
+ } //4. we add in the middle
+ else {
Node p = head;
- for (int i = 0; i < index - 1; ++i)
- {
+ for (int i = 0; i < index - 1; ++i) {
p = p.r;
- }
+ }
//after for loop p point one position before insertion
newNode.l = p;//we connect the left of the new node
@@ -120,181 +96,198 @@ public class PriorityQueueASDV>
p.r.r.l = newNode;//we connect the left of the node AFTER the node
//to be iserted to the new node
- }
+ }
return true;
}
@Override
- public int size()
- {
+ public int size() {
Node p = this.head;
int count = 0;
- while (p != null)
- {
+ while (p != null) {
p = p.r;
count++;
- }
+ }
return count;
}
- private int findCorrectPositionToInsertElement(E e)
- {
+ private int findCorrectPositionToInsertElement(E e) {
Node p = this.head;
int pos = 0;
- while (p != null)
- {
- if (e.compareTo(p.e) > 0)
- {
+ while (p != null) {
+ if (e.compareTo(p.e) > 0) {
p = p.r;
++pos;
- }
- else
- {
+ } else {
break;
- }
- }
+ }
+ }
return pos;
}
- private int findCorrectPositionToInsertElementHashCode(E e)
- {
+ private int findCorrectPositionToInsertElementHashCode(E e) {
Node p = this.head;
int pos = 0;
- while (p != null)
- {
- if (e.hashCode() > p.e.hashCode())
- {
+ while (p != null) {
+ if (e.hashCode() > p.e.hashCode()) {
p = p.r;
++pos;
- }
- else
- {
+ } else {
break;
- }
- }
+ }
+ }
return pos;
}
/**
- * Inserts the specified element into this queue if it is possible to do so
- * immediately without violating capacity restrictions. When using a
- * capacity-restricted queue, this method is generally preferable to add(E),
- * which can fail to insert an element only by throwing an exception.
+ * Inserts the specified element into this queue if it is possible to do so immediately without violating capacity restrictions. When using a capacity-restricted queue, this method is generally preferable to add(E), which can fail to insert an element only by throwing an exception.
*
* @param e - the element to add
- * @throws IllegalStateException - if the element cannot be added at this
- * time due to capacity restrictions
+ * @throws IllegalStateException - if the element cannot be added at this time due to capacity restrictions
* @throws ClassCastException - if the class of the specified element
- * @throws NullPointerException - if the specified element is null and this
- * queue does not permit null elements
- * @throws IllegalArgumentException - if some property of this element
- * prevents it from being added to this queue
+ * @throws NullPointerException - if the specified element is null and this queue does not permit null elements
+ * @throws IllegalArgumentException - if some property of this element prevents it from being added to this queue
* @return true if the element was added
*/
@Override
- public boolean offer(E e)
- {
+ public boolean offer(E e) {
return add(e);
}
+ /**
+ * Retrieves and removes the head of this queue. This method differs from {@link #poll poll} only in that it throws an exception if this queue is empty.
+ *
+ *
+ * This implementation returns the result of {@code poll} unless the queue is empty.
+ *
+ * @return the head of this queue
+ * @throws NoSuchElementException if this queue is empty
+ */
@Override
- public E remove()
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
+ public E remove() {
+ Node pointer = head.r;
+ E removedElement = head.e;
+ head = head.r;
+ head.l = null;
+
+ return removedElement;
}
/**
- * Retrieves and removes the head of this queue, or returns null if this
- * queue is empty.
+ * Retrieves and removes the head of this queue, or returns null if this queue is empty.
*
* Returns: the head of this queue, or null if this queue is empty
*
* @return
*/
@Override
- public E poll()
- {
- if (size() == 0)
- {
+ public E poll() {
+ if (size() == 0) {
return null;
- }
- if (size() > 1)
- {
+ }
+ if (size() > 1) {
head = head.r;
E e = head.l.e;
head.l = null;
return e;
- }
- else //size 1
- {
+ } else //size 1
+ {
E e = head.e;
head = tail = null;
return e;
- }
+ }
+ }
+ /**
+ * Retrieves, but does not remove, the head of this queue. This method
+ * differs from {@link #peek peek} only in that it throws an exception
+ * if this queue is empty.
+ *
+ * @return the head of this queue
+ * @throws NoSuchElementException if this queue is empty
+ */
+ @Override
+ public E element() {
+ if (head != null) {
+ return (E) head;
+ } else {
+ throw new NoSuchElementException("Element does not exist.");
+ }
+ }
+ /**
+ * Retrieves, but does not remove, the head of this queue,
+ * or returns {@code null} if this queue is empty.
+ *
+ * @return the head of this queue, or {@code null} if this queue is empty
+ */
+ @Override
+ public E peek() {
+ return (E) head;
}
@Override
- public E element()
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
- }
-
- @Override
- public E peek()
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
- }
-
- @Override
- public boolean isEmpty()
- {
+ public boolean isEmpty() {
return head == null && tail == null ? true : false;
}
-
+ /**
+ * Returns {@code true} if this collection contains the specified element.
+ * More formally, returns {@code true} if and only if this collection
+ * contains at least one element {@code e} such that
+ * {@code Objects.equals(o, e)}.
+ *
+ * @param o element whose presence in this collection is to be tested
+ * @return {@code true} if this collection contains the specified
+ * element
+ * @throws ClassCastException if the type of the specified element
+ * is incompatible with this collection
+ * ({@linkplain Collection##optional-restrictions optional})
+ * @throws NullPointerException if the specified element is null and this
+ * collection does not permit null elements
+ * ({@linkplain Collection##optional-restrictions optional})
+ */
@Override
- public boolean contains(Object o)
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
+ public boolean contains(Object o) {
+ Node pointer = head;
+ do {
+ if (pointer.equals(o)) {
+ return true;
+ } else {
+ pointer =pointer.r;
+ }
+ } while (pointer != null);
+ return false;
}
@Override
- public Iterator iterator()
- {
- Iterator it = new Iterator()
- {
+ public Iterator iterator() {
+ Iterator it = new Iterator() {
Node p = head;
@Override
- public boolean hasNext()
- {
+ public boolean hasNext() {
return p == null ? false : true;
}
@Override
- public E next()
- {
- if (hasNext() == false)
- {
+ public E next() {
+ if (hasNext() == false) {
throw new NoSuchElementException("the is no next element");
- }
+ }
E e = p.e;
p = p.r;
return e;
}
@Override
- public void forEachRemaining(Consumer super E> action)
- {
- while (hasNext())
- {
+ public void forEachRemaining(Consumer super E> action) {
+ while (hasNext()) {
action.accept(p.e);
p = p.r;
- }
+ }
}
};
@@ -303,65 +296,111 @@ public class PriorityQueueASDV>
}
@Override
- public Object[] toArray()
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
+ public Object[] toArray() {
+ Node pointer = head;
+ Object[] returnArray = new Object[this.size()];
+ int i = 0;
+ while (pointer.r != null) {
+ returnArray[i++] = pointer.e;
+ pointer = pointer.r;
+ }
+ returnArray[i++] = pointer.e;
+ return returnArray;
}
-
+ /**
+ * Returns an array containing all of the elements in this collection;
+ * the runtime type of the returned array is that of the specified array.
+ * If the collection fits in the specified array, it is returned therein.
+ * Otherwise, a new array is allocated with the runtime type of the
+ * specified array and the size of this collection.
+ *
+ * If this collection fits in the specified array with room to spare
+ * (i.e., the array has more elements than this collection), the element
+ * in the array immediately following the end of the collection is set to
+ * {@code null}. (This is useful in determining the length of this
+ * collection only if the caller knows that this collection does
+ * not contain any {@code null} elements.)
+ *
+ *
If this collection makes any guarantees as to what order its elements
+ * are returned by its iterator, this method must return the elements in
+ * the same order.
+ *
+ * @apiNote
+ * This method acts as a bridge between array-based and collection-based APIs.
+ * It allows an existing array to be reused under certain circumstances.
+ * Use {@link #toArray()} to create an array whose runtime type is {@code Object[]},
+ * or use {@link #toArray(IntFunction)} to control the runtime type of
+ * the array.
+ *
+ *
Suppose {@code x} is a collection known to contain only strings.
+ * The following code can be used to dump the collection into a previously
+ * allocated {@code String} array:
+ *
+ *
+ * String[] y = new String[SIZE];
+ * ...
+ * y = x.toArray(y);
+ *
+ * The return value is reassigned to the variable {@code y}, because a
+ * new array will be allocated and returned if the collection {@code x} has
+ * too many elements to fit into the existing array {@code y}.
+ *
+ *
Note that {@code toArray(new Object[0])} is identical in function to
+ * {@code toArray()}.
+ *
+ * @param the component type of the array to contain the collection
+ * @param a the array into which the elements of this collection are to be
+ * stored, if it is big enough; otherwise, a new array of the same
+ * runtime type is allocated for this purpose.
+ * @return an array containing all of the elements in this collection
+ * @throws ArrayStoreException if the runtime type of any element in this
+ * collection is not assignable to the {@linkplain Class#getComponentType
+ * runtime component type} of the specified array
+ * @throws NullPointerException if the specified array is null
+ */
@Override
- public T[] toArray(T[] a)
- {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
+ public T[] toArray(T[] a) {
+ T[] genericArray = new T[this.size()];
+ Node pointer = head;
+ for (int i = 0; i < this.size(); ++i) {
+ genericArray[i] = pointer;
+ }
}
/**
- * Removes a single instance of the specified element from this collection,
- * if it is present (optional operation). More formally, removes an element
- * e such that (o==null ? e==null : o.equals(e)), if this collection
- * contains one or more such elements. Returns true if this collection
- * contained the specified element (or equivalently, if this collection
- * changed as a result of the call).
+ * Removes a single instance of the specified element from this collection, if it is present (optional operation). More formally, removes an element e such that (o==null ? e==null : o.equals(e)), if this collection contains one or more such elements. Returns true if this collection contained the specified element (or equivalently, if this collection changed as a result of the call).
*
* @param o - element to be removed from this collection, if present
- * @throws ClassCastException - if the type of the specified element is
- * incompatible with this collection
- * @throws NullPointerException - if the specified element is null and this
- * collection does not permit null elements
+ * @throws ClassCastException - if the type of the specified element is incompatible with this collection
+ * @throws NullPointerException - if the specified element is null and this collection does not permit null elements
* @return true if an element was removed as a result of this call
*/
@Override
- public boolean remove(Object o)
- {
- if (o == null)
- {
+ public boolean remove(Object o) {
+ if (o == null) {
throw new NullPointerException("null vales not allowed");
- }
- if (size() == 0)
- {
+ }
+ if (size() == 0) {
return false;
- }
+ }
Node p = this.head;
int pos = 0;
- while (p != this.tail)
- {
- if (p.e.equals(o))
- {
- if (size() == 1)
- {
+ while (p != this.tail) {
+ if (p.e.equals(o)) {
+ if (size() == 1) {
this.head = this.tail = null;
return true;
- }
+ }
this.removeAt(pos, (E) o);
break;
- }
+ }
++pos;
p = p.r;
- }
- if (p == tail && p.e.equals(o))
- {
+ }
+ if (p == tail && p.e.equals(o)) {
this.removeAt(size() - 1, (E) o);
- }
+ }
return true;
}
@@ -369,162 +408,141 @@ public class PriorityQueueASDV>
*
* @param pos
* @param e
- * @throws IndexOutOfBoundsException - if pos less 0 OR pos greater-equal
- * size()
+ * @throws IndexOutOfBoundsException - if pos less 0 OR pos greater-equal size()
* @return
*/
- private boolean removeAt(int pos, E e)
- {
- if (pos < 0 || pos >= size())
- {
+ private boolean removeAt(int pos, E e) {
+ if (pos < 0 || pos >= size()) {
throw new IndexOutOfBoundsException(pos + " is out of bounds");
- }
+ }
//1.list is empty
- if (isEmpty())
- {
+ if (isEmpty()) {
return false;
- }
- //2. one node exists
- else if (size() == 1)
- {
+ } //2. one node exists
+ else if (size() == 1) {
this.head = this.tail = null;
- }
- //3. remove in the front( head)
- else if (pos == 0)
- {
+ } //3. remove in the front( head)
+ else if (pos == 0) {
this.head = this.head.r;
head.l = null;
- }
- //4. remove in the end ( tail)
- else if (pos == size() - 1)
- {
+ } //4. remove in the end ( tail)
+ else if (pos == size() - 1) {
this.tail = this.tail.l;
this.tail.r = null;
- }
-
- //5. remove in the middle ( at least 3 nodes are in the queue)
- else
- {
+ } //5. remove in the middle ( at least 3 nodes are in the queue)
+ else {
Node p = head;
- for (int i = 0; i < pos - 1; ++i)
- {
+ for (int i = 0; i < pos - 1; ++i) {
p = p.r;
- }
+ }
p.r = p.r.r;
p.r.l = p;
- }
+ }
return true;
}
-
+ /**
+ * Returns {@code true} if this collection contains all of the elements
+ * in the specified collection.
+ *
+ * @param c collection to be checked for containment in this collection
+ * @return {@code true} if this collection contains all of the elements
+ * in the specified collection
+ * @throws ClassCastException if the types of one or more elements
+ * in the specified collection are incompatible with this
+ * collection
+ * ({@linkplain Collection##optional-restrictions optional})
+ * @throws NullPointerException if the specified collection contains one
+ * or more null elements and this collection does not permit null
+ * elements
+ * ({@linkplain Collection##optional-restrictions optional})
+ * or if the specified collection is null.
+ * @see #contains(Object)
+ */
@Override
- public boolean containsAll(Collection> c)
- {
+ public boolean containsAll(Collection> c) {
throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
}
/**
- * Adds all of the elements in the specified collection to this collection
- * (optional operation). The behavior of this operation is undefined if the
- * specified collection is modified while the operation is in progress.
- * (This implies that the behavior of this call is undefined if the
- * specified collection is this collection, and this collection is
- * nonempty.)
+ * Adds all of the elements in the specified collection to this collection (optional operation). The behavior of this operation is undefined if the specified collection is modified while the operation is in progress. (This implies that the behavior of this call is undefined if the specified collection is this collection, and this collection is nonempty.)
*
* @param c - collection containing elements to be added to this collection
- * @throws ClassCastException - if the class of an element of the specified
- * collection prevents it from being added to this collection.
- * @throws NullPointerException - if the specified collection contains a
- * null element and this collection does not permit null elements, or if the
- * specified collection is null
- * @throws IllegalArgumentException - if some property of an element of the
- * specified collection prevents it from being added to this collection
- * @throws IllegalArgumentException - if some property of an element of the
- * specified collection prevents it from being added to this collection
+ * @throws ClassCastException - if the class of an element of the specified collection prevents it from being added to this collection.
+ * @throws NullPointerException - if the specified collection contains a null element and this collection does not permit null elements, or if the specified collection is null
+ * @throws IllegalArgumentException - if some property of an element of the specified collection prevents it from being added to this collection
+ * @throws IllegalArgumentException - if some property of an element of the specified collection prevents it from being added to this collection
* @return true if this collection changed as a result of the call
*/
@Override
- public boolean addAll(Collection extends E> c)
- {
+ public boolean addAll(Collection extends E> c) {
int sizeBefore = size();
- for (E e : c)
- {
+ for (E e : c) {
add(e);
- }
+ }
int sizeAfter = size();
return sizeAfter > sizeBefore;
}
@Override
- public boolean removeAll(Collection> c)
- {
+ public boolean removeAll(Collection> c) {
throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
}
@Override
- public boolean retainAll(Collection> c)
- {
+ public boolean retainAll(Collection> c) {
throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
}
@Override
- public void clear()
- {
- // head = tail = null;
-
+ public void clear() {
+ // head = tail = null;
+
//extra, no necessary to set the link of every node
- Node p = head ;
- while ( p != tail )
- {
- p = p.r;
- p.l = null;
- }
+ Node p = head;
+ while (p != tail) {
+ p = p.r;
+ p.l = null;
+ }
head = tail = null;
}
@Override
- public void forEach(Consumer super E> action)
- {
+ public void forEach(Consumer super E> action) {
//1. use a pointer that points to the head
//2. while the pointer has not reached the end of the queue
//consume it
Node p = head;
- while ( p != null)
- {
+ while (p != null) {
action.accept(p.e);
p = p.r;
- }
-
+ }
+
}
@Override
- public String toString()
- {
+ public String toString() {
String s = "PriorityQueueASDV {";
Node p = head;
- while (p != null)
- {
+ while (p != null) {
s += p.e.toString();
- if (p != tail)
- {
+ if (p != tail) {
s += ", ";
- }
+ }
p = p.r;
- }
+ }
s += "}";
return s;
}
@Override
- protected Object clone()
- throws CloneNotSupportedException
- {
- PriorityQueueASDV c = ( PriorityQueueASDV ) super.clone();
- return c;
+ protected Object clone()
+ throws CloneNotSupportedException {
+ PriorityQueueASDV c = (PriorityQueueASDV) super.clone();
+ return c;
}
- public static void main(String[] args)
- {
+ public static void main(String[] args) {
System.out.println("\n--> PriorityQueueASDV testing add");
PriorityQueueASDV pq1 = new PriorityQueueASDV();
pq1.add("Paris");
@@ -629,44 +647,32 @@ public class PriorityQueueASDV>
System.out.println(pq2);
System.out.println("\n\t offer null");
- try
- {
+ try {
pq1.offer(null);
- }
- catch (Exception e)
- {
+ } catch (Exception e) {
System.err.println(e);
- }
+ }
- try
- {
+ try {
pq2.offer(null);
- }
- catch (Exception e)
- {
+ } catch (Exception e) {
System.err.println(e);
- }
+ }
System.out.println(pq1);
System.out.println(pq2);
System.out.println("\n\t offer ClassCastException with Object");
- try
- {
+ try {
pq1.offer((String) new Object());
- }
- catch (Exception e)
- {
+ } catch (Exception e) {
System.err.println(e);
- }
+ }
- try
- {
+ try {
pq2.offer((String) new Object());
- }
- catch (Exception e)
- {
+ } catch (Exception e) {
System.err.println(e);
- }
+ }
System.out.println(pq1);
System.out.println(pq2);
@@ -680,55 +686,43 @@ public class PriorityQueueASDV>
Iterator it1 = pq1.iterator();
Iterator it2 = pq2.iterator();
- while (it1.hasNext())
- {
+ while (it1.hasNext()) {
System.out.print(it1.next() + " ");
- }
+ }
System.out.println("");
- while (it2.hasNext())
- {
+ while (it2.hasNext()) {
System.out.print(it2.next() + " ");
- }
+ }
System.out.println("");
System.out.println("\n\t Iterator NoSuchElementException ");
- try
- {
+ try {
System.out.println(it1.next());
- }
- catch (NoSuchElementException e)
- {
+ } catch (NoSuchElementException e) {
System.err.println(e);
- }
- try
- {
+ }
+ try {
System.out.println(it2.next());
- }
- catch (NoSuchElementException e)
- {
+ } catch (NoSuchElementException e) {
System.err.println(e);
- }
+ }
System.out.println("\n\t Iterator foreach ");
it1 = pq1.iterator();
it2 = pq2.iterator();
- it1.forEachRemaining(new Consumer()
- {
+ it1.forEachRemaining(new Consumer() {
@Override
- public void accept(Object t)
- {
+ public void accept(Object t) {
System.out.print(t + "*** ");
}
});
System.out.println("");
- it2.forEachRemaining(new Consumer()
- {
+ it2.forEachRemaining(new Consumer() {
@Override
- public void accept(Object t)
- {
+ public void accept(Object t) {
System.out.print(t + "+++ ");
}
});
@@ -740,14 +734,14 @@ public class PriorityQueueASDV>
pq2.addAll(ar1);
System.out.println(pq1);
System.out.println(pq2);
-
- System.out.println("\n\t clear" );
+
+ System.out.println("\n\t clear");
pq1.clear();
pq2.clear();
System.out.println(pq1);
System.out.println(pq2);
System.out.println("");
-
+
System.out.println("\n--> PriorityQueueASDV recreate priority queues from empty");
pq1.add("Paris");
pq1.add("Athens");
@@ -763,37 +757,72 @@ public class PriorityQueueASDV>
pq2.add("Berlin");
pq2.add("Zurich");
System.out.println(pq1);
- System.out.println(pq2);
-
+ System.out.println(pq2);
+
System.out.println("\n\t forEach");
- pq1.forEach(new Consumer(){
+ pq1.forEach(new Consumer() {
@Override
- public void accept(Object t)
- {
- System.out.print( t + "*** ");
+ public void accept(Object t) {
+ System.out.print(t + "*** ");
}
});
System.out.println("");
- pq2.forEach(new Consumer(){
+ pq2.forEach(new Consumer() {
@Override
- public void accept(Object t)
- {
- System.out.print( t + "+++ ");
+ public void accept(Object t) {
+ System.out.print(t + "+++ ");
}
});
System.out.println("");
System.out.println("\n\t clone");
- try{PriorityQueueASDV pq1Cloned =
- ( PriorityQueueASDV) pq1.clone();
- System.out.println(pq1Cloned);
- pq1Cloned.add("Las Vegas");
- System.out.println(pq1Cloned);
- System.out.println(pq1);
+ try {
+ PriorityQueueASDV pq1Cloned
+ = (PriorityQueueASDV) pq1.clone();
+ System.out.println(pq1Cloned);
+ pq1Cloned.add("Las Vegas");
+ System.out.println(pq1Cloned);
+ System.out.println(pq1);
- }
- catch(CloneNotSupportedException e ){System.err.println(e);}
-
-
+ } catch (CloneNotSupportedException e) {
+ System.err.println(e);
+ }
+ pq1.clear();
+ pq2.clear();
+ pq1.add("Paris");
+ pq1.add("Athens");
+ pq1.add("London");
+ pq1.add("Lafayette");
+ pq1.add("Berlin");
+ pq1.add("Zurich");
+
+ pq2.add("Paris");
+ pq2.add("Athens");
+ pq2.add("London");
+ pq2.add("Lafayette");
+ pq2.add("Berlin");
+ pq2.add("Zurich");
+ System.out.println("----------------");
+ System.out.println(pq1);
+ System.out.println(pq2);
+
+ System.out.println("Attempt to remove an element.");
+ pq1.remove();
+ pq2.remove();
+ System.out.println(pq1);
+ System.out.println(pq2);
+ System.out.println("Get array of the priority queues.");
+ Object pqArray1[] = pq1.toArray();
+ Object pqArray2[] = pq2.toArray();
+
+ printArrays(pqArray1);
+ printArrays(pqArray2);
+ }
+
+ static void printArrays(Object[] arr) {
+ for (Object element : arr) {
+ System.out.print(element + ", ");
+ }
+ System.out.println();
}
}
diff --git a/Semester 3/ZIPs/MP5-Binary-Files_CalebFontenot.zip b/Semester 3/ZIPs/MP5-Binary-Files_CalebFontenot.zip
index 4d43c54..b14f978 100644
Binary files a/Semester 3/ZIPs/MP5-Binary-Files_CalebFontenot.zip and b/Semester 3/ZIPs/MP5-Binary-Files_CalebFontenot.zip differ