Fetching contributors…
Cannot retrieve contributors at this time
205 lines (104 sloc) 6.23 KB

Changes between Urly 2.0.0-alpha4 and 2.0.0-alpha5

Path Encoding

clojurewerkz.urly.core/encode-path now handles colons in URI path.

Changes between Urly 2.0.0-alpha3 and 2.0.0-alpha4

Path Encoding

clojurewerkz.urly.core/encode-path encodes argument as URI path.

See What Every Developer Should Know About URL Encoding for more information.

Clojure 1.4 By Default

Urly now depends on org.clojure/clojure version 1.4.0. It is still compatible with Clojure 1.3 and if your project.clj depends on 1.3, it will be used, but 1.4 is the default now.

We encourage all users to upgrade to 1.4, it is a drop-in replacement for the majority of projects out there.

Changes between Urly 2.0.0-alpha2 and 2.0.0-alpha3

Added nil bubbling for PartsAccessors, which allows client to decide what to do with nil. That's especially useful when Url is invalid, therefore urly is not able to parse it.

Changes between Urly 2.0.0-alpha1 and 2.0.0-alpha2

New functions

clojurewerkz.urly.core/count-segments can be used to calculate number of segments in the path:

(count-segments "") ;; => 0
(count-segments "") ;; => 0
(count-segments"/") ;; => 0
(count-segments "") ;; => 1
(count-segments "/iphone") ;; => 1
(count-segments "") ;; => 1
(count-segments "/iphone/") ;; => 1
(count-segments "") ;; => 6
(count-segments (url-like "")) ;; => 6
(count-segments ( "")) ;; => 6
(count-segments ( "")) ;; => 6
(count-segments (url-like "")) ;; => 4

Changes between Urly 1.0.0 and 2.0.0-alpha1


UrlLike#withWww does the opposite of UrlLike#withoutWww

Changes between Urly 1.0.0-rc6 and 1.0.0

Java API improvements

clojurewerkz.urly.UrlLike now has several additional methods:

  • UrlLike#withoutQuery
  • UrlLike#withoutFragment

New functions

clojurewerkz.urly.core/without-query-string and clojurewerkz.urly.core/without-fragment were added, similar in purpose with clojurewerkz.urly.core/without-query-string-and-fragment.

clojurewerkz.urly.core/absolutize and clojurewerkz.urly.core/normalize-url were extracted from Crawlista

Changes between Urly 1.0.0-rc5 and 1.0.0-rc6


Authority (section 3.2 in RFC 3986) is now recalculated when hostname, port or user info are mutated.


clojurewerkz.urly.UrlLike#withoutWww is a Java API addition that eliminates www., www.2, www.11 and similar prefixes from the hostname.

Changes between Urly 1.0.0-rc4 and 1.0.0-rc5

Eliminated reflection warnings

Reflection warnings for clojurewerkz.urly.core/resolve were eliminated.

Thousands new test cases

Urly test suite now has about 3K more new test cases for the parser.

Changes between Urly 1.0.0-rc3 and 1.0.0-rc4

clojurewerkz.urly.core/resolve now supports UrlLike

clojurewerkz.urly.core/resolve now supports UrlLike instances

Changes between Urly 1.0.0-rc2 and 1.0.0-rc3

Query mutation and encoding improvements

New functions allow for query string mutation via function (much like Clojure atoms) and URL-encoding (note that Clojure API uses UTF-8 encoding):

  • clojurewerkz.urly.core/mutate-query-with
  • clojurewerkz.urly.core/encode-query
  • clojurewerkz.urly.core/encode-fragment

Java API improvements

clojurewerkz.urly.UrlLike now has several additional methods:

  • UrlLike#hasQuery
  • UrlLike#hasFragment
  • UrlLike#hasNonDefaultPort
  • UrlLike#encodeQuery

Changes between Urly 1.0.0-rc1 and 1.0.0-rc2

Extra protocol elimination (for example http:// => is now case-insensitive (will recognize http as well as HTTp).

Changes between Urly 1.0.0-beta9 and 1.0.0-rc1

clojurewerkz.urly.core/url-like now uses fully-qualified class name for its return type hint. This is a usability improvement: this way namespaces that use it won't have to import it.

Changes between Urly 1.0.0-beta8 and 1.0.0-beta9

UrlLike/homepageOf now uses the same default port value as

UrlLike/homepageOf used to use default port value of 80. Starting with 1.0.0-beta9, it uses the same default prot as (-1).

url-like now treats inputs that are valid Internet domain names specially

urly.core/url-like now recognizes cases like "" or "" (Internet domain names) and uses the input to assign UrlLike instance host ( assigns path), which is what you typically want.

In cases where you want classic behavior, use UrlLike/from with a URI instance:

(UrlLike/from ( ""))

Changes between Urly 1.0.0-beta7 and 1.0.0-beta8

urly.core/url-like how handles cases when URL parts (typically query string) have unescaped spaces in them

Changes between Urly 1.0.0-beta6 and 1.0.0-beta7

urly.core/protocol-of how correctly returns nil for inputs that have no protocol

Changes between Urly 1.0.0-beta5 and 1.0.0-beta6

urly.core/absolute? and urly.core/relative? now work for urly.UrlLike instances

Changes between Urly 1.0.0-beta4 and 1.0.0-beta5

Added urly.core/eliminate-extra-protocol-prefixes that turns URLs like http:// into

Changes between Urly 1.0.0-beta3 and 1.0.0-beta4

JDK 6 Compatibility

Urly now correctly uses JDK 6 as Java compilation target.

Changes between Urly 1.0.0-beta2 and 1.0.0-beta3

Leiningen 2

Urly now uses Leiningen 2.