Class: RbFind::Entry
- Inherits:
-
Object
show all
- Includes:
- Csv
- Defined in:
- lib/rbfind.rb
Constant Summary
collapse
- ARROW =
" -> "
Constants included
from Csv
Csv::COLON
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
Methods included from Csv
#colsep, #csv, outfile, putl, #spcsep, #tabsep
Constructor Details
#initialize(filename, walk) ⇒ Entry
Returns a new instance of Entry.
413
414
415
416
417
|
# File 'lib/rbfind.rb', line 413
def initialize filename, walk
@walk = walk
@prev, @name = walk.current, filename.dup.freeze
@path = join_path @name
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(sym, *args, &block) ⇒ Object
462
463
464
465
466
467
468
|
# File 'lib/rbfind.rb', line 462
def method_missing sym, *args, &block
if stat.respond_to? sym then
stat.send sym, *args, &block
else
super
end
end
|
Instance Attribute Details
#name ⇒ Object
Returns the value of attribute name.
411
412
413
|
# File 'lib/rbfind.rb', line 411
def name
@name
end
|
#path ⇒ Object
Returns the value of attribute path.
411
412
413
|
# File 'lib/rbfind.rb', line 411
def path
@path
end
|
Class Method Details
.colored(arg, num) ⇒ Object
Also known as:
coloured
813
814
815
816
|
# File 'lib/rbfind.rb', line 813
def colored arg, num
colors col_str
"\e[#{@colors[num]}m#{arg}\e[m"
end
|
.colors(str) ⇒ Object
Also known as:
colours
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
|
# File 'lib/rbfind.rb', line 819
def colors str
@colors ||= if str =~ /:/ then
h = {}
(str.split ":").each { |a|
t, c = a.split "="
h[ t] = c
}
%w(rs or di ln so pi ex bd cd su sg tw ow - -).map { |t| h[ t] }
else
cols = []
str.scan /(.)(.)/i do
fg, bg = $~.captures.map { |x| x.downcase.ord - ?a.ord }
a = []
case fg
when 0..7 then a.push 30 + fg
end
a.push 1 if $1 == $1.upcase
case bg
when 0..7 then a.push 40 + bg
end
e = a.join ";"
cols.push e
end
cols
end
end
|
Instance Method Details
#aage ⇒ Object
489
|
# File 'lib/rbfind.rb', line 489
def aage ; @walk.start - stat.atime ; end
|
#arrow ⇒ Object
554
555
556
|
# File 'lib/rbfind.rb', line 554
def arrow
ARROW + (File.readlink @path) if symlink?
end
|
#binary?(n = 1) ⇒ Boolean
Also known as:
bin?
:call-seq:
binary?( n = 1) -> true or false
Test whether the first n blocks contain null characters.
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
|
# File 'lib/rbfind.rb', line 679
def binary? n = 1
bs = stat.blksize
open { |file|
loop do
if n then
break if n <= 0
n -= 1
end
b = file.read bs
b or break
return true if b[ "\0"]
end
}
false
end
|
#broken_link? ⇒ Boolean
Also known as:
broken?
544
545
546
547
548
549
550
|
# File 'lib/rbfind.rb', line 544
def broken_link?
return unless symlink?
rstat
false
rescue
true
end
|
#cage ⇒ Object
491
|
# File 'lib/rbfind.rb', line 491
def cage ; @walk.start - stat.ctime ; end
|
#carrow ⇒ Object
757
758
759
760
|
# File 'lib/rbfind.rb', line 757
def carrow
r = creadlink
ARROW + r if r
end
|
#cfullpath ⇒ Object
745
|
# File 'lib/rbfind.rb', line 745
def cfullpath ; color fullpath ; end
|
#cfullpath! ⇒ Object
747
|
# File 'lib/rbfind.rb', line 747
def cfullpath! ; color fullpath! ; end
|
#cname ⇒ Object
743
|
# File 'lib/rbfind.rb', line 743
def cname ; color name ; end
|
#color(arg) ⇒ Object
Also known as:
colour
763
764
765
|
# File 'lib/rbfind.rb', line 763
def color arg
color_stat arg, stat
end
|
#contains?(name) ⇒ Boolean
:call-seq:
contains?( name) -> true or false
Check whether a directory contains an entry.
577
578
579
580
581
582
583
|
# File 'lib/rbfind.rb', line 577
def contains? name
p = File.join @path, name
File.lstat p
true
rescue
false
end
|
#count ⇒ Object
430
|
# File 'lib/rbfind.rb', line 430
def count ; @walk.count ; end
|
#cpath ⇒ Object
744
|
# File 'lib/rbfind.rb', line 744
def cpath ; color path ; end
|
#cpath! ⇒ Object
746
|
# File 'lib/rbfind.rb', line 746
def cpath! ; color path! ; end
|
#creadlink ⇒ Object
749
750
751
752
753
754
755
|
# File 'lib/rbfind.rb', line 749
def creadlink
l = readlink
if l then
s = rstat rescue nil
color_stat l, s
end
end
|
#cyclic? ⇒ Boolean
476
477
478
479
480
481
482
483
484
485
486
|
# File 'lib/rbfind.rb', line 476
def cyclic?
e = self
loop do
e = e.prev
e or break
if File.identical? e.path, @path then
return true
end
end
false
end
|
#depth ⇒ Object
431
|
# File 'lib/rbfind.rb', line 431
def depth ; @walk.depth ; end
|
#directory? ⇒ Boolean
Also known as:
dir?
471
|
# File 'lib/rbfind.rb', line 471
def directory? ; stat.directory? ; end
|
#dirname ⇒ Object
447
448
449
|
# File 'lib/rbfind.rb', line 447
def dirname
File.basename File.dirname fullpath
end
|
#done ⇒ Object
Also known as:
done!
705
|
# File 'lib/rbfind.rb', line 705
def done ; raise Done ; end
|
#empty? ⇒ Boolean
:call-seq:
empty?() -> true or false
Look up if the directory is empty. If the object is not a directory or not accessible, nil is returned.
566
567
568
569
570
|
# File 'lib/rbfind.rb', line 566
def empty?
(Dir.new @path).each_child { |f| return false }
true
rescue Errno::ENOTDIR
end
|
#entries ⇒ Object
Also known as:
children
:call-seq:
entries() -> ary
Return all entries in an array. If the object is not a directory, nil is returned.
591
592
593
594
|
# File 'lib/rbfind.rb', line 591
def entries
(Dir.new @path).children
rescue Errno::ENOTDIR
end
|
#ext ⇒ Object
452
|
# File 'lib/rbfind.rb', line 452
def ext ; File.extname name ; end
|
#filesize ⇒ Object
:call-seq:
filesize => nil or int
filesize { |size| ... } => obj
Returns the files size. When the object is not a regular file, nil will be returned or the block will not be called.
501
502
503
504
505
506
507
508
|
# File 'lib/rbfind.rb', line 501
def filesize
stat.file? or return
if block_given? then
yield stat.size
else
stat.size
end
end
|
#fullpath ⇒ Object
434
|
# File 'lib/rbfind.rb', line 434
def fullpath ; @fullpath ||= File.absolute_path @path ; end
|
#fullpath! ⇒ Object
445
|
# File 'lib/rbfind.rb', line 445
def fullpath! ; append_slash fullpath ; end
|
#grep(re, color = nil) ⇒ Object
659
660
661
662
663
664
665
666
667
668
669
670
671
672
|
# File 'lib/rbfind.rb', line 659
def grep re, color = nil
case color
when /\A\d+(?:;\d+)*\z/, nil, false then
when true then color = "31;1"
else raise "Illegal color spec: #{color}"
end
lines { |l,i|
l.scrub!
l =~ re or next
color and l = "#$`\e[#{color}m#$&\e[m#$'"
colsep @path, i, l
true
}
end
|
#group ⇒ Object
532
533
534
|
# File 'lib/rbfind.rb', line 532
def group
get_group stat.gid
end
|
#group! ⇒ Object
536
537
538
539
|
# File 'lib/rbfind.rb', line 536
def group!
g = stat.gid
g == Process.gid ? "." : (get_group g)
end
|
#hidden? ⇒ Boolean
455
|
# File 'lib/rbfind.rb', line 455
def hidden? ; name =~ /^\./ ; end
|
#lines ⇒ Object
:call-seq:
lines { |l,i| ... } -> nil
Yield line by line together with the line number i.
645
646
647
648
649
650
651
652
653
654
655
656
657
|
# File 'lib/rbfind.rb', line 645
def lines
block_given? or return lines do end
r = false
open { |file|
n = 0
file.each_line { |l|
l.chomp!
n += 1
r ||= true if yield l, n
}
r
}
end
|
#mage ⇒ Object
Also known as:
age
490
|
# File 'lib/rbfind.rb', line 490
def mage ; @walk.start - stat.mtime ; end
|
#mode ⇒ Object
459
|
# File 'lib/rbfind.rb', line 459
def mode ; stat.mode ; end
|
#novcs ⇒ Object
Also known as:
no_vcs
711
712
713
|
# File 'lib/rbfind.rb', line 711
def novcs
prune if vcs?
end
|
#now ⇒ Object
432
|
# File 'lib/rbfind.rb', line 432
def now ; @walk.start ; end
|
#open(&block) ⇒ Object
:call-seq:
open() { |h| ... } -> obj
Open the file for reading. If the object is not a regular file, nothing will be done.
609
610
611
612
613
614
|
# File 'lib/rbfind.rb', line 609
def open &block
@ostat ||= $stdout.stat
@ostat.identical? @path and
raise "Refusing to open output file."
File.open @path, &block if file?
end
|
#path! ⇒ Object
444
|
# File 'lib/rbfind.rb', line 444
def path! ; append_slash path ; end
|
#prune ⇒ Object
Also known as:
prune!
708
|
# File 'lib/rbfind.rb', line 708
def prune ; raise Prune ; end
|
#read(n = nil) ⇒ Object
:call-seq:
read( n = nil) -> str or nil
read( n = nil) { |b| ... } -> nil
Read the first n bytes or return nil for others than regular files. nil reads to end of file. If a block is given, chonks of n bytes (or all) will be yielded.
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
|
# File 'lib/rbfind.rb', line 624
def read n = nil
open { |o|
if block_given? then
if n then
while (r = o.read n) do
yield r
end
else
yield o.read
end
else
o.read n
end
}
end
|
#readlink ⇒ Object
542
|
# File 'lib/rbfind.rb', line 542
def readlink ; File.readlink @path if symlink? ; end
|
#rename(newname) ⇒ Object
Also known as:
mv
720
721
722
723
724
725
726
727
728
729
|
# File 'lib/rbfind.rb', line 720
def rename newname
@name = newname
newname == (File.basename newname) or
raise "Rename to `#{newname}' may not be a path."
p = join_path newname
(File.exist? p) and raise "Rename to `#{p}` would overwrite."
File.rename @path, p
@name, @path = newname.dup.freeze, p
reset
end
|
#rm ⇒ Object
732
733
734
735
736
737
738
739
740
|
# File 'lib/rbfind.rb', line 732
def rm
if directory? then
Dir.rmdir @path
else
File.unlink @path
end
@name = @path = nil
reset
end
|
#rstat ⇒ Object
437
|
# File 'lib/rbfind.rb', line 437
def rstat ; @rstat ||= File.stat @path ; end
|
#stat ⇒ Object
436
|
# File 'lib/rbfind.rb', line 436
def stat ; @stat ||= File.lstat @path ; end
|
#symlink? ⇒ Boolean
474
|
# File 'lib/rbfind.rb', line 474
def symlink? ; stat.symlink? ; end
|
#user ⇒ Object
Also known as:
owner
521
522
523
|
# File 'lib/rbfind.rb', line 521
def user
get_user stat.uid
end
|
#user! ⇒ Object
Also known as:
owner!
526
527
528
529
|
# File 'lib/rbfind.rb', line 526
def user!
u = stat.uid
u == Process.uid ? "." : (get_user u)
end
|
#vcs? ⇒ Boolean
598
599
600
|
# File 'lib/rbfind.rb', line 598
def vcs?
%w(CVS .svn .git .hg .fslckout).include? name
end
|
#vimswap? ⇒ Boolean
696
697
698
699
700
701
|
# File 'lib/rbfind.rb', line 696
def vimswap?
if name =~ /\A(\..+)?\.sw[a-z]\z/i then
mark = read 5
mark == "b0VIM"
end
end
|
#visible? ⇒ Boolean
456
|
# File 'lib/rbfind.rb', line 456
def visible? ; not hidden? ; end
|
#without_ext ⇒ Object
453
|
# File 'lib/rbfind.rb', line 453
def without_ext ; name[ /^(.+?)(?:\.[^.]+)?$/, 1 ].to_s ; end
|