File: asynchronous.rb

package info (click to toggle)
libnet-sftp-ruby 1.1.0-1
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 1,272 kB
  • ctags: 855
  • sloc: ruby: 4,171; makefile: 47
file content (57 lines) | stat: -rw-r--r-- 1,986 bytes parent folder | download | duplicates (3)
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
#--
# =============================================================================
# Copyright (c) 2004, Jamis Buck (jamis@37signals.com)
# All rights reserved.
#
# This source file is distributed as part of the Net::SFTP Secure FTP Client
# library for Ruby. This file (and the library as a whole) may be used only as
# allowed by either the BSD license, or the Ruby license (or, by association
# with the Ruby license, the GPL). See the "doc" subdirectory of the Net::SFTP
# distribution for the texts of these licenses.
# -----------------------------------------------------------------------------
# net-sftp website: http://net-ssh.rubyforge.org/sftp
# project website : http://rubyforge.org/projects/net-ssh
# =============================================================================
#++

$:.unshift "../lib"
require 'net/sftp'

Net::SFTP.start( 'localhost',
  :registry_options => { :logs => { :levels => { "sftp.*" => :debug } } }
) do |sftp|
  closed = 0

  size = sftp.stat( "temp/out" ).size

  # setting this to a higher value typically causes problems...looks like it
  # might be a problem with OpenSSH, but I'm not sure.
  parts = 5

  chunk_size = size / parts
  chunks = []

  # Set up 'parts' read operations, each one pulling from a different segment
  # of the file. Each of these will be run in parallel.
  parts.times do |part|
    sftp.open( "temp/out" ) do |s,h|
      puts "----------------------------------------------"
      puts "got handle ##{part+1} (#{h.inspect})"
      sftp.read( h, chunk_size*part, chunk_size ) do |s,data|
        puts "----------------------------------------------"
        puts "got data ##{part+1} (#{data.length} bytes)"
        chunks[part] = data
        sftp.close_handle( h ) do
          closed += 1
          sftp.close_channel if closed == parts
        end
      end
    end
  end

  sftp.loop

  puts "----------------------------------------------"
  data = chunks.join
  puts "done! (#{data.length} bytes)"
end