diff options
author | Igor Pashev <pashev.igor@gmail.com> | 2021-07-17 18:10:34 +0200 |
---|---|---|
committer | Igor Pashev <pashev.igor@gmail.com> | 2021-07-17 18:46:16 +0200 |
commit | 48459559a13a20083fc9b31eb523b8ea2bf0a63f (patch) | |
tree | 1c04e75709457403110a6f8c5c90099f22369de3 /tools | |
parent | 0c39509d9b6a58958228cebf5d643598e5c98950 (diff) | |
parent | 46099e79defe662e541b12548200caf29063c1c6 (diff) | |
download | pandoc-48459559a13a20083fc9b31eb523b8ea2bf0a63f.tar.gz |
Merge branch 'master' of https://github.com/jgm/pandoc
Diffstat (limited to 'tools')
-rw-r--r-- | tools/build-arm.sh | 110 | ||||
-rwxr-xr-x | tools/changelog-helper.sh | 15 | ||||
-rw-r--r-- | tools/parseTimings.pl | 33 |
3 files changed, 154 insertions, 4 deletions
diff --git a/tools/build-arm.sh b/tools/build-arm.sh new file mode 100644 index 000000000..dc275e4b2 --- /dev/null +++ b/tools/build-arm.sh @@ -0,0 +1,110 @@ +#!/bin/sh + +#old version: +#IMAGE_ID=ami-0fa8979d18f69948b +IMAGE_ID=ami-0cd6b53a434812702 +INSTANCE_TYPE=t4g.2xlarge +KEY_NAME=debian-arm-us-east-2 +SECURITY_GROUP_ID=sg-086ffbadc286c5c00 +ARTIFACTS="${ARTIFACTS:-build-artifacts-$(date +%s)}" + +STARTTIME=$(date +%H:%M) + +# Spin up an ARM build machine using aws cli, build pandoc, and +# download the artifact. +# +# We need to use us-east-2; since my us-west-1 has EC2-classic. +# docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-classic-platform.html + +aws configure set default.region us-east-2 + +echo "Creating instance..." + +aws ec2 run-instances --image-id "$IMAGE_ID" --count 1 --instance-type "$INSTANCE_TYPE" --block-device-mapping 'DeviceName=/dev/xvda,Ebs={VolumeSize=16}' --key-name "$KEY_NAME" --security-group-ids "$SECURITY_GROUP_ID" > ec2.json + +jq < ec2.json + +# Now get the public IP address. + +INSTANCEID=$(jq '.Instances[0].InstanceId' ec2.json | sed -e 's/"//g') +IPADDR=$(aws ec2 describe-instances --instance-ids="$INSTANCEID" --query 'Reservations[0].Instances[0].PublicIpAddress' | sed -e 's/"//g') + +echo "IP address is $IPADDR" + +clean_up() { + echo "Terminating the instance in 20 seconds..." + echo "Ctrl-C to preserve it." + sleep 20 && aws ec2 terminate-instances --instance-ids "$INSTANCEID" +} +trap clean_up EXIT + +echo "Waiting for instance to start up..." + +STATUS=none +while [ "$STATUS" != "running" ] +do + sleep 20 + STATUS=$(aws ec2 describe-instance-status --instance-id "$INSTANCEID" | jq '.InstanceStatuses[0].InstanceState.Name' | sed -e 's/"//g') + echo "...$STATUS" +done + +# At this point you can connect via SSH, or run this script: +# $ ssh -i ~/.ssh/debian-arm-us-east-2.pem admin@$IPADDR + +ssh -o "StrictHostKeyChecking=no" -i "~/.ssh/$KEY_NAME.pem" admin@$IPADDR uname -a + +SSH="ssh -i ~/.ssh/$KEY_NAME.pem admin@$IPADDR" + +echo "Provisioning..." + +$SSH <<EOF +sudo apt-get update +sudo apt-get upgrade -y +sudo apt-get install -y apt-transport-https ca-certificates curl gnupg git make +curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg +echo \ + "deb [arch=arm64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian \ + \$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list +sudo apt-get update +sudo apt-get install -y docker-ce docker-ce-cli containerd.io +sudo groupadd docker +sudo usermod -aG docker admin +EOF + +echo "Building..." + +($SSH <<EOF +mkdir src +cd src || exit +git clone https://github.com/jgm/pandoc +cd pandoc || exit +make debpkg +EOF +) & + +# Now we need to wait for the build to complete (this can take 3 hours). + +while true +do + sleep 20 + # print last line of log output and free memory + $SSH "tail -n1 src/pandoc/docker.log && free -h | grep Mem" + # Check to see if the artifact has been produced + $SSH "ls -l src/pandoc/linux/artifacts/DONE 2>/dev/null" && break +done + +# Retrieve the artifacts + +echo "Successful build. Retrieving artifacts..." + +scp -i "$HOME/.ssh/$KEY_NAME.pem" -r "admin@$IPADDR:src/pandoc/linux/artifacts" "$ARTIFACTS" + +echo "Artifacts saved in $ARTIFACTS" +ls "$ARTIFACTS" + +ENDTIME=$(date +%H:%M) + +echo "Started: $STARTTIME" +echo "Finished: $ENDTIME" + +exit 0 diff --git a/tools/changelog-helper.sh b/tools/changelog-helper.sh index 3608e96f5..d5c950bf8 100755 --- a/tools/changelog-helper.sh +++ b/tools/changelog-helper.sh @@ -2,11 +2,11 @@ # generate preliminary list of changes since changelog # was last modified -lastmod=`git log -n2 --format=oneline changelog | awk '{print $1;}'` -#git log --format=oneline $starthash..HEAD -files=`git ls-tree -r master --name-only` +lastmod=`git log -n1 --format=oneline changelog.md | awk '{print $1;}'` +files=`git ls-tree -r master --name-only | grep --invert-match '^test\/\|^data\/docx\/\|^data\/odt\/\|^data\/pptx\/\|^citeproc\/\|^data\/translations\/'` for x in $files do + echo $x 1>&2 commits=`git log -n1 $lastmod..HEAD $x` if [ ! -z "$commits" ] then @@ -17,7 +17,14 @@ do file=$x fi echo " * $file" - GIT_PAGER=cat git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' -- "$lastmod..HEAD" "$x" + git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" "$x" fi done +echo "test/" 1>&2 +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" test/ +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" data/docx/ +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" data/odt/ +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" data/pptx/ +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" data/translations/ +git log --pretty=format:'%n%w(78,4,6)+ %s (%aN)%n%n%w(78,6,6)%b%n' "$lastmod..HEAD" citeproc/ diff --git a/tools/parseTimings.pl b/tools/parseTimings.pl new file mode 100644 index 000000000..aa12bfabb --- /dev/null +++ b/tools/parseTimings.pl @@ -0,0 +1,33 @@ +#!/usr/bin/env perl + +# Breaks down compilation time and memory usage by module. +# To use this script, do +# +# stack clean +# stack build --ghc-options='-dshow-passes' 2>output.txt +# perl parseTimings.pl output.txt + +while (<>) { + if (/!!! (.*) \[(.*)\]: finished in (.*) milliseconds, allocated (.*) megabytes/) { + $phase = $1; + $module = $2; + $milliseconds = $3; + $megabytes = $4; + if (!$timings{$module}) { + $timings{$module} = {'milliseconds' => 0, 'megabytes' => 0}; + }; + $timings{$module}{'milliseconds'} += $milliseconds; + $timings{$module}{'megabytes'} += $megabytes; + } + } + printf("%10s %10s %s\n", "Time (ms)", "Alloc (Mb)", "LOC", "Module"); + for (keys %timings) { + $path = $_; + $path =~ s/\./\//g; + $path = "src/$path.hs"; + $loc = `wc -l $path 2>/dev/null`; + if ($loc) { + $loc =~ s/^\s*(\d+).*/\1/; + printf("%10d %10d %6d %s\n", $timings{$_}{'milliseconds'}, $timings{$_}{'megabytes'}, $loc, $_); + } +} |