Compare commits
12 commits
2025.02.27
...
main
Author | SHA1 | Date | |
---|---|---|---|
03da18cacd | |||
5fb17b3e06 | |||
98ac6ab3fc | |||
a06ad8aaab | |||
49243fd99e | |||
cab11ef3af | |||
45743bd6df | |||
397bc485ec | |||
2ca6473869 | |||
34ca3c9b0e | |||
36b2ae610d | |||
d395a29ca8 |
18 changed files with 113 additions and 63 deletions
2
Justfile
2
Justfile
|
@ -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
|
||||
|
|
|
@ -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"
|
||||
|
|
|
@ -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.",
|
||||
)
|
||||
),
|
||||
),
|
||||
)
|
||||
|
|
|
@ -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,
|
||||
)
|
||||
)
|
||||
)
|
||||
|
|
|
@ -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),
|
||||
)
|
||||
}
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
grid(
|
||||
columns: 4,
|
||||
rows: 1,
|
||||
gutter: 4em,
|
||||
gutter: 3em,
|
||||
email,
|
||||
phone,
|
||||
location,
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
title: "",
|
||||
subtitle: "",
|
||||
role: "",
|
||||
role_subtitle: "",
|
||||
timeframe: "",
|
||||
skills: (""),
|
||||
highlights: (""),
|
||||
|
|
|
@ -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,
|
||||
),
|
||||
|
|
|
@ -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),
|
||||
)
|
||||
}
|
||||
|
|
|
@ -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),
|
||||
)
|
||||
}
|
||||
|
|
5
src/section/base/item/heading/role/main.typ
Normal file
5
src/section/base/item/heading/role/main.typ
Normal file
|
@ -0,0 +1,5 @@
|
|||
#let section_base_item_heading_role_main(title: "") = text(
|
||||
weight: "light",
|
||||
size: .9em,
|
||||
title
|
||||
)
|
7
src/section/base/item/heading/role/subtitle.typ
Normal file
7
src/section/base/item/heading/role/subtitle.typ
Normal file
|
@ -0,0 +1,7 @@
|
|||
#let section_base_item_heading_role_subtitle(
|
||||
subtitle: "",
|
||||
) = text(
|
||||
size: .85em,
|
||||
weight: "extralight",
|
||||
subtitle
|
||||
)
|
|
@ -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
|
||||
)
|
||||
}
|
||||
)
|
||||
|
|
|
@ -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),
|
||||
)
|
||||
|
|
|
@ -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,
|
||||
|
|
|
@ -2,5 +2,8 @@
|
|||
list: (""),
|
||||
) = text(
|
||||
weight: "light",
|
||||
list.join(", "),
|
||||
par(
|
||||
justify: true,
|
||||
list.join(", ")
|
||||
)
|
||||
)
|
||||
|
|
|
@ -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,
|
||||
)),
|
|
@ -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,
|
Loading…
Add table
Reference in a new issue