Implement SigScript system and pipeline into project

Co-authored-by: sigonasr2 <sigonasr2@gmail.com>
main
sigonasr2, Sig, Sigo 2 years ago committed by GitHub
parent f9c2300ced
commit c68bd89820
  1. 7
      C/scripts/build.sh
  2. 20
      C/scripts/commit.sh
  3. 2
      C/scripts/filelist
  4. 2
      C/scripts/md5
  5. BIN
      CProjectTemplate
  6. 19
      README.md
  7. 15
      install
  8. BIN
      main
  9. 2
      main.c
  10. 9
      sig
  11. 1
      utils/.coauthors
  12. 4
      utils/.updateDirectories
  13. 26
      utils/define.sh
  14. 7
      utils/filelist
  15. 28
      utils/main.sh
  16. 6
      utils/md5
  17. 103
      utils/search.sh
  18. 6
      utils/utils.c
  19. 1
      utils/utils.h

@ -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:dbb1880f6b747ec208d6f277c0be61c2 -
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

BIN
main

Binary file not shown.

@ -1,6 +1,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <ncurses.h> #include <ncurses.h>
#include "extras.h" #include "extras.h"
#include "utils/utils.h"
int main(int argc,char**argv) { int main(int argc,char**argv) {
int rows,cols; int rows,cols;
@ -21,6 +22,7 @@ int main(int argc,char**argv) {
addch(ACS_BTEE); addch(ACS_BTEE);
addch(' '); addch(' ');
writeExtras(); writeExtras();
testReach();
mvaddch(5,17,ACS_DARROW); mvaddch(5,17,ACS_DARROW);
attron(COLOR_PAIR(1)); attron(COLOR_PAIR(1));

9
sig

@ -0,0 +1,9 @@
export AUTO_UPDATE=true
source utils/define.sh
define PROJECT_NAME "main"
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,7 @@
.coauthors
define.sh
main.sh
search.sh
.updateDirectories
utils.c
utils.h

@ -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,6 @@
define.sh:3ecab0dffe2adfb950f3eb7c7061b750 -
main.sh:d3d1bd0b56d8114eb7479964227f8576 -
search.sh:81d08f5ff48e8a44b5f68387d426da05 -
.updateDirectories:fa5e95db12be22ae8aed7ecbc560e38c -
utils.c:dda26981cc7c9e9a62110e8db54e582f -
utils.h:324dca30e95cbdf1effb042813da858d -

@ -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: https://raw.githubusercontent.com/sigonasr2/SigScript/main/$1md5"
curl -H 'Cache-Control: no-cache, no-store' -s "https://raw.githubusercontent.com/sigonasr2/SigScript/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' "https://raw.githubusercontent.com/sigonasr2/SigScript/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' "https://raw.githubusercontent.com/sigonasr2/SigScript/main/$1$g" --output $LANGUAGE/scripts/$g
fi
fi
else
echo "++==Downloading $1$g..."
curl -H 'Cache-Control: no-cache, no-store' "https://raw.githubusercontent.com/sigonasr2/SigScript/main/$1$g" --output $1$g
fi
fi
done < /tmp/out
fi
fi
if [ -f "$1/filelist" ];
then
echo " filelist: https://raw.githubusercontent.com/sigonasr2/SigScript/main/$1filelist"
curl -H 'Cache-Control: no-cache, no-store' -s "https://raw.githubusercontent.com/sigonasr2/SigScript/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' "https://raw.githubusercontent.com/sigonasr2/SigScript/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' "https://raw.githubusercontent.com/sigonasr2/SigScript/main/$1$g" --output $LANGUAGE/scripts/$g
fi
fi
else
echo "++==Downloading $1$g..."
curl -H 'Cache-Control: no-cache, no-store' "https://raw.githubusercontent.com/sigonasr2/SigScript/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
}

@ -0,0 +1,6 @@
#include <ncurses.h>
#include "utils.h"
void testReach() {
addch(ACS_DEGREE);
}

@ -0,0 +1 @@
void testReach();
Loading…
Cancel
Save