cs-3443: finish up lab2 with uml
This commit is contained in:
parent
aca6abf2ef
commit
958aeef38f
67
Summer-2024/CS-3443/Labs/Lab2/Layout.puml
Normal file
67
Summer-2024/CS-3443/Labs/Lab2/Layout.puml
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
@startuml
|
||||||
|
skinparam classAttributeIconSize 0
|
||||||
|
class CrewMember {
|
||||||
|
- name: String
|
||||||
|
- position: String
|
||||||
|
- rank: String
|
||||||
|
- species: String
|
||||||
|
- assignment: String
|
||||||
|
+ <<constructor>> CrewMember(name: String, position: String, rank: String, species: String, assignment: String)
|
||||||
|
+ <<constructor>> CrewMember(name: String, position: String, rank: String, species: String)
|
||||||
|
+ toString(): String
|
||||||
|
+ getName(): String
|
||||||
|
+ setName(name: String)
|
||||||
|
+ getPosition(): String
|
||||||
|
+ setPosition(position: String)
|
||||||
|
+ getRank(): String
|
||||||
|
+ setRank(rank: String)
|
||||||
|
+ getSpecies(): String
|
||||||
|
+ setSpecies(species: String)
|
||||||
|
+ getAssignment(): String
|
||||||
|
+ setAssignment(assignment: String)
|
||||||
|
}
|
||||||
|
|
||||||
|
skinparam classAttributeIconSize 0
|
||||||
|
class Starship {
|
||||||
|
- name: String
|
||||||
|
- registry: String
|
||||||
|
- starshipClass: String
|
||||||
|
- crew: ArrayList<CrewMember>
|
||||||
|
+ <<constructor>> Starship(name: String, registry: String, starshipClass: String)
|
||||||
|
+ toString(): String
|
||||||
|
+ addCrewMember(crewMember: CrewMember)
|
||||||
|
+ getNumberOfPersonnel(): Integer
|
||||||
|
+ getName(): String
|
||||||
|
+ setName(name: String)
|
||||||
|
+ getRegistry(): String
|
||||||
|
+ setRegistry(registry: String)
|
||||||
|
+ getCrew(): ArrayList<CrewMember>
|
||||||
|
+ setCrew(crew: ArrayList<CrewMember>)
|
||||||
|
+ getStarshipClass(): String
|
||||||
|
+ setStarshipClass(starshipClass: String)
|
||||||
|
}
|
||||||
|
|
||||||
|
skinparam classAttributeIconSize 0
|
||||||
|
class Fleet {
|
||||||
|
- name: String
|
||||||
|
- starships: ArrayList<Starship>
|
||||||
|
+ <<constructor>> Fleet(name: String)
|
||||||
|
+ toString(): String
|
||||||
|
+ getSizeOfFleet(): Integer
|
||||||
|
+ addStarship(starship: Starship)
|
||||||
|
+ getName(): String
|
||||||
|
+ setName(name: String)
|
||||||
|
+ getStarships(): ArrayList<Starship>
|
||||||
|
+ setStarships(starships: ArrayList<Starship>)
|
||||||
|
+ loadStarships(starshipsDirectory: String)
|
||||||
|
}
|
||||||
|
|
||||||
|
skinparam classAttributeIconSize 0
|
||||||
|
class Lab2 {
|
||||||
|
+ _ main(args: String[]): void
|
||||||
|
}
|
||||||
|
|
||||||
|
Fleet o-- Starship
|
||||||
|
Starship o-- CrewMember
|
||||||
|
Lab2 ..|> Fleet
|
||||||
|
@enduml
|
1
Summer-2024/CS-3443/Labs/Lab2/Layout.svg
Normal file
1
Summer-2024/CS-3443/Labs/Lab2/Layout.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 14 KiB |
@ -4,21 +4,31 @@ ABC123: =zfp106=
|
|||||||
Date: =2024-06-22=
|
Date: =2024-06-22=
|
||||||
URL: [[https://git.orion-technologies.io/Price/college/src/branch/Development/Summer-2024/CS-3443/Labs/Lab2]]
|
URL: [[https://git.orion-technologies.io/Price/college/src/branch/Development/Summer-2024/CS-3443/Labs/Lab2]]
|
||||||
|
|
||||||
|
** UML Diagram
|
||||||
|
|
||||||
|
#+ATTR_HTML: :alt :align left :class img
|
||||||
|
[[./Layout.svg][UML Diagram of the program]]
|
||||||
|
|
||||||
|
You can see the HTML rendering at [[./UML.html]]
|
||||||
|
|
||||||
** Running the program
|
** Running the program
|
||||||
|
|
||||||
Recording of the program running: [[file:./assets/run-recording.webm]]
|
Recording of the program running: [[file:./assets/run-recording.webm]]
|
||||||
|
|
||||||
|
To operate correctly the program must be ran from the top level directory!
|
||||||
|
|
||||||
*** via Eclipse
|
*** via Eclipse
|
||||||
|
|
||||||
- Open Eclipse
|
- Open Eclipse
|
||||||
- Select File
|
- Select File
|
||||||
- Select Import
|
- Select Import
|
||||||
- In the dialogue that appears, expand =General=
|
- In the dialogue that appears, expand =General=
|
||||||
- Select =Archive File=
|
- Select =Existing Projects into Workspace=
|
||||||
- Click =Next=
|
- Click =Next=
|
||||||
- In the top right of the new menu, select =Browse...=
|
- Select =Select archive file:=
|
||||||
|
- To the right of that dialogue click =Browse...=
|
||||||
- Find the archive on your file system and select it
|
- Find the archive on your file system and select it
|
||||||
- Select a valid path for =Into folder:=
|
- Click =Add project to working sets=
|
||||||
- Click =Finish=
|
- Click =Finish=
|
||||||
- Select the project on the left bar
|
- Select the project on the left bar
|
||||||
- On the top bar, expand the =Run= category
|
- On the top bar, expand the =Run= category
|
||||||
@ -26,3 +36,5 @@ Recording of the program running: [[file:./assets/run-recording.webm]]
|
|||||||
|
|
||||||
*** via Maven
|
*** 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.lab2.Lab2"~.
|
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"~.
|
||||||
|
|
||||||
|
Tests can be run via ~mvn test~ from the top level of the project as well.
|
||||||
|
66
Summer-2024/CS-3443/Labs/Lab2/UML.html
Normal file
66
Summer-2024/CS-3443/Labs/Lab2/UML.html
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html lang="en">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8" />
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||||||
|
<title>zfp106 UML Diagram for Lab2</title>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<h1 style="color: red; background: yellow">
|
||||||
|
Made with <u>infinite, undying, <i>hatred</i></u> in PlantUML (Lab2,
|
||||||
|
zfp106)
|
||||||
|
</h1>
|
||||||
|
<p>
|
||||||
|
Some notes on the decisions made here.
|
||||||
|
<table border=1>
|
||||||
|
<tr>
|
||||||
|
<th>Question</th>
|
||||||
|
<th>Answer</th>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Why is <code>Starship</code> associated to <code>CrewMember</code> via
|
||||||
|
aggregation?</td>
|
||||||
|
<td>Because a <code>Starship</code> has 0 or more crew members and crew
|
||||||
|
members aren't dependent on a <code>Starship</code> to exist. It is possible for a
|
||||||
|
crew member to not be assigned to <i>any</i>
|
||||||
|
<code>Starship</code>.
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
Why is <code>Fleet</code> associated to <code>Starship</code> via aggregation?
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
Same reason as the previous. It is possible for a fleet to exist in name
|
||||||
|
only without any Starships contained within at all. A fleet is quite
|
||||||
|
literally an aggregation of any <i>n</i> number of ships in the first
|
||||||
|
place anyhow.
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Why does <code>Lab2</code> with its <code>main</code> method have a dependency
|
||||||
|
relationship with <code>Fleet</code>?</td>
|
||||||
|
<td>Because a near identical example of this relationship was in the slides. <q>We will
|
||||||
|
primarily use it for classes referenced in <strong><code>main</code></strong>.</q></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Why don't you show associations/other connections to Java standard library classes like
|
||||||
|
<code>ArrayList</code>?
|
||||||
|
</td>
|
||||||
|
<td>Because we can keep going down that rabbit hole until infinity (or by my count in my IDE ~5 - 6 levels of
|
||||||
|
indirection from any given Java standard lib class to the bottom of the chain). I'm not interested in showing
|
||||||
|
the full diagram all the way down until we hit the base <code>Object</code> class.</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
</table>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p><q>Your answers are wrong and you should feel bad.</q> Them's fighting words, and I have a
|
||||||
|
whole hill here to defend and die upon, sword gleaming in the midnight sun.</p>
|
||||||
|
<p><u>The actual UML diagram below:<u></p>
|
||||||
|
<img src="./Layout.svg" alt="Uml Diagram" />
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
Binary file not shown.
@ -1,10 +1,10 @@
|
|||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>org.zfp106.lab1</groupId>
|
<groupId>org.zfp106.lab2</groupId>
|
||||||
<artifactId>lab1</artifactId>
|
<artifactId>lab2</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<version>0.1</version>
|
<version>0.1</version>
|
||||||
<name>lab1</name>
|
<name>lab2</name>
|
||||||
<url>http://maven.apache.org</url>
|
<url>http://maven.apache.org</url>
|
||||||
<dependencyManagement>
|
<dependencyManagement>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
@ -37,7 +37,7 @@
|
|||||||
<configuration>
|
<configuration>
|
||||||
<archive>
|
<archive>
|
||||||
<manifest>
|
<manifest>
|
||||||
<mainClass>com.zfp106.lab1.Lab1</mainClass>
|
<mainClass>com.zfp106.lab2.lab2</mainClass>
|
||||||
</manifest>
|
</manifest>
|
||||||
</archive>
|
</archive>
|
||||||
</configuration>
|
</configuration>
|
||||||
|
@ -1,5 +1,12 @@
|
|||||||
package com.zfp106.lab2;
|
package com.zfp106.lab2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A crew member that can be assigned to a starship
|
||||||
|
*
|
||||||
|
* <p>A crew member has a name, a position, a rank, a species, and an assignment.
|
||||||
|
*
|
||||||
|
* <p>A crew member may not have an active assignment, meaning they're not assigned to a ship
|
||||||
|
*/
|
||||||
public class CrewMember {
|
public class CrewMember {
|
||||||
private String name;
|
private String name;
|
||||||
private String position;
|
private String position;
|
||||||
@ -7,6 +14,15 @@ public class CrewMember {
|
|||||||
private String species;
|
private String species;
|
||||||
private String assignment;
|
private String assignment;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new crew member with an active assignment to a starship
|
||||||
|
*
|
||||||
|
* @param name The name of the crew member
|
||||||
|
* @param position The position of the crew member
|
||||||
|
* @param rank The rank of the crew member
|
||||||
|
* @param species The species of the crew member
|
||||||
|
* @param assignment The ship registry the crew member is assigned to
|
||||||
|
*/
|
||||||
public CrewMember(String name, String position, String rank, String species, String assignment) {
|
public CrewMember(String name, String position, String rank, String species, String assignment) {
|
||||||
this.setName(name);
|
this.setName(name);
|
||||||
this.setPosition(position);
|
this.setPosition(position);
|
||||||
@ -15,6 +31,14 @@ public class CrewMember {
|
|||||||
this.setAssignment(assignment);
|
this.setAssignment(assignment);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new crew member with an active assignment to a starship
|
||||||
|
*
|
||||||
|
* @param name The name of the crew member
|
||||||
|
* @param position The position of the crew member
|
||||||
|
* @param rank The rank of the crew member
|
||||||
|
* @param species The species of the crew member
|
||||||
|
*/
|
||||||
public CrewMember(String name, String position, String rank, String species) {
|
public CrewMember(String name, String position, String rank, String species) {
|
||||||
this.setName(name);
|
this.setName(name);
|
||||||
this.setPosition(position);
|
this.setPosition(position);
|
||||||
@ -22,47 +46,102 @@ public class CrewMember {
|
|||||||
this.setSpecies(species);
|
this.setSpecies(species);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the string representation for the crew member
|
||||||
|
*
|
||||||
|
* @return String representation of the crew member
|
||||||
|
*/
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return String.format(
|
return String.format(
|
||||||
"%s (%s) - %s [%s]", this.getName(), this.getRank(), this.getPosition(), this.getSpecies());
|
"%s (%s) - %s [%s]", this.getName(), this.getRank(), this.getPosition(), this.getSpecies());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name of the crew member
|
||||||
|
*
|
||||||
|
* @return The name of the crew member
|
||||||
|
*/
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return this.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the name of the crew member
|
||||||
|
*
|
||||||
|
* @param name The new name for the crew member
|
||||||
|
*/
|
||||||
public void setName(String name) {
|
public void setName(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the position of the crew member
|
||||||
|
*
|
||||||
|
* @return The position of the crew member
|
||||||
|
*/
|
||||||
public String getPosition() {
|
public String getPosition() {
|
||||||
return position;
|
return this.position;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the position of the crew member
|
||||||
|
*
|
||||||
|
* @param position The new position for the crew member
|
||||||
|
*/
|
||||||
public void setPosition(String position) {
|
public void setPosition(String position) {
|
||||||
this.position = position;
|
this.position = position;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the rank of the crew member
|
||||||
|
*
|
||||||
|
* @return The rank of the crew member
|
||||||
|
*/
|
||||||
public String getRank() {
|
public String getRank() {
|
||||||
return rank;
|
return this.rank;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the rank of the crew member
|
||||||
|
*
|
||||||
|
* @param rank The new rank for the crew member
|
||||||
|
*/
|
||||||
public void setRank(String rank) {
|
public void setRank(String rank) {
|
||||||
this.rank = rank;
|
this.rank = rank;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the species of the crew member
|
||||||
|
*
|
||||||
|
* @return The species of the crew member
|
||||||
|
*/
|
||||||
public String getSpecies() {
|
public String getSpecies() {
|
||||||
return species;
|
return this.species;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the species of the crew member
|
||||||
|
*
|
||||||
|
* @param species The new species for the crew member
|
||||||
|
*/
|
||||||
public void setSpecies(String species) {
|
public void setSpecies(String species) {
|
||||||
this.species = species;
|
this.species = species;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the starship registry that the crew member is assigned to
|
||||||
|
*
|
||||||
|
* @return The starship registry that the crew member is assigned to
|
||||||
|
*/
|
||||||
public String getAssignment() {
|
public String getAssignment() {
|
||||||
return assignment;
|
return this.assignment;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the starship registry that the crew member is assigned to
|
||||||
|
*
|
||||||
|
* @param assignment The new starship registry to assign the crew member to
|
||||||
|
*/
|
||||||
public void setAssignment(String assignment) {
|
public void setAssignment(String assignment) {
|
||||||
this.assignment = assignment;
|
this.assignment = assignment;
|
||||||
}
|
}
|
||||||
|
@ -2,13 +2,17 @@ package com.zfp106.lab2;
|
|||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a fleet of starships
|
* Represents a fleet of starships
|
||||||
*
|
*
|
||||||
* <p>Each fleet has the following: - A name - Starships said fleet contains
|
* <p>Each fleet has a name and 0 or more starships
|
||||||
*/
|
*/
|
||||||
public class Fleet {
|
public class Fleet {
|
||||||
private String name;
|
private String name;
|
||||||
@ -19,22 +23,11 @@ public class Fleet {
|
|||||||
this.setStarships(new ArrayList<Starship>());
|
this.setStarships(new ArrayList<Starship>());
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
/**
|
||||||
return name;
|
* Get the string representation of a fleet
|
||||||
}
|
*
|
||||||
|
* @return string representation of the fleet
|
||||||
public void setName(String name) {
|
*/
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ArrayList<Starship> getStarships() {
|
|
||||||
return starships;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStarships(ArrayList<Starship> starships) {
|
|
||||||
this.starships = starships;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String out =
|
String out =
|
||||||
String.format(
|
String.format(
|
||||||
@ -47,8 +40,70 @@ public class Fleet {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadStarships(String starshipsDirectoryStr) throws IOException {
|
/**
|
||||||
File[] starshipFiles = Paths.get(starshipsDirectoryStr).toFile().listFiles();
|
* Get the number of ships in the fleet
|
||||||
|
*
|
||||||
|
* @return Number of ships in the fleet
|
||||||
|
*/
|
||||||
|
public Integer getSizeOfFleet() {
|
||||||
|
return this.getStarships().size();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a starship to the fleet
|
||||||
|
*
|
||||||
|
* @param starship A starship to add to the fleet
|
||||||
|
*/
|
||||||
|
public void addStarship(Starship starship) {
|
||||||
|
if (!this.getStarships().contains(starship)) {
|
||||||
|
this.starships.add(starship);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name of the fleet
|
||||||
|
*
|
||||||
|
* @return name of the fleet
|
||||||
|
*/
|
||||||
|
public String getName() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the name of the fleet
|
||||||
|
*
|
||||||
|
* @param name New name for the fleet
|
||||||
|
*/
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all the starships in the fleet
|
||||||
|
*
|
||||||
|
* @return starships in the fleet
|
||||||
|
*/
|
||||||
|
public ArrayList<Starship> getStarships() {
|
||||||
|
return this.starships;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the fleet's starship's to a new list of ships
|
||||||
|
*
|
||||||
|
* @param starships New starship's to set for the fleet
|
||||||
|
*/
|
||||||
|
public void setStarships(ArrayList<Starship> starships) {
|
||||||
|
this.starships = starships;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load many starships from a given directory
|
||||||
|
*
|
||||||
|
* @param starshipsDirectory A directory containing one or more csv files with starship data
|
||||||
|
* @throws IOException When a valid csv file cannot be read
|
||||||
|
*/
|
||||||
|
public void loadStarships(String starshipsDirectory) throws IOException {
|
||||||
|
File[] starshipFiles = Paths.get(starshipsDirectory).toFile().listFiles();
|
||||||
Integer curFile = 0;
|
Integer curFile = 0;
|
||||||
Integer remainingFiles = starshipFiles.length;
|
Integer remainingFiles = starshipFiles.length;
|
||||||
// This is, imo, not *great* code, but it gets the job done. Based on the assignment
|
// This is, imo, not *great* code, but it gets the job done. Based on the assignment
|
||||||
@ -68,7 +123,24 @@ public class Fleet {
|
|||||||
}
|
}
|
||||||
// Once we locate a file, load it and then mark the file as read by setting it to null
|
// Once we locate a file, load it and then mark the file as read by setting it to null
|
||||||
if (starshipFiles[curFile] != null) {
|
if (starshipFiles[curFile] != null) {
|
||||||
this.starships.add(Starship.loadStarshipFromPath(starshipFiles[curFile].toPath()));
|
List<String> starshipInfo = new ArrayList<String>();
|
||||||
|
try (Stream<String> lines = Files.lines(starshipFiles[curFile].toPath())) {
|
||||||
|
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(",");
|
||||||
|
String registry = header[1];
|
||||||
|
Starship starship = new Starship(header[0], registry, 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]));
|
||||||
|
}
|
||||||
|
this.addStarship(starship);
|
||||||
starshipFiles[curFile] = null;
|
starshipFiles[curFile] = null;
|
||||||
remainingFiles--;
|
remainingFiles--;
|
||||||
}
|
}
|
||||||
|
@ -1,26 +1,38 @@
|
|||||||
package com.zfp106.lab2;
|
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.ArrayList;
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A starship
|
||||||
|
*
|
||||||
|
* <p>Each starship has a name, a registry code, a class, and 0 or more crew members
|
||||||
|
*/
|
||||||
public class Starship {
|
public class Starship {
|
||||||
private String name;
|
private String name;
|
||||||
private String registry;
|
private String registry;
|
||||||
private String starshipClass;
|
private String starshipClass;
|
||||||
private ArrayList<CrewMember> crew;
|
private ArrayList<CrewMember> crew;
|
||||||
|
|
||||||
public Starship(String name, String registry, String starship_class) {
|
/**
|
||||||
|
* Instantiates a starship with the given name, registry, the class of starship, and an empty list
|
||||||
|
* of crew members.
|
||||||
|
*
|
||||||
|
* @param name The name of the starship
|
||||||
|
* @param registry The registry code of the starship
|
||||||
|
* @param starshipClass The class of the starship
|
||||||
|
*/
|
||||||
|
public Starship(String name, String registry, String starshipClass) {
|
||||||
this.setName(name);
|
this.setName(name);
|
||||||
this.setRegistry(registry);
|
this.setRegistry(registry);
|
||||||
this.setStarshipClass(starship_class);
|
this.setStarshipClass(starshipClass);
|
||||||
this.setCrew(new ArrayList<CrewMember>());
|
this.setCrew(new ArrayList<CrewMember>());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the string representation of a Starship
|
||||||
|
*
|
||||||
|
* @return string representation of a Starship
|
||||||
|
*/
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String out =
|
String out =
|
||||||
String.format(
|
String.format(
|
||||||
@ -37,64 +49,101 @@ public class Starship {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the given crew member to the starship and sets their assignment to the starship.
|
||||||
|
*
|
||||||
|
* <p>Note that this will reassign the crew member to the starship
|
||||||
|
*
|
||||||
|
* @param crewMember The crew member to assign to the starship
|
||||||
|
*/
|
||||||
public void addCrewMember(CrewMember crewMember) {
|
public void addCrewMember(CrewMember crewMember) {
|
||||||
if (!this.crew.contains(crewMember)) {
|
if (!this.crew.contains(crewMember)) {
|
||||||
|
crewMember.setAssignment(this.getRegistry());
|
||||||
this.crew.add(crewMember);
|
this.crew.add(crewMember);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the number of crew assigned to the starship
|
||||||
|
*
|
||||||
|
* @return The number of crew assigned to the starship
|
||||||
|
*/
|
||||||
public Integer getNumberOfPersonnel() {
|
public Integer getNumberOfPersonnel() {
|
||||||
return this.crew.size();
|
return this.getCrew().size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name of the starship
|
||||||
|
*
|
||||||
|
* @return The name of the starship
|
||||||
|
*/
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return this.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the name of the starship
|
||||||
|
*
|
||||||
|
* @param name New name for the starship
|
||||||
|
*/
|
||||||
public void setName(String name) {
|
public void setName(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the registry code of the starship
|
||||||
|
*
|
||||||
|
* @return The registry code of the starship
|
||||||
|
*/
|
||||||
public String getRegistry() {
|
public String getRegistry() {
|
||||||
return registry;
|
return this.registry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the registry code of the starship
|
||||||
|
*
|
||||||
|
* @param registry The new registry code for the starship
|
||||||
|
*/
|
||||||
public void setRegistry(String registry) {
|
public void setRegistry(String registry) {
|
||||||
this.registry = registry;
|
this.registry = registry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all of the crew assigned to the starship
|
||||||
|
*
|
||||||
|
* @return The crew assigned to the starship
|
||||||
|
*/
|
||||||
public ArrayList<CrewMember> getCrew() {
|
public ArrayList<CrewMember> getCrew() {
|
||||||
return crew;
|
return this.crew;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set all the crew members of the ship. This will replace the existing crew.
|
||||||
|
*
|
||||||
|
* @param crew The new crew members to assign to the ship
|
||||||
|
*/
|
||||||
public void setCrew(ArrayList<CrewMember> crew) {
|
public void setCrew(ArrayList<CrewMember> crew) {
|
||||||
this.crew = crew;
|
this.crew = new ArrayList<CrewMember>();
|
||||||
|
for (CrewMember crewMember : crew) {
|
||||||
|
this.addCrewMember(crewMember);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the class of the starship
|
||||||
|
*
|
||||||
|
* @return The class of the starship
|
||||||
|
*/
|
||||||
public String getStarshipClass() {
|
public String getStarshipClass() {
|
||||||
return starshipClass;
|
return this.starshipClass;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the starship's class
|
||||||
|
*
|
||||||
|
* @param starshipClass The new class for the starship
|
||||||
|
*/
|
||||||
public void setStarshipClass(String starshipClass) {
|
public void setStarshipClass(String starshipClass) {
|
||||||
this.starshipClass = starshipClass;
|
this.starshipClass = starshipClass;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Starship loadStarshipFromPath(Path filePath) throws IOException {
|
|
||||||
List<String> starshipInfo = new ArrayList<String>();
|
|
||||||
try (Stream<String> 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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user