-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME
62 lines (43 loc) · 1.96 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
= pathname3
This library is a replacement for the venerable pathname and pathname2
libraries.
The original implementation of pathname is extremely slow, and
instantiates extreme numbers of objects for relatively simple operations.
Twenty or so Pathname instantiations on some method calls is relatively
common.
An implementation by Daniel J. Berger, pathname2, improved on the original
significantly, adding Windows support, a Facade implementation, and a String-
based implementation. While his version is faster, it's still very slow at
instantiation. And its Facade implementation misses some odd case methods
like Pathname#join.
This version will focus on being fast and lightweight, while still being pure
Ruby. Windows support will be forthcoming once I have access to a Windows
development machine. Until then, patches adding Windows compatibility are
welcome.
== Installation
You can install pathname3 through Rubygems. The gem is hosted on GitHub, and
can be installed via
$ sudo gem install --source http://gems.github.com/ stouset-pathname3
== Usage
require 'pathname3'
p = '~/foo'.to_path # => "~/foo"
p.absolute? # => false
p.relative? # => true
p.exists? # => false
p = p.absolute # => "/Users/stouset/foo"
p.absolute? # => true
p.relative? # => false
p.relative_path_from('/Users') # => "stouset/foo"
p.relative_path_from('/Library') # => "../Users/stouset/foo"
p.split # => ["/Users/stouset", "foo"]
p.touch # => "/Users/stouset/foo"
p.ctime # => Thu Jun 05 14:00:01 -0400 2008
p.delete # => true
== Contribution
The pathname3 project is hosted on GitHub.
http://github.com/stouset/pathname3/
To clone the repository, simply run:
git clone git://github.com/stouset/pathname3.git
== License
pathname3 is available under the MIT license.
:include: LICENSE