SlideShare a Scribd company logo
Serving
    Code Samples

Lachstock
I was recently on holidays.
Holidays are boring
Holidays are boring




So I wrote code.
Holidays are boring




Then I thought I should blog about it.
Holidays are boring




But I didn’t want to write a long article.
Holidays are boring




Just a snippet.
Holidays are boring




I needed   code section
Holidays are boring




I needed a   code section!
Five busy days later...
The Problem




I needed to display the actual code I wrote.
The Problem




Ordered list with codey bits in LIs?
The Problem




Gist?
The Problem




Surely someone has solved this?
The Problem




Surely someone has solved this?
NO!
The Post
 %h2 HTML

 = code_sample("anchor.html")
The Helper
  def code_sample(filename)
    @filename = filename
    file = "#{options.views}/#{@category}/#{@name}/
  files/#{filename}.txt"
    if File.exist? file
      @code_snippet= preserve(
    escape_once(File.read(file))
  )
  extension = filename.split('.')[1]
  @code_class = (
    extension == "js" ? "javascript" : extension
  )
 end
 haml(:"_code_sample", :layout => false)
end
The Partial
 .code
   %pre
    %code{:class => @code_class}= @code_snippet
   %span.download
    Download file:
    %a{:href => "files/#{@filename}"}= @filename
The Browser
  <h2>HTML</h2>
  <div class="code">
   <pre> <code class="html">&lt;a href=&quot;/
  feeds/articles/&quot; id=&quot;feed-
  button&quot;&gt;&#x000A;
  &lt;span&gt;Subscribe&lt;/span&gt;&#x000A;&lt;/
  a&gt;</code></pre>

 <span class="download">
  Download file:
  <a href="files/anchor.html">
   anchor.html
  </a>
 </span>
</div>
The Controller
  get '/*/files/:filename.:filetype' do

 filetype = params[:filetype] == "zip" ? "zip" :
"#{params[:filetype]}.txt"

 file = "#{options.views}/#{params[:splat]}/files/
#{params[:filename]}.#{filetype}"

 if File.exists? file
   content_type 'text/plain', :charset => 'utf-8'
   send_file(file)
 else
   raise not_found
 end
end
Questions?

More Related Content

PPTX
Types of Database Keys
PPTX
Keys in Database Management System
PPTX
Subtle Encipherment Hall
PPS
Exhibits and Presenters
PPTX
Google's Chromebook and Android Strategy
PDF
The Content Journey: illustrated by Dribbble designers from around the globe
PDF
Introduction to Google Developer Relations
PDF
Don't Fear the Custom Theme: How to build a custom WordPress theme with only ...
Types of Database Keys
Keys in Database Management System
Subtle Encipherment Hall
Exhibits and Presenters
Google's Chromebook and Android Strategy
The Content Journey: illustrated by Dribbble designers from around the globe
Introduction to Google Developer Relations
Don't Fear the Custom Theme: How to build a custom WordPress theme with only ...

Similar to Serving Code Samples (20)

PPTX
Module 2-Introduction to HTML (Chapter 2).pptx
DOC
Wordpress(css,php,js,ajax)
PDF
Le Wagon Tokyo | Build your Landing Page in 2 hours
PDF
php-mysql-tutorial-part-3
PDF
php-mysql-tutorial-part-3
PDF
&lt;b>PHP&lt;/b>/MySQL &lt;b>Tutorial&lt;/b> webmonkey/programming/
PDF
&lt;img src="../i/r_14.png" />
PDF
Le Wagon - Build your Landing Page in 2 hours
PPTX
Twig internals - Maksym MoskvychevTwig internals maksym moskvychev
PDF
Le Wagon - 2h Landing
PDF
Instagram filters (8 24)
PPTX
Professional Help for PowerShell Modules
PDF
Coder son site web
PDF
Instagram filters
PPTX
Listen afup 2010
PPTX
Web 101 intro to html
PPT
WordPress Theme Design - Rich Media Institute Workshop
PDF
&lt;img src="../i/r_14.png" />
PDF
&lt;b>PHP&lt;/b> Reference: Beginner to Intermediate &lt;b>PHP5&lt;/b>
PDF
Intro to WordPress theme development
Module 2-Introduction to HTML (Chapter 2).pptx
Wordpress(css,php,js,ajax)
Le Wagon Tokyo | Build your Landing Page in 2 hours
php-mysql-tutorial-part-3
php-mysql-tutorial-part-3
&lt;b>PHP&lt;/b>/MySQL &lt;b>Tutorial&lt;/b> webmonkey/programming/
&lt;img src="../i/r_14.png" />
Le Wagon - Build your Landing Page in 2 hours
Twig internals - Maksym MoskvychevTwig internals maksym moskvychev
Le Wagon - 2h Landing
Instagram filters (8 24)
Professional Help for PowerShell Modules
Coder son site web
Instagram filters
Listen afup 2010
Web 101 intro to html
WordPress Theme Design - Rich Media Institute Workshop
&lt;img src="../i/r_14.png" />
&lt;b>PHP&lt;/b> Reference: Beginner to Intermediate &lt;b>PHP5&lt;/b>
Intro to WordPress theme development
Ad

More from Lachlan Hardy (11)

KEY
Give Your JavaScript Apps Some Spine
KEY
Give Your JavaScript Apps A Spine
PDF
SydJS.com
KEY
Yql && Raphaël
KEY
GitHub for JavaScripters
KEY
The Open Web
PDF
The Open Web
PDF
The Open Web
PDF
Improving Dashboards with open content sharing
PDF
Local Government on the Open Web
PPT
Welcome to IE8 - Integrating Your Site With Internet Explorer 8
Give Your JavaScript Apps Some Spine
Give Your JavaScript Apps A Spine
SydJS.com
Yql && Raphaël
GitHub for JavaScripters
The Open Web
The Open Web
The Open Web
Improving Dashboards with open content sharing
Local Government on the Open Web
Welcome to IE8 - Integrating Your Site With Internet Explorer 8
Ad

Recently uploaded (20)

DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
Machine Learning_overview_presentation.pptx
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Empathic Computing: Creating Shared Understanding
PPTX
Big Data Technologies - Introduction.pptx
PPTX
Cloud computing and distributed systems.
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PDF
A comparative analysis of optical character recognition models for extracting...
The AUB Centre for AI in Media Proposal.docx
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Digital-Transformation-Roadmap-for-Companies.pptx
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Per capita expenditure prediction using model stacking based on satellite ima...
Chapter 3 Spatial Domain Image Processing.pdf
Machine Learning_overview_presentation.pptx
Unlocking AI with Model Context Protocol (MCP)
Mobile App Security Testing_ A Comprehensive Guide.pdf
“AI and Expert System Decision Support & Business Intelligence Systems”
Assigned Numbers - 2025 - Bluetooth® Document
Building Integrated photovoltaic BIPV_UPV.pdf
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Network Security Unit 5.pdf for BCA BBA.
Empathic Computing: Creating Shared Understanding
Big Data Technologies - Introduction.pptx
Cloud computing and distributed systems.
MIND Revenue Release Quarter 2 2025 Press Release
A comparative analysis of optical character recognition models for extracting...

Serving Code Samples