generated from sigonasr2/CProjectTemplate
commit
ba6af6dad3
@ -0,0 +1,7 @@ |
|||||||
|
#Compiles the entire program then runs it, producing an executable. |
||||||
|
#C |
||||||
|
printf "Running program...\n\n\n" |
||||||
|
if gcc $(find . -type f -name "*.c") ${CUSTOM_PARAMS} -o ${PROJECT_NAME}; then |
||||||
|
./${PROJECT_NAME} "$@" |
||||||
|
fi |
||||||
|
printf "\n\n" |
@ -0,0 +1,20 @@ |
|||||||
|
#Adds a commit message and pushes project to github repository. |
||||||
|
#C |
||||||
|
COMMIT_MESSAGE="$*" |
||||||
|
FIRST_LINE=true |
||||||
|
while IFS= read -r line |
||||||
|
do |
||||||
|
if [ "$FIRST_LINE" = true ]; then |
||||||
|
COMMIT_MESSAGE+=" |
||||||
|
|
||||||
|
Co-authored-by: $line" |
||||||
|
FIRST_LINE=false |
||||||
|
else |
||||||
|
COMMIT_MESSAGE+=" |
||||||
|
Co-authored-by: $line" |
||||||
|
fi |
||||||
|
done < utils/.coauthors |
||||||
|
git add -u |
||||||
|
git add * |
||||||
|
git commit -m "$COMMIT_MESSAGE" |
||||||
|
git push |
@ -0,0 +1,2 @@ |
|||||||
|
build.sh |
||||||
|
commit.sh |
@ -0,0 +1,2 @@ |
|||||||
|
build.sh:fcbd8c14fe2a608d11166cf5aa7dba02 - |
||||||
|
commit.sh:89783d2e6a165aa9612c79cfbd804a35 - |
Binary file not shown.
@ -0,0 +1,19 @@ |
|||||||
|
This repository provides a template for starting a new C project using Sig's build system! Updates are automatically propogated. Run `./sig` for a list of commands and then use follow the instructions given to invoke them. Adjust variables as necessary in the `sig` command file. |
||||||
|
|
||||||
|
``` |
||||||
|
@sigonasr2 ➜ /workspaces/CProjectTemplate (main) $ ./sig |
||||||
|
Dev build, no checks required. |
||||||
|
|
||||||
|
Usage: ./sig <command> {args} |
||||||
|
|
||||||
|
==== Current Configuration ===================== |
||||||
|
PROJECT_NAME CProjectTemplate |
||||||
|
BUILD_OPTIONS -lncurses |
||||||
|
LANGUAGE C |
||||||
|
===================================================== |
||||||
|
|
||||||
|
Command List: |
||||||
|
|
||||||
|
build Compiles the entire program then runs it, producing an executable. |
||||||
|
commit Adds a commit message and pushes project to github repository. |
||||||
|
'`` |
@ -0,0 +1,15 @@ |
|||||||
|
echo "Initializing..." |
||||||
|
FILES=$(ls -dA */) |
||||||
|
LANGUAGES=() |
||||||
|
for f in $FILES |
||||||
|
do |
||||||
|
if [ "$f" != "scripts/" ] && [ "$f" != "utils/" ]; |
||||||
|
then |
||||||
|
LANGUAGES+=(""${f::-1}"") |
||||||
|
fi |
||||||
|
done |
||||||
|
echo "Languages Detected:" |
||||||
|
for f in "${LANGUAGES[@]}" |
||||||
|
do |
||||||
|
printf "\t%-15s\n" $f |
||||||
|
done |
@ -0,0 +1,5 @@ |
|||||||
|
#include <stdio.h> |
||||||
|
|
||||||
|
int main(int argc,char**argv) { |
||||||
|
printf("Hello World!"); |
||||||
|
} |
@ -0,0 +1,9 @@ |
|||||||
|
export AUTO_UPDATE=true |
||||||
|
|
||||||
|
source utils/define.sh |
||||||
|
|
||||||
|
define PROJECT_NAME "CProjectTemplate" |
||||||
|
define CUSTOM_PARAMS "-lncurses" |
||||||
|
define LANGUAGE "C" |
||||||
|
|
||||||
|
source utils/main.sh |
@ -0,0 +1 @@ |
|||||||
|
sigonasr2 <sigonasr2@gmail.com> |
@ -0,0 +1,4 @@ |
|||||||
|
Java/ |
||||||
|
C/ |
||||||
|
scripts/ |
||||||
|
utils/ |
@ -0,0 +1,26 @@ |
|||||||
|
export VARS=("") |
||||||
|
|
||||||
|
export LANGUAGE="" |
||||||
|
|
||||||
|
function define() { |
||||||
|
VARS+=("$1") |
||||||
|
value="${*:2}" |
||||||
|
eval export "$1"='$value' |
||||||
|
} |
||||||
|
|
||||||
|
if [[ $(pwd) != *"SigScript" && $AUTO_UPDATE = "true" && $1 != "update" ]]; then |
||||||
|
source utils/search.sh |
||||||
|
|
||||||
|
find . -type f -name md5 -delete |
||||||
|
find . -type f -name filelist -delete |
||||||
|
|
||||||
|
#Check for hashes |
||||||
|
FILES=$(cat utils/.updateDirectories) |
||||||
|
for f in $FILES |
||||||
|
do |
||||||
|
search $f |
||||||
|
check $f |
||||||
|
done |
||||||
|
else |
||||||
|
echo "Dev build, no checks required." |
||||||
|
fi |
@ -0,0 +1,5 @@ |
|||||||
|
.coauthors |
||||||
|
define.sh |
||||||
|
main.sh |
||||||
|
search.sh |
||||||
|
.updateDirectories |
@ -0,0 +1,28 @@ |
|||||||
|
if [ -z "$1" ] |
||||||
|
then |
||||||
|
echo "" |
||||||
|
echo " Usage: ./sig <command> {args}" |
||||||
|
echo "" |
||||||
|
printf "====\tCurrent Configuration" |
||||||
|
printf "\t=====================" |
||||||
|
for t in ${VARS[@]} |
||||||
|
do |
||||||
|
printf "\n\t%-15s%20s" $t ${!t} |
||||||
|
done |
||||||
|
printf "\n=====================================================" |
||||||
|
echo "" |
||||||
|
echo "" |
||||||
|
echo " Command List:" |
||||||
|
FILES=$(ls -1A ./$LANGUAGE/scripts 2>/dev/null | sed -e 's/\.sh$//' | sed -e 's/^/ /') |
||||||
|
for f in $FILES |
||||||
|
do |
||||||
|
if [ -f "./$LANGUAGE/scripts/$f.sh" ]; then |
||||||
|
DESC="$(head -n1 ./$LANGUAGE/scripts/$f.sh)" |
||||||
|
printf "\n\t%-15s%-65s" $f "${DESC:1}" |
||||||
|
fi |
||||||
|
done |
||||||
|
echo "" |
||||||
|
exit |
||||||
|
fi |
||||||
|
|
||||||
|
./$LANGUAGE/scripts/$1.sh "${*:2}" |
@ -0,0 +1,4 @@ |
|||||||
|
define.sh:3ecab0dffe2adfb950f3eb7c7061b750 - |
||||||
|
main.sh:d3d1bd0b56d8114eb7479964227f8576 - |
||||||
|
search.sh:81d08f5ff48e8a44b5f68387d426da05 - |
||||||
|
.updateDirectories:fa5e95db12be22ae8aed7ecbc560e38c - |
@ -0,0 +1,103 @@ |
|||||||
|
function search() { |
||||||
|
FILES2=$(ls -A $1 2>/dev/null) |
||||||
|
for g in $FILES2 |
||||||
|
do |
||||||
|
if [ -d $1$g ]; |
||||||
|
then |
||||||
|
echo "$1$g is a directory" |
||||||
|
search $1$g/ |
||||||
|
else |
||||||
|
echo "$1$g is a file" |
||||||
|
if [ $g != "md5" ] && [ $g != "filelist" ] && [ $g != ".package.files" ]; then |
||||||
|
if [ $g != ".coauthors" ] && [ $g != "version_info" ]; then |
||||||
|
SUM=$(md5sum < $1$g) |
||||||
|
echo "$g:$SUM" >> $1md5 |
||||||
|
fi |
||||||
|
echo "$g" >> $1filelist |
||||||
|
else |
||||||
|
echo " ignoring $g..." |
||||||
|
fi |
||||||
|
fi |
||||||
|
done |
||||||
|
} |
||||||
|
|
||||||
|
function check() { |
||||||
|
echo "Check $1" |
||||||
|
FILES2=$(ls -A $1 2>/dev/null) |
||||||
|
if [ -f "$1/md5" ]; |
||||||
|
then |
||||||
|
echo " md5: http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1md5" |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' -s "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1md5" --output /tmp/out |
||||||
|
cmp -s $1/md5 /tmp/out |
||||||
|
if [ "$?" -ne 0 ] |
||||||
|
then |
||||||
|
echo " Differences detected!" |
||||||
|
cat /tmp/out |
||||||
|
while IFS= read -r line |
||||||
|
do |
||||||
|
IFS=':' read -ra split <<< $line |
||||||
|
g="${split[0]}" |
||||||
|
echo "LINE -- $g" |
||||||
|
if [ "$g" != "md5" ] && [ "$g" != "filelist" ] && [ "$g" != ".package.files" ]; then |
||||||
|
if [ -f $1$g ]; |
||||||
|
then |
||||||
|
if [ "$g" != ".coauthors" ] && [ "$g" != "version_info" ]; then |
||||||
|
echo "++Redownload $1$g..." |
||||||
|
if [ -f "$1$g" ]; then |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $1$g |
||||||
|
else |
||||||
|
echo "===Could not find directory, assuming regular scripts directory exists." |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $LANGUAGE/scripts/$g |
||||||
|
fi |
||||||
|
fi |
||||||
|
else |
||||||
|
echo "++==Downloading $1$g..." |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $1$g |
||||||
|
fi |
||||||
|
fi |
||||||
|
done < /tmp/out |
||||||
|
fi |
||||||
|
fi |
||||||
|
if [ -f "$1/filelist" ]; |
||||||
|
then |
||||||
|
echo " filelist: http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1filelist" |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' -s "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1filelist" --output /tmp/out |
||||||
|
cmp -s $1/filelist /tmp/out |
||||||
|
if [ "$?" -ne 0 ] |
||||||
|
then |
||||||
|
echo " Differences detected!" |
||||||
|
cat /tmp/out |
||||||
|
while IFS= read -r line |
||||||
|
do |
||||||
|
IFS=':' read -ra split <<< $line |
||||||
|
g="${split[0]}" |
||||||
|
echo "LINE -- $g" |
||||||
|
if [ "$g" != "md5" ] && [ "$g" != "filelist" ] && [ "$g" != ".package.files" ]; then |
||||||
|
if [ -f $1$g ]; |
||||||
|
then |
||||||
|
if [ "$g" != ".coauthors" ] && [ "$g" != "version_info" ]; then |
||||||
|
echo "++Redownload $1$g..." |
||||||
|
if [ -f "$1$g" ]; then |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $1$g |
||||||
|
else |
||||||
|
echo "===Could not find directory, assuming regular scripts directory exists." |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $LANGUAGE/scripts/$g |
||||||
|
fi |
||||||
|
fi |
||||||
|
else |
||||||
|
echo "++==Downloading $1$g..." |
||||||
|
curl -H 'Cache-Control: no-cache, no-store' "http://sig.projectdivar.com/sigonasr2/SigScript/raw/branch/main/$1$g" --output $1$g |
||||||
|
fi |
||||||
|
fi |
||||||
|
done < /tmp/out |
||||||
|
fi |
||||||
|
fi |
||||||
|
for g in $FILES2 |
||||||
|
do |
||||||
|
if [ -d $1$g ]; |
||||||
|
then |
||||||
|
echo "$1$g is a directory" |
||||||
|
check $1$g/ |
||||||
|
fi |
||||||
|
done |
||||||
|
} |
Loading…
Reference in new issue