Compare commits

..

12 commits

18 changed files with 113 additions and 63 deletions

View file

@ -1,5 +1,5 @@
default:
guix time-machine --channels=./channels.scm.lock -- shell --container --emulate-fhs --manifest=./manifest.scm -- typst compile ./src/document.typ ./out/resume.pdf --font-path=/usr/share/fonts
guix time-machine --channels=./channels.scm.lock -- shell --container --emulate-fhs --manifest=./manifest.scm -- sh -c "mkdir -p ./out && typst compile ./src/document.typ ./out/resume.pdf --font-path=/usr/share/fonts --root=src"
fonts:
guix time-machine --channels=./channels.scm.lock -- shell --container --emulate-fhs --manifest=./manifest.scm -- typst fonts --font-path=/usr/share/fonts

View file

@ -3,7 +3,7 @@
(url "https://git.savannah.gnu.org/git/guix.git")
(branch "master")
(commit
"8c483c12e94bcf43e4c44170f1d5fea5fbba4970")
"e25cd565bf191691838702d76c764a2a3cd557d3")
(introduction
(make-channel-introduction
"9edb3f66fd807b096b48283debdcddccfea34bad"
@ -14,7 +14,7 @@
(url "https://codeberg.org/guix-science/guix-science")
(branch "master")
(commit
"a82cc47ae408a9a92e1bd038fdb8d46f694ebde3")
"b9f41a281365e0681dd78ac4c756c78a5997fa30")
(introduction
(make-channel-introduction
"b1fe5aaff3ab48e798a4cce02f0212bc91f423dc"

View file

@ -4,7 +4,7 @@
email: "contact@ethanreece.com",
phone: "(208) 515-2094",
location: "Richardson, TX",
website: "https://ethanreece.com/"
website: "linkedin.com/in/-ethanreece-"
),
skills: (
(
@ -12,12 +12,12 @@
items: (
"Linux",
"Git",
"GitHub Actions",
"Docker",
"Proxmox",
"Nix",
"Guix",
"Terraform",
"GitHub Actions",
),
),
(
@ -25,11 +25,10 @@
items: (
"JavaScript",
"C#",
"Java",
"Rust",
"Java",
"C",
"C++",
"Guile/Scheme",
),
),
(
@ -50,31 +49,27 @@
(
title: "The University of Texas at Dallas",
degree: "Bachelor of Science in Computer Science",
graduation: "May 2026",
gpa: "Current GPA: 3.768",
graduation: "Expected Graduation: December 2025",
gpa: "Current GPA: 3.801",
coursework: (
completed: (
"Programming Language Paradigms",
"Digital Logic & Computer Design",
"Operating Systems Concepts",
"Probability & Statistics in CS/SE",
"Data Structures & Algorithmic Analysis",
"Software Engineering",
"Systems Programming in UNIX",
"Computer Architecture (CS 2340)",
"Discrete Mathematics II",
"Database Systems",
"Advanced Algorithm Design & Analysis",
"Linear Algebra",
"Theoretical Concepts of Calculus",
"Differential Equations with Applications",
),
current: (
"Automata Theory",
"Cyber Attack & Defense Lab",
"Computer Architecture (CS 6304)",
"Advanced Operating Systems",
),
current: (
"Design and Analysis of Computer Algorithms",
"Computer Networks",
"Real-Time Systems",
),
),
highlights: (
"Computer Science Fast Track Program, Systems Track",
@ -82,7 +77,7 @@
),
),
),
work_experience: (
experience: (
(
title: "Scrumfish Software",
location: "Nampa, ID",
@ -93,6 +88,7 @@
"JavaScript/React",
"Microsoft SQL Server",
"GitHub",
"Jira",
),
highlights: (
"Developed ASP.NET APIs for data management, multifactor authentication, and document conversion.",
@ -118,7 +114,7 @@
),
),
),
professional_development: (
projects: (
(
title: "Declarative Laptop Configuration",
timeframe: "July 2024 Present",
@ -130,8 +126,8 @@
"Git",
),
highlights: (
"Leveraging Guix and Nix to centralize my laptop user configuration for tracking history and improving maintainability.",
"Utilizing the \"time-machine\" function to ensure consistent software versions and to allow rolling back."
"Leverage Guix and Nix to centralize my laptop user configuration for tracking history and improving maintainability.",
"Utilize the \"time-machine\" function to ensure consistent software versions and to allow rolling back."
),
),
(
@ -149,10 +145,28 @@
"Cloudflare",
),
highlights: (
"Managing a physical server using Proxmox, Debian VMs, and Docker for several applications.",
"Hosting various services including Forgejo, TrueNAS, Nextcloud, and Vaultwarden.",
"Using Terraform with NixOS, Hetzner, and Cloudflare integrations to centralize configurations for a VPN used to navigate CGNAT limitations.",
"Manage a physical server using Proxmox, Debian VMs, and Docker for several applications.",
"Host various services including Forgejo, TrueNAS, Nextcloud, and Vaultwarden.",
"Use Terraform with NixOS, Hetzner, and Cloudflare integrations to centralize configurations for a VPN used to navigate CGNAT limitations.",
),
),
(
title: "Failure-Resistant Distributed Database System",
timeframe: "April May 2025",
role: "Course Group Project",
skills: (
"Rust",
"Tokio",
"Serde",
"Nix",
"TCP",
"Linux",
"GitHub",
),
highlights: (
"Implemented a basic distributed database system with an architecture similar to Amazon Dynamo, designed to tolerate a small number of server failures.",
"Demonstrated that transaction logs remain totally ordered, even under a high load.",
)
),
),
)

View file

@ -22,7 +22,7 @@
highlights: (""),
),
),
work_experience: (
experience: (
(
title: "",
location: "",
@ -32,7 +32,7 @@
highlights: (""),
),
),
professional_development: (
projects: (
(
title: "",
timeframe: "",
@ -55,8 +55,8 @@
page_resume_content(
skills: skills,
education: education,
work_experience: work_experience,
professional_development: professional_development,
experience: experience,
projects: projects,
)
)
)

View file

@ -15,7 +15,7 @@
highlights: (""),
),
),
work_experience: (
experience: (
(
title: "",
location: "",
@ -25,7 +25,7 @@
highlights: (""),
),
),
professional_development: (
projects: (
(
title: "",
timeframe: "",
@ -37,14 +37,14 @@
) = {
import "../../section/skills.typ": section_skills
import "../../section/education.typ": section_education
import "../../section/work_experience.typ": section_work_experience
import "../../section/professional_development.typ": section_professional_development
import "../../section/experience.typ": section_experience
import "../../section/projects.typ": section_projects
grid(
gutter: 1.7em,
gutter: 1.1em,
section_skills(skills: skills),
section_education(education: education),
section_work_experience(work_experience: work_experience),
section_professional_development(professional_development: professional_development),
section_experience(experience: experience),
section_projects(projects: projects),
)
}

View file

@ -9,7 +9,7 @@
grid(
columns: 4,
rows: 1,
gutter: 4em,
gutter: 3em,
email,
phone,
location,

View file

@ -5,6 +5,7 @@
title: "",
subtitle: "",
role: "",
role_subtitle: "",
timeframe: "",
skills: (""),
highlights: (""),

View file

@ -2,6 +2,7 @@
title: "",
subtitle: "",
role: "",
role_subtitle: "",
timeframe: "",
skills: (""),
highlights: (""),
@ -15,6 +16,7 @@
title: title,
subtitle: subtitle,
role: role,
role_subtitle: role_subtitle,
timeframe: timeframe,
skills: skills,
),

View file

@ -2,6 +2,7 @@
title: "",
subtitle: "",
role: "",
role_subtitle: "",
timeframe: "",
skills: (""),
) = {
@ -23,7 +24,10 @@
subtitle: subtitle,
),
section_base_item_heading_timeframe(timeframe: timeframe),
section_base_item_heading_role(role: role),
section_base_item_heading_role(
title: role,
subtitle: role_subtitle,
),
section_base_item_heading_skills(skills: skills),
)
}

View file

@ -1,5 +1,15 @@
#let section_base_item_heading_role(role: "") = text(
weight: "light",
size: .9em,
role
)
#let section_base_item_heading_role(
title: "",
subtitle: "",
) = {
import "role/main.typ": section_base_item_heading_role_main
import "role/subtitle.typ": section_base_item_heading_role_subtitle
grid(
columns: 2,
gutter: 1.5em,
align: bottom,
section_base_item_heading_role_main(title: title),
section_base_item_heading_role_subtitle(subtitle: subtitle),
)
}

View file

@ -0,0 +1,5 @@
#let section_base_item_heading_role_main(title: "") = text(
weight: "light",
size: .9em,
title
)

View file

@ -0,0 +1,7 @@
#let section_base_item_heading_role_subtitle(
subtitle: "",
) = text(
size: .85em,
weight: "extralight",
subtitle
)

View file

@ -1,9 +1,13 @@
#let section_base_item_highlight(
highlight: "",
) = par(
justify: true,
text(
size: 0.95em,
) = text(
size: 0.95em,
if type(highlight) == str {
par(
justify: true,
highlight
)
} else {
highlight
)
}
)

View file

@ -6,7 +6,7 @@
import "body.typ": section_base_body
grid(
gutter: 1.1em,
gutter: 0.8em,
section_base_heading(title: title),
section_base_body(body),
)

View file

@ -19,8 +19,8 @@
section_base_full(
title: "Education",
items: education.map(school => (
title: school.title,
role: school.degree,
title: school.degree,
role: school.title,
timeframe: school.graduation,
skills: (
school.gpa,

View file

@ -2,5 +2,8 @@
list: (""),
) = text(
weight: "light",
list.join(", "),
par(
justify: true,
list.join(", ")
)
)

View file

@ -1,5 +1,5 @@
#let section_work_experience(
work_experience: (
#let section_experience(
experience: (
(
title: "",
location: "",
@ -13,12 +13,12 @@
import "base/full.typ": section_base_full
section_base_full(
title: "Work Experience",
items: work_experience.map(company => (
title: company.title,
subtitle: company.location,
title: "Experience",
items: experience.map(company => (
title: company.role,
timeframe: company.timeframe,
role: company.role,
role: company.title,
role_subtitle: company.location,
skills: company.skills,
highlights: company.highlights,
)),

View file

@ -1,5 +1,5 @@
#let section_professional_development(
professional_development: (
#let section_projects(
projects: (
(
title: "",
timeframe: "",
@ -12,8 +12,8 @@
import "base/full.typ": section_base_full
section_base_full(
title: "Professional Development",
items: professional_development.map(item => (
title: "Projects",
items: projects.map(item => (
title: item.title,
timeframe: item.timeframe,
role: item.role,