Author: Nanda H Krishna
Organisation: Homebrew
Project: Adding a livecheck Formula DSL and migrating Livecheckables to homebrew/core
Mentors: Sam Ford, Mike McQuaid, Sean Molenaar, Rui Chen, Thierry Moisan
Homebrew has a brew livecheck
command which checks upstream sources (web pages, files, Git repositories) to identify the latest version of software in a formula. livecheck
uses its built-in strategies to identify versions for certain URLs and this works fine for some formulae. However, it is sometimes necessary to provide explicit information to livecheck
, telling it where to check and how to identify versions in the fetched content.
Prior to this GSoC project, these livecheck
instructions were found in the homebrew/livecheck tap's Livecheckables
folder. "Livecheckable" files were minimal substitutes for formulae and only consisted of a class with livecheck
information inside. Throughout livecheck
's development, there was a desire to eventually incorporate this information into homebrew/core formulae, so the livecheckable files were merely a stopgap measure.
The livecheck
information was originally formatted as a hash argument to a livecheck
method. While this format was functional, it didn't follow the existing norms within formulae and would need to be modified. Homebrew uses various domain-specific languages (DSLs) when establishing formula information, so it was necessary to add a livecheck
DSL to the Formula
class before the livecheck
information could be incorporated into homebrew/core formulae.
Adding the livecheck
DSL and incorporating the livecheckables into homebrew/core formulae were two expressed goals of this GSoC project. The livecheck
DSL was the first task that was completed and it was implemented early in the project. Due to the ongoing work on livecheckables in the homebrew/livecheck tap, we waited until close to the end of GSoC to migrate the livecheck
blocks into homebrew/core formulae.
Outside of these initial goals, we also decided to incorporate the brew livecheck
command into the main Homebrew/brew repository, making it a built-in developer command. Before this point, users were required to tap homebrew/livecheck to be able to use this command.
As a result of this project, the homebrew/livecheck tap is no longer needed and has been deprecated. Further work related to the brew livecheck
command will happen in Homebrew/brew and work on livecheck
blocks will happen in homebrew/core formulae.
- Implemented a
livecheck
DSL in Homebrew/brew and incorporated it into theFormula
class - Added support for the
livecheck
DSL to thebrew livecheck
command - Updated existing livecheckables to use the new DSL format
- Removed support for the old livecheckable format from
brew livecheck
- Added the ability to reference certain formula URLs as
url
symbol arguments (:head
,:homepage
,:stable
) - Updated livecheckables to use URL symbols, where possible
- Added autocompletion for
brew livecheck
- Added
url
information to the livecheckables that only contained a regex - Added livecheckables for some of the formulae that require an explicit check to be able to identify versions
- Updated existing livecheckables to bring them closer to current standards
- Integrated the
livecheck
blocks found in livecheckable files into their respective homebrew/core formulae - Integrated the
brew livecheck
command into Homebrew/brew as adev-cmd
- Removed all files from the homebrew/livecheck tap and deprecated it
- Add RuboCops to enforce standards for
livecheck
block information - Add/improve network-related
livecheck
tests - Other improvements to
livecheck
, including addinglivecheck
blocks to formulae, adding a progress bar for JSON output, documentation, etc.
- Before GSoC, I had zero knowledge of Ruby. As an aspiring polyglot (human and programming languages), learning a new language was a fun challenge. Ruby is now one of my favourite languages and I definitely see myself brewing up projects using it.
- Homebrew has a huge codebase, it took quite some time to wrap my head around some of the internals that were central to this project.
- I had other work alongside this project, and one of the biggest challenges was time management. I identified a few strategies that worked for me, and I was able to plan ahead and complete my work efficiently.
- I was able to automate some of the work by writing scripts, something I enjoy doing. With this I was able to identify what tasks could be automated and how, complete them quickly and gain some extra Ruby knowledge.
- My code quality has definitely improved, thanks to detailed reviews from the mentors. I'm working on improving the quality of my documentation and tests.
I'd like to thank my mentors for helping me throughout this project. A special shoutout to my primary mentor Sam for their amazing and comprehensive code reviews and guidance. I enjoyed our weekly meetings and am extremely grateful to them for taking the time to answer all my questions. The Homebrew community is welcoming and friendly, and the maintainers are just brilliant. I'm glad I got an opportunity to work closely with them thanks to GSoC, and I'm looking forward to contributing to Homebrew in the future. I'd also like to acknowledge my wonderful co-GSoCers, rmNULL and Vidushee Amoli, it was great fun working with them.
- #7179 - Livecheck Formula DSL
- #7578 - livecheck: add component order rubocop
- #7625 - livecheck: modified urls cop
- #7668 - livecheck: reference Formula URLs
- #7671 - livecheck: modify regex in tests
- #7748 - Add completion for livecheck
- #8180 - livecheck migration: add
brew livecheck
developer command - #8254 - livecheck migration: create Homebrew::Livecheck
- #8255 - livecheck migration: add strategies
- #8544 - livecheck: remove test for
livecheck_formulae
- #40791 - anime-downloader 3.6.3 (new formula)
- #45722 - anime-downloader 4.0.1
- #54565 - Add livecheck block to a52dec.rb
- #54595 - aacgain: add livecheck block
- #54597 - imap-uw: add livecheck block
- #55321 - detekt: update homepage
- #55950 - livecheck: modify Formula urls
- #56290 - ossp-uuid: update homepage
- #57627 - aacgain: update livecheck regex
- #58760 - vsts-cli: deprecate
- #60324 - livecheck: migrate livecheckables to livecheck blocks
- #235 - anime-downloader: add livecheckable
- #237 - [WIP] Adding livecheckables for formulae
- #238 - aamath: add livecheckable
- #239 - a52dec: add livecheckable
- #240 - aacgain: add livecheckable
- #241 - abuse: add livecheckable
- #242 - aardvark_shell_utils: add livecheckable
- #243 - lrzip: add livecheckable
- #247 - aalib: add livecheckable
- #555 - Add support for livecheck DSL
- #745 - Update PyPI livecheck urls
- #747 - archey: update url
- #748 - freetds: update url
- #749 - castxml: update url
- #750 - checkbashisms: update url
- #751 - dpkg: update url
- #752 - fakeroot: update url
- #753 - Fix style offenses in livecheck.rb and utils.rb
- #762 - closure-compiler: update url
- #764 - Convert Livecheckables from Hashes to blocks
- #766 - detekt: update url
- #767 - spice-protocol: update regex
- #768 - plzip: update url and regex
- #769 - livecheck: remove support for hash format
- #775 - Fix Livecheck object instantiation
- #779 - anttweakbar: skip livecheck
- #786 - acme: add livecheckable
- #787 - mosquitto: update url and regex
- #788 - gradle: add livecheckable
- #789 - telnet: add livecheckable
- #792 - mysql-client: add livecheckable
- #793 - bash-completion: add livecheckable
- #794 - scala: add livecheckable
- #795 - libmagic: add livecheckable
- #796 - metis: add livecheckable
- #798 - s-lang: add livecheckable
- #799 - popt: add livecheckable
- #800 - libspatialite: add livecheckable
- #801 - openssh: add livecheckable
- #802 - sdl: add livecheckable
- #803 - ldns: add livecheckable
- #804 - mecab: add livecheckable
- #818 - Reference Formula urls in Livecheckables
- #820 - openjdk: add livecheckable
- #821 - arpoison: add livecheckable
- #822 - fltk: add livecheckable
- #823 - md5sha1sum: add livecheckable
- #824 - algol68g: add livecheckable
- #825 - figlet: add livecheckable
- #826 - epstool: add livecheckable
- #827 - texi2html: skip
- #828 - lrzsz: add livecheckable
- #829 - pstree: add livecheckable
- #830 - makedepend: add livecheckable
- #831 - git-crypt: add livecheckable
- #832 - libcaca: add livecheckable
- #833 - sdl_ttf: add livecheckable
- #834 - sdl_mixer: add livecheckable
- #835 - sdl_image: add livecheckable
- #836 - phpmyadmin: add livecheckable
- #837 - nkf: add livecheckable
- #838 - qhull: add livecheckable
- #844 - media-info: add livecheckable
- #845 - testdisk: add livecheckable
- #846 - selenium-server-standalone: add livecheckable
- #847 - cairomm: add livecheckable
- #848 - bzip2: add livecheckable
- #849 - minicom: add livecheckable
- #850 - libelf: add livecheckable to skip
- #851 - mplayer: add livecheckable
- #855 - neo4j: add livecheckable
- #856 - avrdude: add livecheckable
- #857 - libftdi0: add livecheckable
- #858 - libftdi: add livecheckable
- #859 - ossp-uuid: add livecheckable
- #861 - libhid: add livecheckable
- #862 - xpdf: add livecheckable
- #863 - ipcalc: add livecheckable
- #864 - newt: add livecheckable
- #865 - iftop: add livecheckable
- #866 - fcrackzip: add livecheckable
- #867 - lxc: add livecheckable
- #868 - less: add livecheckable
- #869 - oath-toolkit: add livecheckable
- #870 - Add completion for livecheck
- #871 - dependency-check: add livecheckable
- #872 - rethinkdb: add livecheckable
- #873 - libyubikey: add livecheckable
- #874 - pssh: add livecheckable
- #875 - john: add livecheckable
- #876 - notmuch: add livecheckable
- #879 - pyside: add livecheckable
- #880 - tnftp: add livecheckable
- #881 - libspectre: add livecheckable
- #882 - hping: add livecheckable to skip
- #883 - rpm2cpio: add livecheckable
- #884 - pure-ftpd: add livecheckable
- #885 - mit-scheme: add livecheckable
- #886 - corkscrew: add livecheckable
- #887 - cvs: add livecheckable
- #888 - msmtp: add livecheckable
- #889 - desktop-file-utils: add livecheckable
- #891 - smpeg: add livecheckable
- #915 - tcping: add livecheckable
- #916 - ncftp: add livecheckable
- #917 - neon: add livecheckable
- #918 - argp-standalone: add livecheckable
- #919 - mp4v2: add livecheckable
- #920 - markdown: add livecheckable
- #921 - ispell: add livecheckable
- #922 - pidof: add livecheckable
- #923 - clisp: add livecheckable
- #924 - mariadb-connector-c: add livecheckable
- #925 - ucl: add livecheckable
- #926 - juju: add livecheckable
- #927 - cloog: add livecheckable
- #928 - jhead: add livecheckable
- #929 - spidermonkey: add livecheckable
- #930 - sleepwatcher: add livecheckable
- #938 - foremost: add livecheckable
- #939 - swaks: add livecheckable
- #940 - libstfl: add livecheckable
- #941 - sdl_sound: add livecheckable
- #942 - gst-python: add livecheckable
- #943 - megatools: add livecheckable
- #944 - rmtrash: add livecheckable
- #945 - bsdiff: add livecheckable
- #946 - pip-completion: add livecheckable
- #947 - nexus: add livecheckable
- #950 - libotr: add livecheckable
- #951 - pdflib-lite: add livecheckable to skip
- #952 - blast: add livecheckable
- #953 - libsvg: add livecheckable
- #954 - libedit: add livecheckable
- #955 - vsftpd: add livecheckable
- #956 - procmail: add livecheckable
- #957 - superlu: add livecheckable
- #958 - base64: add livecheckable
- #959 - scalapack: add livecheckable
- #960 - eye-d3: add livecheckable
- #961 - rarian: add livecheckable
- #962 - pcsc-lite: add livecheckable
- #963 - grace: add livecheckable
- #964 - minizip: add livecheckable
- #965 - ncview: add livecheckable
- #966 - libsvm: add livecheckable
- #967 - vbindiff: add livecheckable
- #968 - ntp: add livecheckable
- #969 - antiword: add livecheckable
- #970 - sdl_net: add livecheckable
- #971 - ecm: add livecheckable to skip
- #972 - bootloadhid: add livecheckable
- #973 - tcptrace: add livecheckable
- #974 - bcrypt: add livecheckable
- #975 - toilet: add livecheckable
- #976 - most: add livecheckable
- #977 - libsvg-cairo: add livecheckable
- #978 - reaver: add livecheckable
- #979 - lv: add livecheckable to skip
- #980 - opencascade: add livecheckable
- #981 - kim-api: add livecheckable
- #982 - libreplaygain: add livecheckable
- #983 - libcuefile: add livecheckable
- #984 - musepack: add livecheckable
- #985 - ballerina: add livecheckable
- #986 - basex: add livecheckable
- #987 - libagg: add livecheckable to skip
- #988 - asciiquarium: add livecheckable
- #989 - ec2-api-tools: add livecheckable
- #990 - mmv: add livecheckable
- #991 - sloccount: add livecheckable
- #992 - stress: add livecheckable
- #993 - crowdin: add livecheckable
- #994 - hmmer: add livecheckable
- #995 - ifstat: add livecheckable
- #996 - node_exporter: add livecheckable
- #997 - confluent-platform: add livecheckable
- #998 - httperf: add livecheckable
- #1000 - sipcalc: add livecheckable
- #1001 - gst-plugins-bad: update regex
- #1002 - gst-plugins-base: update regex
- #1003 - gst-plugins-good: update regex
- #1004 - gst-plugins-ugly: update regex
- #1005 - gstreamer: update regex
- #1006 - gst-libav: update regex
- #1007 - gst-editing-services: add livecheckable
- #1008 - gst-rtsp-server: add livecheckable
- #1009 - gst-validate: add livecheckable
- #1021 - ttyrec: add livecheckable
- #1023 - dyld-headers: add livecheckable
- #1027 - dns2tcp: add livecheckable
- #1028 - ucspi-tcp: add livecheckable
- #1029 - libestr: add livecheckable
- #1030 - bbftp-client: add livecheckable
- #1031 - wmctrl: add livecheckable
- #1032 - dmg2img: add livecheckable
- #1033 - fastqc: add livecheckable
- #1046 - Add url to Livecheckables
- #1047 - sdl_gfx: add livecheckable
- #1050 - cadaver: add livecheckable
- #1051 - mockserver: add livecheckable
- #1056 - moarvm: add livecheckable
- #1057 - pwncat: add livecheckable
- #1061 - Change
\.j
to\.jar
in regex - #1062 - Change
\.tar
variants to\.t
in regex - #1063 - Change
\.z
to\.zip
in regex - #1064 - bcftools: update url and regex
- #1065 - byacc: update regex
- #1066 - c-ares: update regex
- #1067 - iozone: update url and regex
- #1068 - libpst: update regex
- #1069 - libsamplerate: update regex
- #1070 - lua: update regex
- #1071 - lynx: update regex
- #1072 - lzip: update regex
- #1073 - rsync: update regex
- #1074 - siege: update regex
- #1075 - speex: update regex
- #1076 - tokyo-cabinet: update regex
- #1077 - xvid: update regex
- #1083 - Update Livecheckables using GitHub releases page
- #1090 - wiggle: update url and regex
- #1091 - mbedtls: update livecheckable
- #1092 - python: rename to [email protected], update regex
- #1124 - Improve regexes containing
href=.*
- #1125 - Improve regexes containing
href=.+
andhref=.+?
- #1127 - Change
href=".*
andhref=".*?
tohref=.*?
- #1128 - Change
[ '">]
to["' >]
- #1141 - Change
href="
followed by name tohref=.*?
- #1142 - Change
href="
followed by version directory tohref=.*?
- #1143 - jenkins-lts: update regex
- #1144 - bashdb: update regex
- #1145 - libwps: update regex
- #1146 - remake: update regex
- #1147 - vault: update regex
- #1151 - Change
href="
followed by path tohref=.*?
- #1152 - Change
href=".*?/
tohref=.*?
- #1153 - Change
url=.+?
tourl=.*?
- #1154 - bcpp: update regex
- #1155 - chkrootkit: update regex
- #1156 - daq: update regex
- #1157 - etsh: update regex
- #1158 - exiftool: update regex
- #1160 - fizmo: update regex
- #1161 - fs-uae: update url and regex
- #1162 - gcc: update regex
- #1163 - ghc: update url and regex
- #1164 - gwenhywfar: update regex
- #1165 - nss: update url and regex
- #1167 - Update PyPI urls to stable Formula urls
- #1168 - opus: update url and regex
- #1169 - packer: update url and regex
- #1170 - qrencode: update regex
- #1171 - qtfaststart: update url and regex
- #1172 - r: update regex
- #1173 - sane-backends: update url and regex
- #1174 - strongswan: update url and regex
- #1175 - terraform: update url and regex
- #1176 - zanata-client: update url and regex
- #1187 - mbedtls: update regex
- #1188 - Change remaining
href=".*?
tohref=.*?
- #1189 - Make Livecheckable regexes case-insensitive
- #1203 - Update
([0-9.]+)
in regexes - #1210 - Update
HREF="
tohref=.*?
in regexes - #1211 - Update
([0-9.]+)
tov?(\d{6,8})
in regexes - #1212 - Update
([0-9,.]+)
tov?(\d+(?:\.\d+)+)
in regexes - #1213 - bmake: update regex
- #1214 - Update capture group in versioned regexes
- #1215 - txr: update regex
- #1216 - diffoscope: remove livecheckable
- #1217 - abcmidi: update regex
- #1218 - cppad: update regex
- #1219 - Update multiple
[0-9.]+
tov?(\d+(?:\.\d+)+)
in regexes - #1220 - freetype: update regex
- #1222 - Update regex for [email protected] and [email protected]
- #1224 - Update
[0-9.-]
and[0-9.\-]
in regexes - #1225 - dialog: update regex
- #1226 - percona-server: update regex
- #1227 - percona-toolkit: update regex
- #1231 - autossh: update regex
- #1232 - Update regexes containing
a-z
and0-9
- #1233 - jpeg: update url and regex
- #1234 - openrtsp: update regex
- #1235 - readosm: update regex
- #1236 - vsts-cli: remove livecheckable
- #1244 - Update delimiter before
v?
to[._-]
- #1246 - Update delimiter before capturing group to
[._-]
and addv?
- #1339 - Delete Tap files