mislav / addressable forked from sporkmonger/addressable
- Source
- Commits
- Network (7)
- Downloads (5)
- Wiki (1)
- Graphs
-
Branch:
master
| name | age | message | |
|---|---|---|---|
| |
.gitignore | Mon Oct 13 10:49:21 -0700 2008 | |
| |
CHANGELOG | ||
| |
LICENSE | Thu Jun 05 11:29:57 -0700 2008 | |
| |
README | Tue Apr 28 15:10:19 -0700 2009 | |
| |
Rakefile | Sat Oct 31 18:27:09 -0700 2009 | |
| |
addressable.gemspec | Sat Oct 31 18:26:29 -0700 2009 | |
| |
lib/ | ||
| |
spec/ | ||
| |
tasks/ | Sat Oct 31 18:27:09 -0700 2009 | |
| |
website/ | Mon Nov 17 20:05:29 -0800 2008 |
README
Addressable is a replacement for the URI implementation that is part of
Ruby's standard library. It more closely conforms to the relevant RFCs and
adds support for IRIs and URI templates. Additionally, it provides extensive
support for URI templates.
Example usage:
require "addressable/uri"
uri = Addressable::URI.parse("http://example.com/path/to/resource/")
uri.scheme
#=> "http"
uri.host
#=> "example.com"
uri.path
#=> "/path/to/resource/"
uri = Addressable::URI.parse("http://www.詹姆斯.com/")
uri.normalize
#=> #<Addressable::URI:0xc9a4c8 URI:http://www.xn--8ws00zhy3a.com/>
require "addressable/template"
template = Addressable::Template.new("http://example.com/{-list|+|query}/")
template.expand({
"query" => "an example query".split(" ")
})
#=> #<Addressable::URI:0xc9d95c URI:http://example.com/an+example+query/>
template = Addressable::Template.new(
"http://example.com/{-join|&|one,two,three}/"
)
template.partial_expand({"one" => "1", "three" => 3}).pattern
#=> "http://example.com/?one=1{-prefix|&two=|two}&three=3"
template = Addressable::Template.new(
"http://{host}/{-suffix|/|segments}?{-join|&|one,two,bogus}\#{fragment}"
)
uri = Addressable::URI.parse(
"http://example.com/a/b/c/?one=1&two=2#foo"
)
template.extract(uri)
#=>
# {
# "host" => "example.com",
# "segments" => ["a", "b", "c"],
# "one" => "1",
# "two" => "2",
# "fragment" => "foo"
# }

