Skip to content


Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?


Failed to load latest commit information.
Latest commit message
Commit time
February 25, 2023 09:53
February 25, 2023 09:47
March 18, 2023 09:01
February 25, 2023 09:47
February 25, 2023 09:45
November 26, 2017 13:09

Gem version Gem downloads Build status Code Climate


adsf (A Dead Simple Fileserver) is a tiny static web server that you can launch instantly in any directory, like this:

▸ ls -l
total 0
drwxr-xr-x  2 ddfreyne  staff  68 May 29 10:04 about
drwxr-xr-x  2 ddfreyne  staff  68 May 29 10:04 contact
-rw-r--r--  1 ddfreyne  staff   0 May 29 10:04 index.html
drwxr-xr-x  2 ddfreyne  staff  68 May 29 10:04 projects

▸ adsf
[2017-11-19 11:49:20] INFO  WEBrick 1.3.1
[2017-11-19 11:49:20] INFO  ruby 2.4.2 (2017-09-14) [x86_64-darwin17]
[2017-11-19 11:49:20] INFO  WEBrick::HTTPServer#start: pid=95218 port=3000

… and now you can go to http://localhost:3000/ and start browsing.

See adsf --help for details.

To use adsf --live-reload, please install the separate adsf-live gem. (The live-reload support is not part of adsf itself, because the dependencies of adsf-live make it difficult to install under some circumstances.)

Using adsf programmatically


The Adsf::Rack::IndexFileFinder middleware makes Rack load an index file (e.g. index.html) when requesting a directory. For example, the following runs a web server with the 'public' directory as its web root:

use Adsf::Rack::IndexFileFinder, root: 'public'

It takes the following options:

  • root (required): the path to the web root

  • index_filenames (optional; defaults to ['index.html']): contains the names of the index filenames that will be served when a directory containing an index file is requested. Usually, this will simply be ['index.html'], but under different circumstances (when using IIS, for example), the array may have to be modified to include index filenames such as default.html or index.xml. Here’s an example middleware/application stack that uses custom index filenames:

    use Adsf::Rack::IndexFileFinder,
    	root: 'public',
    	index_filenames: %w[index.html index.xhtml]

Why not use Rack::Static? Rack comes with Rack::Static, whose purpose is similar to, but not the same as, Adsf::Rack::IndexFileFinder. In particular:

  • Adsf::Rack::IndexFileFinder does not serve files, unlike Rack::Static. IndexFileFinder only rewrites the incoming request and passes it on (usually to Rack::File).

  • Adsf::Rack::IndexFileFinder supports multiple index files, while Rack::Static only supports one (you could have multiple Rack::Static middlewares, one for each index filenames, though).

  • Rack::Static will report the wrong filename on 404 pages: when requesting a directory without an index file, it will e.g. report “File not found: /index.html” rather than “File not found: /”.

  • When requesting a directory without specifying the trailing slash, Adsf::Rack::IndexFileFinder will redirect to the URL with a trailing slash, unlike Rack::Static. This mimics the behavior of typical HTTP servers. For example, when requesting /foo, when a foo directory exists and it contains index.html, IndexFileFinder will redirect to /foo/.


Adsf::Server runs a web server programmatically. For example:

server = 'public')

%w[INT TERM].each do |s|
  Signal.trap(s) { server.stop }

It takes the following options:

  • root (required): the path to the web root
  • index_filenames (optional; defaults to ['index.html']): (see above)
  • host (optional; defaults to ''): the address of the network interface to listen on
  • port (optional; defaults to 3000): the port ot listen on
  • handler (optional): the Rack handler to use


  • Ed Brannin
  • Larissa Reis
  • Mark Meves
  • Vipul Amler