yahns Ruby server user/dev discussion
 help / color / mirror / code / Atom feed
59c1b46c947b2fb9741597535fd8edf59cb9678d blob 779 bytes (raw)

 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
 
# Copyright (C) 2013-2016 all contributors <yahns-public@yhbt.net>
# License: GPL-3.0+ (https://www.gnu.org/licenses/gpl-3.0.txt)
# frozen_string_literal: true
module Yahns::ClientExpireGeneric # :nodoc:
  def __timestamp
    Yahns.now
  end

  def yahns_init
    super # Yahns::HttpClient#yahns_init
    @last_io_at = 0
  end

  def yahns_expire(timeout)
    return 0 if closed?
    if (__timestamp - @last_io_at) > timeout
      shutdown
      1
    else
      0
    end
  # shutdown may race with the shutdown in http_response_done
  rescue
    0
  end

  def kgio_trywrite(*args)
    @last_io_at = __timestamp
    super
  end

  def kgio_tryread(*args)
    @last_io_at = __timestamp
    super
  end

  def trysendfile(*args)
    @last_io_at = __timestamp
    super
  end
end
debug log:

solving 59c1b46 ...
found 59c1b46 in https://yhbt.net/yahns.git

Code repositories for project(s) associated with this inbox:

	../../../yahns.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).