Skip to content

Instantly share code, notes, and snippets.

@paulp
Created June 27, 2017 22:12
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save paulp/a5f068714d641a39a34c524ef500dc1d to your computer and use it in GitHub Desktop.
Save paulp/a5f068714d641a39a34c524ef500dc1d to your computer and use it in GitHub Desktop.
#!/usr/bin/env bash
#
set -euo pipefail
# set -x
export PROJECT SCOPE
# This setup echos the times to stderr as they accrue, then
# prints the whole list sorted by time to stdout when complete.
IFS='\n'
declare -a results=()
for file in "$@"; do
elapsed="$( quasar-scalac -S-Ystop-after:typer "$file" |& tail -n1 | perl -pe 's#^.*?[\s+]\[(.*?)\]#\1#' )"
results+=( "$( printf "%-12s %s\n" $elapsed "$file" | tee /dev/stderr )" )
done
printf "\nSorted times:\n\n"
printf "%s\n" "${results[@]}" | gsort -nr
# PROJECT=foundation quasar-scalac-timings foundation/src/main/scala/**/*e*.scala
# 0.533s foundation/src/main/scala/quasar/Predef.scala
# 1.993s foundation/src/main/scala/quasar/RenderTree.scala
# 0.386s foundation/src/main/scala/quasar/concurrent/NamedDaemonThreadFactory.scala
# 0.528s foundation/src/main/scala/quasar/fp/ExternallyManaged.scala
# 0.568s foundation/src/main/scala/quasar/fp/TaskRef.scala
# 0.453s foundation/src/main/scala/quasar/fp/binder/Binder.scala
# 0.826s foundation/src/main/scala/quasar/fp/binder/package.scala
# 0.577s foundation/src/main/scala/quasar/fp/catchable.scala
# 0.785s foundation/src/main/scala/quasar/fp/eitherT.scala
# 0.536s foundation/src/main/scala/quasar/fp/enumeratee.scala
# 0.627s foundation/src/main/scala/quasar/fp/free/Interpreter.scala
# 0.616s foundation/src/main/scala/quasar/fp/free/package.scala
# 0.589s foundation/src/main/scala/quasar/fp/kleisli.scala
# 0.640s foundation/src/main/scala/quasar/fp/numeric/package.scala
# 2.823s foundation/src/main/scala/quasar/fp/package.scala
# 0.795s foundation/src/main/scala/quasar/fp/process.scala
# Sorted times:
# 2.823s foundation/src/main/scala/quasar/fp/package.scala
# 1.993s foundation/src/main/scala/quasar/RenderTree.scala
# 0.826s foundation/src/main/scala/quasar/fp/binder/package.scala
# 0.795s foundation/src/main/scala/quasar/fp/process.scala
# 0.785s foundation/src/main/scala/quasar/fp/eitherT.scala
# 0.640s foundation/src/main/scala/quasar/fp/numeric/package.scala
# 0.627s foundation/src/main/scala/quasar/fp/free/Interpreter.scala
# 0.616s foundation/src/main/scala/quasar/fp/free/package.scala
# 0.589s foundation/src/main/scala/quasar/fp/kleisli.scala
# 0.577s foundation/src/main/scala/quasar/fp/catchable.scala
# 0.568s foundation/src/main/scala/quasar/fp/TaskRef.scala
# 0.536s foundation/src/main/scala/quasar/fp/enumeratee.scala
# 0.533s foundation/src/main/scala/quasar/Predef.scala
# 0.528s foundation/src/main/scala/quasar/fp/ExternallyManaged.scala
# 0.453s foundation/src/main/scala/quasar/fp/binder/Binder.scala
# 0.386s foundation/src/main/scala/quasar/concurrent/NamedDaemonThreadFactory.scala
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment