diff --git a/Summer-2024/CS-3443/Labs/Lab2/README.org b/Summer-2024/CS-3443/Labs/Lab2/README.org index 3095285..5f0690a 100644 --- a/Summer-2024/CS-3443/Labs/Lab2/README.org +++ b/Summer-2024/CS-3443/Labs/Lab2/README.org @@ -1,8 +1,8 @@ -* Lab 1 Submission +* Lab 2 Submission Name: =Price Hiller= ABC123: =zfp106= -Date: =2024-06-12= -URL: [[https://git.orion-technologies.io/Price/college/src/branch/Development/Summer-2024/CS-3443/Labs/Lab1]] +Date: =2024-06-22= +URL: [[https://git.orion-technologies.io/Price/college/src/branch/Development/Summer-2024/CS-3443/Labs/Lab2]] ** Running the program @@ -25,4 +25,4 @@ Recording of the program running: [[file:./assets/run-recording.webm]] - Click =Run= *** via Maven -If you have Maven installed, you can easily run this program when at the top level of the project via ~mvn exec:java -Dexec.mainClass="com.zfp106.lab1.Lab1"~. +If you have Maven installed, you can easily run this program when at the top level of the project via ~mvn exec:java -Dexec.mainClass="com.zfp106.lab2.Lab2"~. diff --git a/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/CrewMember.java b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/CrewMember.java new file mode 100644 index 0000000..5252c7e --- /dev/null +++ b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/CrewMember.java @@ -0,0 +1,69 @@ +package com.zfp106.lab2; + +public class CrewMember { + private String name; + private String position; + private String rank; + private String species; + private String assignment; + + public CrewMember(String name, String position, String rank, String species, String assignment) { + this.setName(name); + this.setPosition(position); + this.setRank(rank); + this.setSpecies(species); + this.setAssignment(assignment); + } + + public CrewMember(String name, String position, String rank, String species) { + this.setName(name); + this.setPosition(position); + this.setRank(rank); + this.setSpecies(species); + } + + public String toString() { + return String.format( + "%s (%s) - %s [%s]", this.getName(), this.getRank(), this.getPosition(), this.getSpecies()); + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getPosition() { + return position; + } + + public void setPosition(String position) { + this.position = position; + } + + public String getRank() { + return rank; + } + + public void setRank(String rank) { + this.rank = rank; + } + + public String getSpecies() { + return species; + } + + public void setSpecies(String species) { + this.species = species; + } + + public String getAssignment() { + return assignment; + } + + public void setAssignment(String assignment) { + this.assignment = assignment; + } +} diff --git a/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Fleet.java b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Fleet.java new file mode 100644 index 0000000..8eda2af --- /dev/null +++ b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Fleet.java @@ -0,0 +1,78 @@ +package com.zfp106.lab2; + +import java.io.File; +import java.io.IOException; +import java.nio.file.Paths; +import java.util.ArrayList; + +/** + * Represents a fleet of starships + * + *

Each fleet has the following: - A name - Starships said fleet contains + */ +public class Fleet { + private String name; + private ArrayList starships; + + public Fleet(String name) { + this.setName(name); + this.setStarships(new ArrayList()); + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public ArrayList getStarships() { + return starships; + } + + public void setStarships(ArrayList starships) { + this.starships = starships; + } + + public String toString() { + String out = + String.format( + "----------------------------\n\n%s\n\n----------------------------\n", this.getName()); + StringBuilder starships = new StringBuilder(); + for (Starship starship : this.getStarships()) { + starships.append("\n" + starship.toString() + "\n"); + } + out = out + starships.toString(); + return out; + } + + public void loadStarships(String starshipsDirectoryStr) throws IOException { + File[] starshipFiles = Paths.get(starshipsDirectoryStr).toFile().listFiles(); + Integer curFile = 0; + Integer remainingFiles = starshipFiles.length; + // This is, imo, not *great* code, but it gets the job done. Based on the assignment + // requirements, the files are loaded in a weird order. To support said order, I iterate + // backwards using modulo arithmetic to wrap values to their positive counterparts. If we + // encounter an already read file, we keep reading backwards by one until we hit an unread + // file. + while (remainingFiles > 0) { + // Read two values backwards and wrap positively + curFile = Math.floorMod(curFile - 2, starshipFiles.length); + // If the current "found" file has already been read, starting going one + // back over an over until we find an unread file + while (starshipFiles[curFile] == null) { + curFile--; + if (curFile < 0) { + curFile = Math.floorMod(curFile, starshipFiles.length); + } + } + // Once we locate a file, load it and then mark the file as read by setting it to null + if (starshipFiles[curFile] != null) { + this.starships.add(Starship.loadStarshipFromPath(starshipFiles[curFile].toPath())); + starshipFiles[curFile] = null; + remainingFiles--; + } + } + } +} diff --git a/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Lab2.java b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Lab2.java index 53c140a..02f7cff 100644 --- a/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Lab2.java +++ b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Lab2.java @@ -1,28 +1,26 @@ +package com.zfp106.lab2; + /** - * Lab2 is a Java class containing a main method to run your program when completed. - * This class will not compile until you have completed the requirements outlined in - * the lab description. + * Lab2 is a Java class containing a main method to run your program when completed. This class will + * not compile until you have completed the requirements outlined in the lab description. * - * @author Amanda Fernandez (abc123) - * UTSA CS 3443 - Lab 2 - * Fall 2022 + * @author Price Hiller (zfp106) UTSA CS 3443 - Lab 2 Fall 2024 */ public class Lab2 { - public static void main( String[] args ) { + public static void main(String[] args) { - Fleet unitedFederation = new Fleet( "United Federation of Planets" ); + Fleet unitedFederation = new Fleet("United Federation of Planets"); - try { - unitedFederation.loadStarships( "data" ); + try { + unitedFederation.loadStarships("data"); - }catch( Exception e ) { - // this is a try/catch which will show any errors to the console (more on these in coming weeks!) - e.printStackTrace(); - } - - System.out.println( unitedFederation ); - - } + } catch (Exception e) { + // this is a try/catch which will show any errors to the console (more on these + // in coming weeks!) + e.printStackTrace(); + } + System.out.println(unitedFederation); + } } diff --git a/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Starship.java b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Starship.java new file mode 100644 index 0000000..b7e7cb7 --- /dev/null +++ b/Summer-2024/CS-3443/Labs/Lab2/src/main/java/com/zfp106/lab2/Starship.java @@ -0,0 +1,102 @@ +package com.zfp106.lab2; + +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.util.ArrayList; +import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.Stream; + +public class Starship { + private String name; + private String registry; + private String starshipClass; + private ArrayList crew; + + public Starship(String name, String registry, String starship_class) { + this.setName(name); + this.setRegistry(registry); + this.setStarshipClass(starship_class); + this.setCrew(new ArrayList()); + } + + public String toString() { + String out = + String.format( + "%s, %s. Registry: %s\n\n%d crew members assigned.", + this.getName(), + this.getStarshipClass(), + this.getRegistry(), + this.getNumberOfPersonnel()); + StringBuilder crew = new StringBuilder(); + for (CrewMember crewMember : this.getCrew()) { + crew.append("\n\n - " + crewMember.toString()); + } + out = out + crew.toString(); + return out; + } + + public void addCrewMember(CrewMember crewMember) { + if (!this.crew.contains(crewMember)) { + this.crew.add(crewMember); + } + } + + public Integer getNumberOfPersonnel() { + return this.crew.size(); + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getRegistry() { + return registry; + } + + public void setRegistry(String registry) { + this.registry = registry; + } + + public ArrayList getCrew() { + return crew; + } + + public void setCrew(ArrayList crew) { + this.crew = crew; + } + + public String getStarshipClass() { + return starshipClass; + } + + public void setStarshipClass(String starshipClass) { + this.starshipClass = starshipClass; + } + + public static Starship loadStarshipFromPath(Path filePath) throws IOException { + List starshipInfo = new ArrayList(); + try (Stream lines = Files.lines(filePath)) { + starshipInfo = lines.collect(Collectors.toList()); + } + // First element of the starship file is the the starship name, registry, and + // class + String[] header = starshipInfo.remove(0).split(","); + Starship starship = new Starship(header[0], header[1], header[2]); + // Then we go through and grab all the crew members assigned to the starship and + // add 'em to + // the starship + for (String crewMemberLine : starshipInfo) { + String[] crewMemberInfo = crewMemberLine.split(","); + starship.addCrewMember( + new CrewMember( + crewMemberInfo[0], crewMemberInfo[1], crewMemberInfo[2], crewMemberInfo[3])); + } + return starship; + } +} diff --git a/Summer-2024/CS-3443/Labs/Lab2/src/test/java/com/zfp106/lab2/Lab2Test.java b/Summer-2024/CS-3443/Labs/Lab2/src/test/java/com/zfp106/lab2/Lab2Test.java index e69de29..e09d2bc 100644 --- a/Summer-2024/CS-3443/Labs/Lab2/src/test/java/com/zfp106/lab2/Lab2Test.java +++ b/Summer-2024/CS-3443/Labs/Lab2/src/test/java/com/zfp106/lab2/Lab2Test.java @@ -0,0 +1,81 @@ +package com.zfp106.lab2; + +import static org.junit.jupiter.api.Assertions.assertEquals; + +import org.junit.jupiter.api.Test; + +class FleetTests { + @Test + void fleetStringReprIsCorrect() { + Fleet fleet = new Fleet("United Federation of Planets"); + try { + fleet.loadStarships("data"); + } catch (Exception e) { + e.printStackTrace(); + } + + String expected = "----------------------------\n" + + "\n" + + "United Federation of Planets\n" + + "\n" + + "----------------------------\n" + + "\n" + + "USS Endeavour, Nebula. Registry: NCC-71805\n" + + "\n" + + "0 crew members assigned.\n" + + "\n" + + "USS Bozeman, Sovereign. Registry: NCC-1941-A\n" + + "\n" + + "0 crew members assigned.\n" + + "\n" + + "USS Enterprise, Constitution. Registry: NCC-1701-A\n" + + "\n" + + "8 crew members assigned.\n" + + "\n" + + " - James T. Kirk (Captain) - Commanding Officer [Human]\n" + + "\n" + + " - Spock (Commander) - First Officer [Vulcan/Human]\n" + + "\n" + + " - Leonard McCoy (Lieutenant Commander) - Chief Medical Officer [Human]\n" + + "\n" + + " - Montgomery Scott (Lieutenant Commander) - Chief Engineering Officer [Human]\n" + + "\n" + + " - Christine Chapel (Crewman) - Nurse [Human]\n" + + "\n" + + " - Nyota Uhura (Lieutenant) - Communications Officer [Human]\n" + + "\n" + + " - Hikaru Sulu (Lieutenant) - Helmsman [Human]\n" + + "\n" + + " - Pavel Chekov (Ensign) - Navigator [Human]\n" + + "\n" + + "USS Bozeman, Soyuz. Registry: NCC-1941\n" + + "\n" + + "0 crew members assigned.\n" + + "\n" + + "USS Enterprise, Galaxy. Registry: NCC-1701-D\n" + + "\n" + + "8 crew members assigned.\n" + + "\n" + + " - Jean-Luc Picard (Captain) - Commanding Officer [Human]\n" + + "\n" + + " - William T. Riker (Commander) - First Officer [Human]\n" + + "\n" + + " - Beverly Crusher (Lieutenant Commander) - Chief Medical Officer [Human]\n" + + "\n" + + " - Geordi La Forge (Lieutenant) - Chief Engineering Officer [Human]\n" + + "\n" + + " - Deanna Troi (Lieutenant Commander) - Counselor [Betazoid]\n" + + "\n" + + " - Worf (Lieutenant) - Helmsman [Klingon]\n" + + "\n" + + " - Data (Lieutenant Commander) - Chief Operations Officer [Android]\n" + + "\n" + + " - Tasha Yar (Lieutenant) - Chief Security Officer [Human]\n" + + "\n" + + "USS Gibraltar, Sovereign. Registry: NCC-75689\n" + + "\n" + + "0 crew members assigned.\n"; + + assertEquals(expected, fleet.toString()); + } +}