6 minutes
Git Submodules…
I know I am not supposed to use them…
I love static sites, and I run this one with Hugo – it’s awesome. Anyways, the way I add the theme to the site is by including the git repo of the theme in the repo that tracks this site. It is not just dropped in mess with all the git configurations. It is added as a git submodule to mess with all the git configurations. I have read countless articles, and have has first hand expierence, about how submodules are usually not worth the headache. I had to re-learn that lesson again today.
After trying to get back into posting on the blog I was trying to see some changes locally before I pushed to my dev branch. I have the dev branch automatically building on Netlify but I wanted a “cleaner” git history so I wanted to see my unstanged changes locally. So I fired up the server on my hugo install:
The -D
will build the drafts so I can see unpublished posts.
After seeing a bunch of “warnings” (I assumed there might be some issue because I am running locally) I was presented with a blank page… I assumed that server was not working. I am running the server via wsl and trying to get to it from my windows desktop targeting localhost:1313
. So I tried a few different browsers – nothing. Then I tried running nc
from the wsl terminal:
So I can confirm that the server is, in fact running, and that it was responding and serving something. So I then moved to my windows desktop and attempted a telnet. At first I got an error, and then realized that I needed to “enable” telnet:
After a short wait I had good ole telnet and was able to run open localhost 1313
At this point I am thinking there is just some problem with hugo. After enableing more logging by passing the -v
flag to the hugo server command it finally hit me that I am just seeing a blank page because the site cannot be rendered properly and that is handled by the theme. To test out this theory I enabled another theme by updating the config.toml
And then made sure to add the theme to my repo:
As soon as I saw the new theme next to my original one, I knew something was up… The new theme had files in the directory, and mine was empty… After launching the hugo server again, I was no longer presented with a blank page at localhost:1313. Finally I realized that I had a directory that was supposed to be a submodule and all the files were missing. So I just checked around realy quick on how to run a “git pull” on a submodule and found this:
No luck, still no files. So I said forget it, I will just delete the folder and then recreate the submodule. This led to new problems becasue that directory was being tracked by git as a submodule. I didn’t want to commit any of this and futher pollute the history. The next step was to check the index with ls-files
. This turned out to do the trick for me.
This showed the directory! At that point I just removed it with:
Finally I was able to add it back
Hopefully putting this info on the blog will help me get to it faster, because I just added the submodule back to my repo :).
1094 Words
2021-04-05 01:23 +0000