Perplexity actually wrote this blog post (to avoid conflicts of interest when criticizing ChatGPT). I edited this blog post to look human.
Key Takeaways
These are the big takeaways from my perspective when writing this post. My takeaways are subject to change.
-
ChatGPT Excels at Granular Tasks
When asked specific questions (e.g., “How do I override a Jekyll layout?”), ChatGPT provided clear, actionable steps. -
High-Level Guidance Leads to Better Results
By asking for broader guidance first (e.g., “How do I set up a blog with this theme?”), I could refine my queries to get more targeted help later. -
Role-Playing Enhances Context
Assigning ChatGPT a role (e.g., “You are my coding assistant”) helped it tailor responses more effectively. Additionally, providing context through conversation improved its suggestions. -
AI Has Limits
ChatGPT is beneficial, the lack of full project context occasionally led to overly complex solutions. Combining its advice with trial and error (testing) worked great.
Building a Blog Site with GitHub Pages Using the So Simple Jekyll Theme
I built this site using the So Simple Jekyll Theme, guided by ChatGPT, and hosted it on GitHub pages. I had never built a Jekyll site before, and I thought it would be easier with ChatGPT.
The Process
Here’s how I built my blog site:
- Cloning the Theme
ChatGPT suggested starting by cloning the So Simple Jekyll theme repository. This theme is minimalistic and highly customizable, making it perfect for a clean blog design. The steps included:- Adding the theme to my GitHub repository using the
remote_theme
method in_config.yml
. - Running
bundle install
locally to set up dependencies.
- Adding the theme to my GitHub repository using the
- Customizing the Blog
Based on ChatGPT’s recommendations, I modified various aspects of the theme:- Updated
_config.yml
to reflect my blog’s title, description, and preferred settings. - Customized layouts and styles by overriding specific files (e.g.,
_includes
and_layouts
). - Tweaked colors and fonts in
assets/css/main.scss
.
- Updated
- Debugging Issues
Debugging was not fun. Some of ChatGPT’s suggestions worked seamlessly, while others required adjustments due to missing context or overly detailed solutions that introduced new challenges. For example:- Fixing broken links caused by incorrect paths in
_config.yml
. - Resolving layout conflicts by carefully reviewing theme documentation.
- Fixing broken links caused by incorrect paths in
Challenges with ChatGPT
- Contextual Gaps: Without full visibility into my project files, ChatGPT sometimes made incorrect assumptions.
- Overly Detailed Solutions: At times, its responses were too intricate for simple problems, leading to unnecessary complications.
Recommendations for Working with ChatGPT
- Start Broad, Then Go Deep: Begin with high-level questions before diving into specifics.
- Provide Context: Share relevant details about your project to improve response accuracy.
- Test Incrementally: Implement changes step-by-step to catch errors early.
- Use Documentation: Supplement AI guidance with official documentation for themes or tools you’re using.
- Engage in Dialogue: Treat interactions as a conversation—clarify responses and iterate on solutions.
Conclusion
Building this blog showcased the strengths and limitations of AI tools like ChatGPT. The trick was leveraging ChatGPT’s granular expertise while maintaining oversight of the bigger picture because ChatGPT doesn’t replace your skills.
Citations: [1] https://github.com/mmistakes/so-simple-theme [2] https://www.sugarscape.net/blog/customize-jekyll-so-simple-theme-category-name/ [3] https://davidlozzi.com/2023/10/20/__trashed/ [4] https://mademistakes.com/work/jekyll-themes/so-simple/ [5] https://docs.github.com/en/pages/setting-up-a-github-pages-site-with-jekyll/adding-a-theme-to-your-github-pages-site-using-jekyll [6] https://jekyllrb.com/docs/themes/ [7] https://docs.github.com/en/pages/quickstart [8] https://stackoverflow.com/questions/74721967/how-to-install-this-jekyll-theme-correctly-in-order-to-make-custom-adjustments