Compare commits

..

No commits in common. "main" and "2025.02.27" have entirely different histories.

18 changed files with 63 additions and 113 deletions

View file

@ -1,5 +1,5 @@
default:
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"
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
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
"e25cd565bf191691838702d76c764a2a3cd557d3")
"8c483c12e94bcf43e4c44170f1d5fea5fbba4970")
(introduction
(make-channel-introduction
"9edb3f66fd807b096b48283debdcddccfea34bad"
@ -14,7 +14,7 @@
(url "https://codeberg.org/guix-science/guix-science")
(branch "master")
(commit
"b9f41a281365e0681dd78ac4c756c78a5997fa30")
"a82cc47ae408a9a92e1bd038fdb8d46f694ebde3")
(introduction
(make-channel-introduction
"b1fe5aaff3ab48e798a4cce02f0212bc91f423dc"

View file

@ -4,7 +4,7 @@
email: "contact@ethanreece.com",
phone: "(208) 515-2094",
location: "Richardson, TX",
website: "linkedin.com/in/-ethanreece-"
website: "https://ethanreece.com/"
),
skills: (
(
@ -12,12 +12,12 @@
items: (
"Linux",
"Git",
"GitHub Actions",
"Docker",
"Proxmox",
"Nix",
"Guix",
"Terraform",
"GitHub Actions",
),
),
(
@ -25,10 +25,11 @@
items: (
"JavaScript",
"C#",
"Rust",
"Java",
"Rust",
"C",
"C++",
"Guile/Scheme",
),
),
(
@ -49,27 +50,31 @@
(
title: "The University of Texas at Dallas",
degree: "Bachelor of Science in Computer Science",
graduation: "Expected Graduation: December 2025",
gpa: "Current GPA: 3.801",
graduation: "May 2026",
gpa: "Current GPA: 3.768",
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",
@ -77,7 +82,7 @@
),
),
),
experience: (
work_experience: (
(
title: "Scrumfish Software",
location: "Nampa, ID",
@ -88,7 +93,6 @@
"JavaScript/React",
"Microsoft SQL Server",
"GitHub",
"Jira",
),
highlights: (
"Developed ASP.NET APIs for data management, multifactor authentication, and document conversion.",
@ -114,7 +118,7 @@
),
),
),
projects: (
professional_development: (
(
title: "Declarative Laptop Configuration",
timeframe: "July 2024 Present",
@ -126,8 +130,8 @@
"Git",
),
highlights: (
"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."
"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."
),
),
(
@ -145,28 +149,10 @@
"Cloudflare",
),
highlights: (
"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.",
"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.",
),
),
(
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: (""),
),
),
experience: (
work_experience: (
(
title: "",
location: "",
@ -32,7 +32,7 @@
highlights: (""),
),
),
projects: (
professional_development: (
(
title: "",
timeframe: "",
@ -55,8 +55,8 @@
page_resume_content(
skills: skills,
education: education,
experience: experience,
projects: projects,
work_experience: work_experience,
professional_development: professional_development,
)
)
)

View file

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

View file

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

View file

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

View file

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

View file

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

View file

@ -1,15 +1,5 @@
#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),
)
}
#let section_base_item_heading_role(role: "") = text(
weight: "light",
size: .9em,
role
)

View file

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

View file

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

View file

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

View file

@ -6,7 +6,7 @@
import "body.typ": section_base_body
grid(
gutter: 0.8em,
gutter: 1.1em,
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.degree,
role: school.title,
title: school.title,
role: school.degree,
timeframe: school.graduation,
skills: (
school.gpa,

View file

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

View file

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

View file

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