leak_profiler 0.5.1 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: b9eee59048d470d4ea437d6eabf4295b4b9fe98b547ed90f43675f56d31b30f4
4
- data.tar.gz: 3f85e846b9cb4e9e6232b69c2025e32223a410af5f8c1edf5a8903ebe24d97fd
3
+ metadata.gz: a0cec55b42b6d790d84c3b54c009da7623040f8aa5c0d3a871eb8d44546d82aa
4
+ data.tar.gz: 0f576971b8e6b1734f51ab4a1bdbb8e00d2822a1eedb1e24f53dc7342c25caff
5
5
  SHA512:
6
- metadata.gz: e070418ef607471a5364579825addfcde2b1d4f13b882546f88cf24ceaea72754439f770d5c44a5c5e2500520ef579285ac9fa252271176295ab56a6074ec434
7
- data.tar.gz: 0be27cc605be614704a20976ec107f9dc56c63235cad4086123365c4f5b2b6ee74ad6cb55320f7cc868cd7661328348ec7797117afd8e018cc3c8a97cf45922f
6
+ metadata.gz: 1636ecd9234f7ba4216c2dbc22892c7aafef11cf26efda7c198dccde3c45cc5273eb2f23974d9524c6d2435f44533c2b20b60f0c70473bc69ebf0101729eddda
7
+ data.tar.gz: b05038cb49f6e21a1a44a3dcc8525c3ee6fdb24a8aa4ae0c04b0544f8a4121218dbe80932281970d61260adc05e38042b2272c4502da4d516e71f0569f589748
data/README.md CHANGED
@@ -86,11 +86,6 @@ elapsed [sec],memory usage (rss) [MB]
86
86
  * `interval` (default `1`): The interval in seconds for report.
87
87
  * `filename` (defalut `nil`): Specify the filename if you want to use custom filename.
88
88
 
89
- > [!WARNING]
90
- > This uses this uses `ps` command for measurement.
91
- > So, this is not supported Windows platform.
92
-
93
-
94
89
  ### `LeakProfiler#report_memsize`
95
90
  This method outputs `ObjectSpace.memsize_of_all` values with CSV format, like:
96
91
 
@@ -1,38 +1,52 @@
1
1
  #include "ruby.h"
2
-
2
+ #include <stdio.h>
3
+ #include <unistd.h>
3
4
 
4
5
  // get the maximum resident set size (RSS) of the current process
5
6
  // return the value in kilobytes
6
7
  #if defined(_WIN32)
7
8
  #include <psapi.h>
8
9
 
9
- static VALUE leak_profiler_max_rss(VALUE self)
10
+ static VALUE leak_profiler_rss(VALUE self)
10
11
  {
11
- PROCESS_MEMORY_COUNTERS pmc;
12
+ PROCESS_MEMORY_COUNTERS pmc;
12
13
  if (!GetProcessMemoryInfo(GetCurrentProcess(), &pmc, sizeof(pmc))) {
13
14
  rb_sys_fail("GetProcessMemoryInfo");
14
15
  }
15
16
  return LONG2NUM(pmc.PeakWorkingSetSize / 1024);
16
17
  }
17
18
 
18
- #else
19
- #include <sys/resource.h>
19
+ #elif defined(__APPLE__)
20
20
 
21
- static VALUE leak_profiler_max_rss(VALUE self)
22
- {
23
- struct rusage usage;
24
- long max_rss;
21
+ #include <mach/mach.h>
25
22
 
26
- if (getrusage(RUSAGE_SELF, &usage) == -1) {
27
- rb_sys_fail("getrusage");
23
+ static VALUE leak_profiler_rss(VALUE self)
24
+ {
25
+ struct mach_task_basic_info info;
26
+ mach_msg_type_number_t count = MACH_TASK_BASIC_INFO_COUNT;
27
+ kern_return_t kr = task_info(mach_task_self(), MACH_TASK_BASIC_INFO, (task_info_t)&info, &count);
28
+ if (kr != KERN_SUCCESS) {
29
+ rb_sys_fail("task_info");
28
30
  }
29
- max_rss = usage.ru_maxrss;
31
+ return LONG2NUM(info.resident_size / 1024);
32
+ }
30
33
 
31
- #if defined(__APPLE__)
32
- max_rss = max_rss / 1024;
33
- #endif
34
+ #else // linux
34
35
 
35
- return LONG2NUM(max_rss);
36
+ static VALUE leak_profiler_rss(VALUE self)
37
+ {
38
+ long rss = 0;
39
+
40
+ FILE *file = fopen("/proc/self/statm", "r");
41
+ if (!file) {
42
+ rb_sys_fail("/proc/self/statm");
43
+ }
44
+ if (fscanf(file, "%*s%ld", &rss) != 1) {
45
+ fclose(file);
46
+ rb_sys_fail("fscanf");
47
+ }
48
+ fclose(file);
49
+ return LONG2NUM(rss * sysconf(_SC_PAGESIZE) / 1024);
36
50
  }
37
51
 
38
52
  #endif
@@ -43,5 +57,5 @@ void Init_leak_profiler_ext(void)
43
57
  VALUE cMemoryUsage = rb_define_class_under(cLeakProfiler, "MemoryUsage", rb_cObject);
44
58
 
45
59
 
46
- rb_define_singleton_method(cMemoryUsage, "max_rss", leak_profiler_max_rss, 0);
60
+ rb_define_singleton_method(cMemoryUsage, "rss", leak_profiler_rss, 0);
47
61
  }
@@ -22,7 +22,7 @@ class LeakProfiler
22
22
  f.puts('elapsed [sec],memory usage (rss) [MB]')
23
23
 
24
24
  loop do
25
- rss = LeakProfiler::MemoryUsage.max_rss / 1024.0
25
+ rss = LeakProfiler::MemoryUsage.rss / 1024.0
26
26
  f.puts("#{i},#{rss}")
27
27
  f.fsync
28
28
  i += @interval
@@ -1,5 +1,5 @@
1
1
  class LeakProfiler
2
2
  class MemoryUsage
3
- def self.max_rss: () -> Integer
3
+ def self.rss: () -> Integer
4
4
  end
5
5
  end
@@ -5,6 +5,6 @@ require 'minitest/autorun'
5
5
 
6
6
  class MemoryUsageTest < Minitest::Test
7
7
  def test_report_rss
8
- assert_equal(true, LeakProfiler::MemoryUsage.max_rss.positive?)
8
+ assert_equal(true, LeakProfiler::MemoryUsage.rss.positive?)
9
9
  end
10
10
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: leak_profiler
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.1
4
+ version: 0.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Watson