Compare commits
10 Commits
48bdc40932
...
735afe9982
Author | SHA1 | Date | |
---|---|---|---|
735afe9982 | |||
6b2bc43d79 | |||
1d1406bb2b | |||
fc50e669a5 | |||
60c6cb3bcd | |||
a799374399 | |||
281a31f5f7 | |||
74e2c1a3fd | |||
91b8b3b570 | |||
e5bbf2dc03 |
13
README.md
13
README.md
@ -14,10 +14,15 @@ Synopsis: `isidore <command> [options]`
|
||||
|
||||
Commands:
|
||||
|
||||
- `new [-i] <dir>`: create a new project directory `<dir>`. Use `-i` for
|
||||
interactive mode.
|
||||
- `build`: build the website (default).
|
||||
- `serve`, `server`: run an HTTP server of the output on port 8080.
|
||||
- `new [args] <dir>`: create a new project.
|
||||
- `<dir>`: new project directory.
|
||||
- `-i`: interactive mode.
|
||||
- `build [args]`: build the website.
|
||||
- `-j<n>`: number of jobs to run concurrently. With `0` it compiles all files
|
||||
at once.
|
||||
- `-v`: run with verbose output.
|
||||
- `serve`, `server [args]`: run an HTTP server of the output (default port 8080).
|
||||
- `-p <port>`: port number to bind server to.
|
||||
- `clean`: cleans build files.
|
||||
- `help`: show help information.
|
||||
- `version`: show Isidore version number.
|
||||
|
@ -4,7 +4,7 @@
|
||||
- New project subcommand
|
||||
- Basic project compilation
|
||||
- v0.2
|
||||
- Don't compile already compiled files
|
||||
- Multi-thread compiling
|
||||
- Helper functions & variables
|
||||
- v0.3
|
||||
- Markdown support
|
||||
|
132
isidore.sh
132
isidore.sh
@ -27,9 +27,9 @@ PROG_NAME=$0
|
||||
PROJECT_NAME="Isidore"
|
||||
|
||||
SOURCE_DIR="site/"
|
||||
TMP_DIR="/tmp/isidore-workdesk/"
|
||||
OUTPUT_DIR="output/"
|
||||
TEMPLATE_DIR="templates/"
|
||||
PROJECT_CONFIG_FILE="config.php"
|
||||
|
||||
##
|
||||
# Create the configuration file. This function is called if it does not already
|
||||
@ -92,11 +92,11 @@ function print_help()
|
||||
print_usage
|
||||
echo -e "\nCOMMANDS:
|
||||
new [-i] <dir>
|
||||
Create a new Isidore project (use interactive mode with '-i')
|
||||
build
|
||||
Create a new Isidore project
|
||||
build [-v] [-j<n>]
|
||||
Build the project rooted in the current directory
|
||||
serve | server
|
||||
Serve a local HTTP server of the output directory on port 8080
|
||||
serve | server [-p <port>]
|
||||
Serve a local HTTP server of the output directory
|
||||
clean
|
||||
Clean the built files
|
||||
version
|
||||
@ -110,7 +110,7 @@ function print_help()
|
||||
##
|
||||
function check_in_project()
|
||||
{
|
||||
if ! [ -f "./config.php" ] || ! [ -f "./.isidore-version" ]
|
||||
if ! [ -f "$PROJECT_CONFIG_FILE" ] || ! [ -f "./.isidore-version" ]
|
||||
then
|
||||
echo "ERROR: You are not currently in the root of an Isidore project."
|
||||
exit 1
|
||||
@ -128,9 +128,9 @@ function new_project()
|
||||
{
|
||||
echo "$PROJECT_NAME v$ISIDORE_VERSION"
|
||||
|
||||
NEW_PROJECT_DIR=$1
|
||||
NEW_PROJECT_NAME="New Project"
|
||||
NEW_PROJECT_URL="http://example.com/"
|
||||
local NEW_PROJECT_DIR=$1
|
||||
local NEW_PROJECT_NAME="New Project"
|
||||
local NEW_PROJECT_URL="http://example.com/"
|
||||
if [ $2 == 1 ]
|
||||
then
|
||||
echo -n "Project name: "
|
||||
@ -146,12 +146,12 @@ function new_project()
|
||||
\$site_name = \"$NEW_PROJECT_NAME\";
|
||||
\$site_author = \"$ISIDORE_AUTHOR_NAME\";
|
||||
\$site_url = \"$NEW_PROJECT_URL\";
|
||||
?>" >> $NEW_PROJECT_DIR/config.php
|
||||
?>" >> $NEW_PROJECT_DIR/$PROJECT_CONFIG_FILE
|
||||
echo "$ISIDORE_VERSION" > $NEW_PROJECT_DIR/.isidore-version
|
||||
|
||||
echo "New project created."
|
||||
[ $2 == 0 ] &&
|
||||
echo "Consider taking a look at the $NEW_PROJECT_DIR/config.php file."
|
||||
echo "Consider taking a look at the $NEW_PROJECT_DIR/$PROJECT_CONFIG_FILE file."
|
||||
}
|
||||
|
||||
##
|
||||
@ -169,41 +169,67 @@ function clean_project()
|
||||
|
||||
##
|
||||
# Build the project.
|
||||
#
|
||||
# Params:
|
||||
# $1 - Verbose flag
|
||||
# $2 - Maximum number of jobs to run
|
||||
##
|
||||
function build_project()
|
||||
{
|
||||
check_in_project
|
||||
|
||||
CFG_HEADER_FILE="$TMP_DIR/config-header.php"
|
||||
|
||||
mkdir -p $OUTPUT_DIR
|
||||
mkdir -p $TMP_DIR
|
||||
echo "<?php include(getcwd() . '/config.php'); ?>" > $CFG_HEADER_FILE
|
||||
|
||||
for i in $(find $SOURCE_DIR -type d)
|
||||
do
|
||||
mkdir -p $OUTPUT_DIR/${i:${#SOURCE_DIR}}
|
||||
mkdir -p $TMP_DIR/$i
|
||||
done
|
||||
|
||||
for i in $(find $SOURCE_DIR -name '*.php' -not -name '*.cfg.php')
|
||||
# number of current jobs
|
||||
local NUM_JOBS="\j"
|
||||
|
||||
for i in $(find site -type f -regextype posix-extended -not -regex '.*\.(cfg|CFG)\.(php|PHP)')
|
||||
do
|
||||
cat $CFG_HEADER_FILE $i > $TMP_DIR/$i
|
||||
: ${i:${#SOURCE_DIR}}
|
||||
OUT_FILE="$OUTPUT_DIR/${_: :-4}"
|
||||
php $TMP_DIR/$i > $OUT_FILE
|
||||
while (( $2 != 0 )) && (( ${NUM_JOBS@P} >= $2 ))
|
||||
do
|
||||
wait -n
|
||||
done
|
||||
|
||||
# parallel block
|
||||
(
|
||||
if [[ $i =~ .*\.(php|PHP) ]]
|
||||
then
|
||||
: ${i:${#SOURCE_DIR}}
|
||||
local OUT_FILE="$OUTPUT_DIR/${_: :-4}"
|
||||
if [ $1 == 1 ]
|
||||
then
|
||||
echo "Building $OUT_FILE ..."
|
||||
fi
|
||||
cat $PROJECT_CONFIG_FILE $i | php > $OUT_FILE
|
||||
else
|
||||
local OUT_FILE="$OUTPUT_DIR/${i:${#SOURCE_DIR}}"
|
||||
if [ $1 == 1 ]
|
||||
then
|
||||
echo "Copying $OUT_FILE ..."
|
||||
fi
|
||||
cp $i $OUT_FILE
|
||||
fi
|
||||
) &
|
||||
done
|
||||
|
||||
for i in $(find $SOURCE_DIR -type f -not -name '*.php')
|
||||
do
|
||||
cp $i $OUTPUT_DIR/${i:${#SOURCE_DIR}}
|
||||
done
|
||||
|
||||
rm -r $TMP_DIR
|
||||
# wait for jobs to finish
|
||||
wait -n
|
||||
}
|
||||
|
||||
set_config_vars
|
||||
|
||||
if [ $# -lt 1 ]
|
||||
then
|
||||
echo "No subcommand was specified. Use the 'help' subcommand."
|
||||
print_usage
|
||||
exit 1
|
||||
fi
|
||||
|
||||
case $1 in
|
||||
new)
|
||||
if [ $# -lt 2 ]
|
||||
@ -224,17 +250,59 @@ case $1 in
|
||||
then
|
||||
NEW_DIR="$i"
|
||||
else
|
||||
echo "Unknown argument for new '$i'. Use the 'help' command."
|
||||
echo "Unknown argument for new '$i'. Use the 'help' subcommand."
|
||||
print_usage
|
||||
exit 1
|
||||
fi
|
||||
fi;;
|
||||
esac
|
||||
done
|
||||
new_project $NEW_DIR $INTERACTIVE;;
|
||||
build)
|
||||
build_project;;
|
||||
VERBOSE=0
|
||||
JOBS=1
|
||||
for i in ${@:2}
|
||||
do
|
||||
case $i in
|
||||
-v)
|
||||
VERBOSE=1;;
|
||||
-j*)
|
||||
if ! [[ "$i" =~ ^-j[0-9]+$ ]]
|
||||
then
|
||||
echo "Argument '$i' badly formatted. Should be '-j<n>' where <n> is a number."
|
||||
print_usage
|
||||
exit 1
|
||||
fi
|
||||
JOBS=${i:2};;
|
||||
*)
|
||||
echo "Unknown argument for build '$i'. Use the 'help' subcommand."
|
||||
print_usage
|
||||
exit 1;;
|
||||
esac
|
||||
done
|
||||
build_project $VERBOSE $JOBS;;
|
||||
serve|server)
|
||||
php -S localhost:8080 -t $OUTPUT_DIR/;;
|
||||
PORT=8080
|
||||
shift
|
||||
while getopts "p:" opt
|
||||
do
|
||||
case $opt in
|
||||
p)
|
||||
if ! [[ "$OPTARG" =~ ^[0-9]+$ ]]
|
||||
then
|
||||
echo "Invalid port $OPTARG. Please enter a number."
|
||||
exit 1
|
||||
fi
|
||||
PORT=$OPTARG;;
|
||||
?)
|
||||
echo "Invalid argument $OPTARG. Use the 'help' subcommand."
|
||||
print_usage
|
||||
exit 1;;
|
||||
:)
|
||||
echo "Option -$OPTARG requires an argument."
|
||||
exit 1;;
|
||||
esac
|
||||
done
|
||||
php -S localhost:$PORT -t $OUTPUT_DIR/;;
|
||||
clean)
|
||||
clean_project;;
|
||||
help)
|
||||
@ -242,7 +310,7 @@ case $1 in
|
||||
version)
|
||||
echo "$PROJECT_NAME v$ISIDORE_VERSION";;
|
||||
*)
|
||||
echo "Unknown command $1. Use the 'help' command."
|
||||
echo "Unknown command $1. Use the 'help' subcommand."
|
||||
print_usage
|
||||
exit 1;;
|
||||
esac
|
||||
|
Loading…
Reference in New Issue
Block a user