Compare commits
2 commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
1b73889fd9 | ||
![]() |
2e199e8f1c |
2 changed files with 145 additions and 152 deletions
128
.github/workflows/rust.yml
vendored
128
.github/workflows/rust.yml
vendored
|
@ -2,99 +2,95 @@ name: Rust -> Build & Test & Release
|
|||
|
||||
on:
|
||||
push:
|
||||
branches: [ "main" ]
|
||||
branches: ["main"]
|
||||
|
||||
env:
|
||||
CARGO_TERM_COLOR: always
|
||||
PROJECT_NAME: ${{ github.event.repository.name }}
|
||||
|
||||
jobs:
|
||||
build_linux:
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
|
||||
- name: Upload Linux Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: banker_algorithm_linux_x64_86
|
||||
path: target/release/banker-algorithm
|
||||
- name: Upload Linux Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: ${{ env.PROJECT_NAME }}-linux-x64_86
|
||||
path: target/release/${{ env.PROJECT_NAME }}
|
||||
|
||||
build_windows:
|
||||
|
||||
runs-on: windows-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
|
||||
- name: Upload Windows Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: banker_algorithm_windows_x64_86
|
||||
path: target/release/banker-algorithm.exe
|
||||
- name: Upload Windows Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: ${{ env.PROJECT_NAME }}-windows-x64_86
|
||||
path: target/release/${{ env.PROJECT_NAME }}.exe
|
||||
|
||||
build_macos:
|
||||
|
||||
runs-on: macos-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build
|
||||
run: cargo build --release --verbose
|
||||
- name: Run tests
|
||||
run: cargo test --verbose
|
||||
|
||||
- name: Upload MacOS Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: banker_algorithm_macos_x64_86
|
||||
path: target/release/banker-algorithm
|
||||
- name: Upload MacOS Binary
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: ${{ env.PROJECT_NAME }}-macos-arm64
|
||||
path: target/release/${{ env.PROJECT_NAME }}
|
||||
|
||||
release:
|
||||
needs: [build_linux, build_windows, build_macos]
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: write
|
||||
permissions:
|
||||
contents: write
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Forge a Folder
|
||||
run: mkdir Downloads
|
||||
working-directory: /home/runner/work/${{ env.PROJECT_NAME }}/${{ env.PROJECT_NAME }}/
|
||||
|
||||
- uses: actions/checkout@v4
|
||||
- name: Forge a Folder
|
||||
run: mkdir Downloads
|
||||
working-directory: /home/runner/work/banker-algorithm/banker-algorithm/
|
||||
- uses: actions/download-artifact@v4
|
||||
name: Download
|
||||
with:
|
||||
path: Downloads/
|
||||
|
||||
- uses: actions/download-artifact@v4
|
||||
name: Download
|
||||
with:
|
||||
path: Downloads/
|
||||
|
||||
- name: Rename Binaries
|
||||
run: |
|
||||
mv Downloads/banker_algorithm_linux_x64_86/banker-algorithm Downloads/banker_algorithm_linux_x64_86/banker-algorithm-linux_x64_86
|
||||
mv Downloads/banker_algorithm_windows_x64_86/banker-algorithm.exe Downloads/banker_algorithm_windows_x64_86/banker-algorithm-windows_x64_86.exe
|
||||
mv Downloads/banker_algorithm_macos_x64_86/banker-algorithm Downloads/banker_algorithm_macos_x64_86/banker-algorithm-macos_x64_86
|
||||
- name: Rename Binaries
|
||||
run: |
|
||||
tree Downloads/
|
||||
mv Downloads/${{ env.PROJECT_NAME }}-linux-x64_86/${{ env.PROJECT_NAME }} Downloads/${{ env.PROJECT_NAME }}-linux-x64_86/${{ env.PROJECT_NAME }}-linux-x64_86
|
||||
mv Downloads/${{ env.PROJECT_NAME }}-windows-x64_86/${{ env.PROJECT_NAME }}.exe Downloads/${{ env.PROJECT_NAME }}-windows-x64_86/${{ env.PROJECT_NAME }}-windows-x64_86.exe
|
||||
mv Downloads/${{ env.PROJECT_NAME }}-macos-arm64/${{ env.PROJECT_NAME }} Downloads/${{ env.PROJECT_NAME }}-macos-arm64/${{ env.PROJECT_NAME }}-macos-arm64
|
||||
- name: Git Commit SHA
|
||||
id: vars
|
||||
run: |
|
||||
calculatedSha=$(git rev-parse --short ${{ github.sha }})
|
||||
echo "short_sha=$calculatedSha" >> $GITHUB_OUTPUT
|
||||
|
||||
- name: Git Commit SHA
|
||||
id: vars
|
||||
run: |
|
||||
calculatedSha=$(git rev-parse --short ${{ github.sha }})
|
||||
echo "short_sha=$calculatedSha" >> $GITHUB_OUTPUT
|
||||
|
||||
- uses: softprops/action-gh-release@v2
|
||||
name: Release
|
||||
with:
|
||||
tag_name: ${{ steps.vars.outputs.short_sha }}
|
||||
generate_release_notes: true
|
||||
files: |
|
||||
Downloads/*linux*/*banker*
|
||||
Downloads/*windows*/*banker*
|
||||
Downloads/*macos*/*banker*
|
||||
|
||||
- uses: softprops/action-gh-release@v2
|
||||
name: Release
|
||||
with:
|
||||
tag_name: ${{ steps.vars.outputs.short_sha }}
|
||||
generate_release_notes: true
|
||||
files: |
|
||||
Downloads/*linux*/${{ env.PROJECT_NAME }}*
|
||||
Downloads/*windows*/${{ env.PROJECT_NAME }}*
|
||||
Downloads/*macos*/${{ env.PROJECT_NAME }}*
|
||||
|
|
169
src/main.rs
169
src/main.rs
|
@ -3,56 +3,33 @@ use std::io;
|
|||
|
||||
const PROCESS_COUNT: usize = 5;
|
||||
const RESOURCE_COUNT: usize = 3;
|
||||
|
||||
fn main() {
|
||||
println!("Hello, world!");
|
||||
|
||||
let mut restart: bool = true;
|
||||
while restart {
|
||||
println!("Max A Resource");
|
||||
let mut resource_input: String = String::new();
|
||||
if let Err(err_val) = io::stdin().read_line(&mut resource_input) {
|
||||
println!("Failed to Read: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let a: u8 = match resource_input.trim().parse::<u8>() {
|
||||
Ok(value) => value,
|
||||
Err(err_val) => {
|
||||
println!("Failed to Convert: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let a = match get_u8_input() {
|
||||
Some(resource_input) => resource_input,
|
||||
None => return,
|
||||
};
|
||||
|
||||
println!("Max B Resource");
|
||||
let mut resource_input: String = String::new();
|
||||
if let Err(err_val) = io::stdin().read_line(&mut resource_input) {
|
||||
println!("Failed to Read: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let b = match resource_input.trim().parse::<u8>() {
|
||||
Ok(value) => value,
|
||||
Err(err_val) => {
|
||||
println!("Failed to Convert: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let b = match get_u8_input() {
|
||||
Some(resource_input) => resource_input,
|
||||
None => return,
|
||||
};
|
||||
|
||||
println!("Max C Resource");
|
||||
let mut resource_input: String = String::new();
|
||||
if let Err(err_val) = io::stdin().read_line(&mut resource_input) {
|
||||
println!("Failed to Read: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let c = match resource_input.trim().parse::<u8>() {
|
||||
Ok(value) => value,
|
||||
Err(err_val) => {
|
||||
println!("Failed to Convert: {}", err_val);
|
||||
return;
|
||||
}
|
||||
let c = match get_u8_input() {
|
||||
Some(resource_input) => resource_input,
|
||||
None => return,
|
||||
};
|
||||
|
||||
println!("\n\tA = {}\n\tB = {}\n\tC = {}", a, b, c);
|
||||
if a == 0 || b == 0 || c == 0 {
|
||||
println!("Exit: Zero as a Input Invalid");
|
||||
eprintln!("Exit: Zero as a Input is Invalid");
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -60,36 +37,13 @@ fn main() {
|
|||
let mut assigned_resources_matrix = [[0_u8; RESOURCE_COUNT]; PROCESS_COUNT];
|
||||
let mut info: (bool, Vec<u8>) = (false, Vec::with_capacity(PROCESS_COUNT));
|
||||
while !info.0 {
|
||||
for i in 0..PROCESS_COUNT {
|
||||
let mut rng = rand::thread_rng();
|
||||
let random = rng.gen_range(0..a);
|
||||
max_needs_matrix[i][0] = random;
|
||||
if random != 0 {
|
||||
assigned_resources_matrix[i][0] = rng.gen_range(0..random);
|
||||
} else {
|
||||
assigned_resources_matrix[i][0] = 0;
|
||||
}
|
||||
}
|
||||
for i in 0..PROCESS_COUNT {
|
||||
let mut rng = rand::thread_rng();
|
||||
let random = rng.gen_range(0..b);
|
||||
max_needs_matrix[i][1] = random;
|
||||
if random != 0 {
|
||||
assigned_resources_matrix[i][1] = rng.gen_range(0..random);
|
||||
} else {
|
||||
assigned_resources_matrix[i][1] = 0;
|
||||
}
|
||||
}
|
||||
for i in 0..PROCESS_COUNT {
|
||||
let mut rng = rand::thread_rng();
|
||||
let random = rng.gen_range(0..c);
|
||||
max_needs_matrix[i][2] = random;
|
||||
if random != 0 {
|
||||
assigned_resources_matrix[i][2] = rng.gen_range(0..random);
|
||||
} else {
|
||||
assigned_resources_matrix[i][2] = 0;
|
||||
}
|
||||
}
|
||||
assign_resource_matrix(
|
||||
&mut max_needs_matrix,
|
||||
&mut assigned_resources_matrix,
|
||||
a,
|
||||
b,
|
||||
c,
|
||||
);
|
||||
info = banker(a, b, c, max_needs_matrix, assigned_resources_matrix);
|
||||
}
|
||||
println!("Max Needs Matrix");
|
||||
|
@ -99,23 +53,16 @@ fn main() {
|
|||
let mut answers: [u8; PROCESS_COUNT] = [0; PROCESS_COUNT];
|
||||
for (answer, correct_answer) in answers.iter_mut().zip(&info.1) {
|
||||
println!("Which Process Should be Done Now ?");
|
||||
let mut input = String::new();
|
||||
if let Err(err_val) = io::stdin().read_line(&mut input) {
|
||||
eprintln!("Error: Reading User Input | {}", err_val);
|
||||
return;
|
||||
}
|
||||
let input: u8 = match input.trim().parse() {
|
||||
Ok(parsed) => parsed,
|
||||
Err(err_val) => {
|
||||
eprintln!("Error: Converting User Input | {}", err_val);
|
||||
return;
|
||||
match get_u8_input() {
|
||||
Some(input) => {
|
||||
*answer = input;
|
||||
if *correct_answer == input {
|
||||
println!("Correct");
|
||||
} else {
|
||||
println!("Wrong it should be = {}", correct_answer);
|
||||
}
|
||||
}
|
||||
};
|
||||
*answer = input;
|
||||
if *correct_answer == input {
|
||||
println!("Correct");
|
||||
} else {
|
||||
println!("Wrong it should be = {}", correct_answer);
|
||||
None => return,
|
||||
}
|
||||
}
|
||||
println!("Your Answers");
|
||||
|
@ -127,13 +74,11 @@ fn main() {
|
|||
println!("P{}", correct_answer);
|
||||
}
|
||||
|
||||
let mut resource_input: String = String::new();
|
||||
println!("Press 'r' to Restart");
|
||||
if let Err(err_val) = io::stdin().read_line(&mut resource_input) {
|
||||
println!("Failed to Read: {}", err_val);
|
||||
return;
|
||||
}
|
||||
resource_input = resource_input.trim().to_string();
|
||||
let resource_input = match get_input() {
|
||||
Some(input) => input,
|
||||
None => return,
|
||||
};
|
||||
match resource_input.as_str() {
|
||||
"r" => {
|
||||
restart = true;
|
||||
|
@ -146,6 +91,58 @@ fn main() {
|
|||
}
|
||||
}
|
||||
|
||||
fn get_input() -> Option<String> {
|
||||
let mut input: String = String::new();
|
||||
if let Err(err_val) = io::stdin().read_line(&mut input) {
|
||||
eprintln!("Error: Failed to Read | {}", err_val);
|
||||
return None;
|
||||
}
|
||||
Some(input.trim_end().to_string())
|
||||
}
|
||||
|
||||
fn get_u8_input() -> Option<u8> {
|
||||
match get_input() {
|
||||
Some(input) => match input.parse::<u8>() {
|
||||
Ok(input) => Some(input),
|
||||
Err(err_val) => {
|
||||
eprintln!("Error: Failed to Convert | {}", err_val);
|
||||
None
|
||||
}
|
||||
},
|
||||
None => None,
|
||||
}
|
||||
}
|
||||
|
||||
fn assign_resource_matrix_column(
|
||||
max_needs_matrix: &mut [[u8; RESOURCE_COUNT]; PROCESS_COUNT],
|
||||
assigned_resources_matrix: &mut [[u8; RESOURCE_COUNT]; PROCESS_COUNT],
|
||||
random_limit: u8,
|
||||
which_resource: usize,
|
||||
) {
|
||||
for i in 0..PROCESS_COUNT {
|
||||
let mut rng = rand::thread_rng();
|
||||
let random = rng.gen_range(0..random_limit);
|
||||
max_needs_matrix[i][which_resource] = random;
|
||||
if random != 0 {
|
||||
assigned_resources_matrix[i][which_resource] = rng.gen_range(0..random);
|
||||
} else {
|
||||
assigned_resources_matrix[i][which_resource] = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn assign_resource_matrix(
|
||||
max_needs_matrix: &mut [[u8; RESOURCE_COUNT]; PROCESS_COUNT],
|
||||
assigned_resources_matrix: &mut [[u8; RESOURCE_COUNT]; PROCESS_COUNT],
|
||||
a: u8,
|
||||
b: u8,
|
||||
c: u8,
|
||||
) {
|
||||
assign_resource_matrix_column(max_needs_matrix, assigned_resources_matrix, a, 0);
|
||||
assign_resource_matrix_column(max_needs_matrix, assigned_resources_matrix, b, 1);
|
||||
assign_resource_matrix_column(max_needs_matrix, assigned_resources_matrix, c, 2);
|
||||
}
|
||||
|
||||
fn print_matrix(matrix: [[u8; RESOURCE_COUNT]; PROCESS_COUNT]) {
|
||||
for (i, matrix_column) in matrix.iter().enumerate() {
|
||||
print!("\n\t Process {}: ", i);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue