Compare commits

...

7 Commits

Author SHA1 Message Date
d0de9b5c6a json here we come... 2024-12-13 16:09:35 -06:00
5444ef0bce Update "MarkdownResume-Pipeline" from "https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git@main"
git-vendor-name: MarkdownResume-Pipeline
git-vendor-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-vendor-repository: https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git
git-vendor-ref: main
2024-12-13 16:07:33 -06:00
d5bc7841f7 Squashed 'vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline/' changes from 0ce7627..0c3b9b4
0c3b9b4 third run of json support...

git-subtree-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-subtree-split: 0c3b9b486884ac1de85094cf49769ccacd494399
2024-12-13 16:07:33 -06:00
119e8dfc39 Update "MarkdownResume-Pipeline" from "https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git@main"
git-vendor-name: MarkdownResume-Pipeline
git-vendor-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-vendor-repository: https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git
git-vendor-ref: main
2024-12-13 16:05:16 -06:00
37098ccd06 Squashed 'vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline/' changes from d8eb0ee..0ce7627
0ce7627 second run of json support...

git-subtree-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-subtree-split: 0ce7627edbc31bfa3c943db44d9520bdc6649832
2024-12-13 16:05:16 -06:00
f6744e3393 Update "MarkdownResume-Pipeline" from "https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git@main"
git-vendor-name: MarkdownResume-Pipeline
git-vendor-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-vendor-repository: https://git.knownelement.com/reachableceo/MarkdownResume-Pipeline.git
git-vendor-ref: main
2024-12-13 16:03:48 -06:00
0ecf6f0526 Squashed 'vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline/' changes from 9511d3d..d8eb0ee
d8eb0ee first run of json support...

git-subtree-dir: vendor/git.knownelement.com/reachableceo/MarkdownResume-Pipeline
git-subtree-split: d8eb0eefcc4e591cd4f57636711940ab954d4d82
2024-12-13 16:03:48 -06:00
2 changed files with 234 additions and 219 deletions

View File

@ -1,3 +0,0 @@
institution,url,area,studyType,startDate,endDate,score,courses
"The University of Queensland",,"Software Engineering (incomplete)","Bachelors","2008-02-12","2009-12-12",,
"University of Technology","http://universityoftechnology.com","Computer Science","Bachelor","2010-09-01","2014-06-30","3.8 GPA","CS101 - Introduction to Computer Science; CS201 - Data Structures and Algorithms; CS301 - Operating Systems"
1 institution url area studyType startDate endDate score courses
2 The University of Queensland Software Engineering (incomplete) Bachelors 2008-02-12 2009-12-12
3 University of Technology http://universityoftechnology.com Computer Science Bachelor 2010-09-01 2014-06-30 3.8 GPA CS101 - Introduction to Computer Science; CS201 - Data Structures and Algorithms; CS301 - Operating Systems

View File

@ -32,6 +32,8 @@ META
} }
add_basics_section() add_basics_section()
{ {
@ -56,147 +58,47 @@ BASICS
} }
add_work_section()
# Bash Function to Append JSON
add_profiles_section ()
{ {
local input_file=$JSON_TEMPLATE_DIRECTORY/work.csv echo '{"profiles": [' >> $BUILD_OUTPUT_DIR/resume.json
cat << 'WORK_START' while IFS=, read -r username url network; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
"work": [ {
WORK_START "username": "$username",
awk -F, 'NR>1 { "url": "$url",
printf " {\n" "network": "$network"
printf " \"name\": \"%s\",\n", $1 },
printf " \"position\": \"%s\",\n", $2 EOF
printf " \"url\": \"%s\",\n", $3 done < $JSON_TEMPLATE_DIRECTORY/profiles.csv
printf " \"startDate\": \"%s\",\n", $4 # Remove trailing comma and close JSON array
if ($5 != "") printf " \"endDate\": \"%s\",\n", $5 sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
printf " \"summary\": \"%s\",\n", $6 echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
printf " \"highlights\": [\n \"%s\"\n ]\n", gensub(/\|/, "\",\n \"", "g", $7)
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'WORK_END'
],
WORK_END
} }
add_volunteer_section() add_certificates_section()
{ {
local input_file="$JSON_TEMPLATE_DIRECTORY/volunteer.csv" echo '{"certificates": [' >> $BUILD_OUTPUT_DIR/resume.json
cat << 'VOLUNTEER_START' >> $BUILD_OUTPUT_DIR/resume.json while IFS=, read -r name date issuer url; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
"volunteer": [
VOLUNTEER_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"organization\": \"%s\",\n", $1
printf " \"position\": \"%s\",\n", $2
printf " \"url\": \"%s\",\n", $3
printf " \"startDate\": \"%s\",\n", $3
printf " \"endDate\": \"%s\",\n", $3
printf " \"summary\": \"%s\"\n", $4
printf " \"highlights\": ["
printf " " $7
printf " ]"
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'VOLUNTEER_END'
],
VOLUNTEER_END
}
add_awards_section()
{ {
"name": "$name",
"date": "$date",
"issuer": "$issuer",
"url": "$url"
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/certificates.csv
local input_file=$JSON_TEMPLATE_DIRECTORY/awards.csv # Remove trailing comma and close JSON array
cat << 'AWARDS_START' >> $BUILD_OUTPUT_DIR/resume.json sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
"awards": [ echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
AWARDS_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"title\": \"%s\",\n", $1
printf " \"date\": \"%s\",\n", $2
printf " \"awarder\": \"%s\",\n", $3
printf " \"summary\": \"%s\"\n", $4
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'AWARDS_END'
],
AWARDS_END
}
add_publications_section()
{
local input_file=$JSON_TEMPLATE_DIRECTORY/publications.csv
cat << 'PUBLICATIONS_START' >> $BUILD_OUTPUT_DIR/resume.json
"publications": [
PUBLICATIONS_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"name\": \"%s\",\n", $1
printf " \"publisher\": \"%s\",\n", $2
printf " \"releaseDate\": \"%s\",\n", $3
printf " \"url\": \"%s\",\n", $4
printf " \"summary\": \"%s\"\n", $5
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'PUBLICATIONS_END'
],
PUBLICATIONS_END
}
add_volunteer_section()
{
local input_file=$JSON_TEMPLATE_DIRECTORY/volunteer.csv
cat << 'VOLUNTEER_START' >> $BUILD_OUTPUT_DIR/resume.json
"volunteer": [
VOLUNTEER_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"organization\": \"%s\",\n", $1
printf " \"position\": \"%s\",\n", $2
printf " \"url\": \"%s\",\n", $3
printf " \"startDate\": \"%s\",\n", $4
printf " \"summary\": \"%s\",\n", $5
printf " \"highlights\": [\n \"%s\"\n ]\n", gensub(/\|/, "\",\n \"", "g", $6)
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'VOLUNTEER_END'
],
VOLUNTEER_END
}
add_skills_section()
{
local input_file="$JSON_TEMPLATE_DIRECTORY/skills.csv"
cat << 'SKILLS_START' >> $BUILD_OUTPUT_DIR/resume.json
"skills": [
SKILLS_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"keywords\": [\n \"%s\"\n ],\n", gensub(/\|/, "\",\n \"", "g", $3)
printf " \"level\": \"%s\",\n", $2
printf " \"name\": \"%s\"\n", $1
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'SKILLS_END'
],
SKILLS_END
} }
@ -204,64 +106,25 @@ add_education_section()
{ {
local input_file="$JSON_TEMPLATE_DIRECTORY/education.csv" echo '{"education": [' >> $BUILD_OUTPUT_DIR/resume.json
cat << 'EDUCATION_START' >> $BUILD_OUTPUT_DIR/resume.json while IFS=, read -r institution url area studyType startDate endDate score courses; do
"education": [ cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
EDUCATION_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"institution\": \"%s\",\n", $1
if ($2 != "") printf " \"url\": \"%s\",\n", $2
printf " \"area\": \"%s\",\n", $3
printf " \"studyType\": \"%s\",\n", $4
printf " \"startDate\": \"%s\",\n", $5
printf " \"endDate\": \"%s\"", $6
if ($7 != "") printf ",\n \"score\": \"%s\"", $7
if ($8 != "") printf ",\n \"courses\": [\n \"%s\"\n ]", gensub(/\|/, "\",\n \"", "g", $8)
printf "\n }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'EDUCATION_END'
],
EDUCATION_END
}
add_languages_section()
{ {
"institution": "$institution",
"url": "$url",
"area": "$area",
"studyType": "$studyType",
"startDate": "$startDate",
"endDate": "$endDate",
"score": "$score",
"courses": [$(echo "$courses" | sed 's/;/","/g' | sed 's/^/"/;s/$/"/')]
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/education.csv
local input_file="$JSON_TEMPLATE_DIRECTORY/languages.csv" # Remove trailing comma and close JSON array
cat << 'LANGUAGES_START' >> $BUILD_OUTPUT_DIR/resume.json sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
"languages": [ echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
LANGUAGES_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"language\": \"%s\",\n", $1
printf " \"fluency\": \"%s\"\n", $2
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'LANGUAGES_END'
],
LANGUAGES_END
}
add_interests_section()
{
local input_file="$JSON_TEMPLATE_DIRECTORY/interests.csv"
cat << 'INTERESTS_START' >> $BUILD_OUTPUT_DIR/resume.json
"interests": [
INTERESTS_START
awk -F, 'NR>1 {
printf " {\n"
printf " \"name\": \"%s\",\n", $1
printf " \"keywords\": [\n \"%s\"\n ]\n", gensub(/\|/, "\",\n \"", "g", $2)
printf " }%s\n", (NR==NR?"":",")
}' "$input_file"
cat << 'INTERESTS_END'
],
INTERESTS_END
} }
@ -269,22 +132,178 @@ add_references_section()
{ {
local input_file="$JSON_TEMPLATE_DIRECTORY/references.csv" echo '{"references": [' >> $BUILD_OUTPUT_DIR/resume.json
cat << 'REFERENCES_START' >> $BUILD_OUTPUT_DIR/resume.json while IFS=, read -r reference name; do
"references": [ cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
REFERENCES_START {
awk -F, 'NR>1 { "reference": "$reference",
printf " {\n" "name": "$name"
printf " \"name\": \"%s\",\n", $1 },
printf " \"reference\": \"%s\"\n", $2 EOF
printf " }%s\n", (NR==NR?"":",") done < $JSON_TEMPLATE_DIRECTORY/references.csv
}' "$input_file"
cat << 'REFERENCES_END' # Remove trailing comma and close JSON array
] sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
REFERENCES_END echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
} }
add_skills_section()
{
echo '{"skills": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r name level keywords; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"name": "$name",
"level": "$level",
"keywords": [$(echo "$keywords" | sed 's/;/","/g' | sed 's/^/"/;s/$/"/')]
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/skills.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_awards_section()
{
echo '{"awards": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r title awarder date summary; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"title": "$title",
"awarder": "$awarder",
"date": "$date",
"summary": "$summary"
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/awards.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_publications_section()
{
echo '{"publications": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r name publisher releaseDate url summary; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"name": "$name",
"publisher": "$publisher",
"releaseDate": "$releaseDate",
"url": "$url",
"summary": "$summary"
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/publications.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_volunteer_section()
{
echo '{"volunteer": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r organization position url startDate summary highlights; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"organization": "$organization",
"position": "$position",
"url": "$url",
"startDate": "$startDate",
"summary": "$summary",
"highlights": [$(echo "$highlights" | sed 's/;/","/g' | sed 's/^/"/;s/$/"/')]
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/volunteer.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_work_section()
{
echo '{"work": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r name position location website startDate endDate summary highlights; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"name": "$name",
"position": "$position",
"location": "$location",
"website": "$website",
"startDate": "$startDate",
"endDate": "$endDate",
"summary": "$summary",
"highlights": [$(echo "$highlights" | sed 's/;/","/g' | sed 's/^/"/;s/$/"/')]
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/work.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_languages_section()
{
echo '{"languages": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r language fluency; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"language": "$language",
"fluency": "$fluency"
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/languages.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_interests_section()
{
echo '{"interests": [' >> $BUILD_OUTPUT_DIR/resume.json
while IFS=, read -r name keywords; do
cat <<EOF >> $BUILD_OUTPUT_DIR/resume.json
{
"name": "$name",
"keywords": [$(echo "$keywords" | sed 's/;/","/g' | sed 's/^/"/;s/$/"/')]
},
EOF
done < $JSON_TEMPLATE_DIRECTORY/interests.csv
# Remove trailing comma and close JSON array
sed -i '$ s/},/}/' $BUILD_OUTPUT_DIR/resume.json
echo ']}' >> $BUILD_OUTPUT_DIR/resume.json
}
add_close_section() add_close_section()
@ -299,20 +318,19 @@ main()
{ {
add_open_section add_open_section
add_meta_section $JSON_TEMPLATE_DIRECTORY/meta.csv add_meta_section
add_basics_section $JSON_TEMPLATE_DIRECTORY/basics.csv add_basics_section
add_profiles_section $JSON_TEMPLATE_DIRECTORY/profiles.csv add_profiles_section
add_work_section $JSON_TEMPLATE_DIRECTORY/work.csv add_work_section
add_volunteer_section $JSON_TEMPLATE_DIRECTORY/volunteer.csv add_volunteer_section
add_education-section $JSON_TEMPLATE_DIRECTORY/education.csv add_education_section
add_awards_section $JSON_TEMPLATE_DIRECTORY/awards.csv add_awards_section
add_certificates_section $JSON_TEMPLATE_DIRECTORY/certificates.csv add_certificates_section
add_publications_section $JSON_TEMPLATE_DIRECTORY/publications.csv add_publications_section
add_skills_section $JSON_TEMPLATE_DIRECTORY/skills.csv add_skills_section
add_languages_section $JSON_TEMPLATE_DIRECTORY/languages.csv add_languages_section
add_interests_section $JSON_TEMPLATE_DIRECTORY/interests.csv add_interests_section
add_references_section $JSON_TEMPLATE_DIRECTORY/references.csv add_references_section
add_projects_section $JSON_TEMPLATE_DIRECTORY/projects.csv
add_close_section add_close_section
} }