eventmachine 0.12.10-x86-mswin32-60 → 1.0.0.beta.2-x86-mswin32-60
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +2 -0
- data/Gemfile +1 -0
- data/README +80 -81
- data/Rakefile +7 -370
- data/docs/COPYING +60 -60
- data/docs/ChangeLog +211 -211
- data/docs/DEFERRABLES +246 -133
- data/docs/EPOLL +141 -141
- data/docs/GNU +281 -281
- data/docs/INSTALL +13 -13
- data/docs/KEYBOARD +42 -38
- data/docs/LEGAL +25 -25
- data/docs/LIGHTWEIGHT_CONCURRENCY +130 -70
- data/docs/PURE_RUBY +75 -75
- data/docs/RELEASE_NOTES +94 -94
- data/docs/SMTP +4 -2
- data/docs/SPAWNED_PROCESSES +148 -89
- data/docs/TODO +8 -8
- data/eventmachine.gemspec +19 -26
- data/examples/ex_channel.rb +42 -42
- data/examples/ex_queue.rb +2 -2
- data/examples/ex_tick_loop_array.rb +15 -0
- data/examples/ex_tick_loop_counter.rb +32 -0
- data/examples/helper.rb +1 -1
- data/ext/binder.cpp +0 -1
- data/ext/cmain.cpp +36 -25
- data/ext/ed.cpp +104 -113
- data/ext/ed.h +24 -30
- data/ext/em.cpp +349 -283
- data/ext/em.h +25 -29
- data/ext/eventmachine.h +5 -4
- data/ext/extconf.rb +58 -49
- data/ext/fastfilereader/extconf.rb +5 -3
- data/ext/fastfilereader/mapper.cpp +214 -214
- data/ext/fastfilereader/mapper.h +59 -59
- data/ext/fastfilereader/rubymain.cpp +127 -127
- data/ext/kb.cpp +1 -3
- data/ext/page.cpp +107 -107
- data/ext/page.h +51 -51
- data/ext/pipe.cpp +9 -11
- data/ext/project.h +12 -8
- data/ext/rubymain.cpp +138 -104
- data/java/.classpath +8 -8
- data/java/.project +17 -17
- data/java/src/com/rubyeventmachine/EmReactor.java +1 -0
- data/java/src/com/rubyeventmachine/EmReactorException.java +40 -40
- data/lib/em/buftok.rb +138 -138
- data/lib/em/callback.rb +25 -25
- data/lib/em/channel.rb +1 -1
- data/lib/em/connection.rb +6 -1
- data/lib/em/deferrable.rb +16 -2
- data/lib/em/file_watch.rb +53 -53
- data/lib/em/future.rb +61 -61
- data/lib/em/iterator.rb +270 -0
- data/lib/em/messages.rb +66 -66
- data/lib/em/process_watch.rb +43 -43
- data/lib/em/protocols.rb +1 -1
- data/lib/em/protocols/header_and_content.rb +138 -138
- data/lib/em/protocols/httpclient.rb +267 -262
- data/lib/em/protocols/line_protocol.rb +28 -0
- data/lib/em/protocols/memcache.rb +322 -322
- data/lib/em/protocols/postgres3.rb +247 -247
- data/lib/em/protocols/saslauth.rb +175 -175
- data/lib/em/protocols/smtpserver.rb +640 -547
- data/lib/em/protocols/stomp.rb +200 -200
- data/lib/em/protocols/tcptest.rb +52 -52
- data/lib/{pr_eventmachine.rb → em/pure_ruby.rb} +1013 -1022
- data/lib/em/queue.rb +1 -0
- data/lib/em/spawnable.rb +85 -85
- data/lib/em/streamer.rb +130 -130
- data/lib/em/tick_loop.rb +85 -0
- data/lib/em/timers.rb +2 -1
- data/lib/em/version.rb +1 -1
- data/lib/eventmachine.rb +40 -84
- data/lib/jeventmachine.rb +2 -1
- data/lib/rubyeventmachine.rb +2 -0
- data/setup.rb +1585 -1585
- data/tasks/doc.rake +30 -0
- data/tasks/package.rake +85 -0
- data/tasks/test.rake +6 -0
- data/tests/client.crt +31 -31
- data/tests/client.key +51 -51
- data/tests/test_attach.rb +13 -3
- data/tests/test_basic.rb +60 -95
- data/tests/test_channel.rb +3 -2
- data/tests/test_defer.rb +49 -47
- data/tests/test_deferrable.rb +35 -0
- data/tests/test_error_handler.rb +35 -35
- data/tests/test_errors.rb +82 -82
- data/tests/test_exc.rb +55 -55
- data/tests/test_file_watch.rb +49 -49
- data/tests/test_futures.rb +198 -198
- data/tests/test_handler_check.rb +36 -36
- data/tests/test_hc.rb +190 -218
- data/tests/test_httpclient.rb +227 -218
- data/tests/test_httpclient2.rb +3 -2
- data/tests/test_inactivity_timeout.rb +3 -3
- data/tests/test_kb.rb +60 -60
- data/tests/test_ltp.rb +13 -5
- data/tests/test_ltp2.rb +317 -317
- data/tests/test_next_tick.rb +1 -1
- data/tests/test_object_protocol.rb +36 -36
- data/tests/test_pending_connect_timeout.rb +2 -2
- data/tests/test_process_watch.rb +50 -48
- data/tests/test_proxy_connection.rb +52 -0
- data/tests/test_pure.rb +134 -125
- data/tests/test_queue.rb +44 -44
- data/tests/test_running.rb +42 -42
- data/tests/test_sasl.rb +72 -72
- data/tests/test_send_file.rb +251 -242
- data/tests/test_servers.rb +76 -76
- data/tests/test_smtpclient.rb +83 -83
- data/tests/test_smtpserver.rb +85 -85
- data/tests/test_spawn.rb +322 -322
- data/tests/test_ssl_methods.rb +49 -49
- data/tests/test_ssl_verify.rb +82 -82
- data/tests/test_tick_loop.rb +59 -0
- data/tests/test_timers.rb +13 -15
- data/tests/test_ud.rb +36 -36
- data/tests/testem.rb +31 -31
- metadata +66 -51
- data/ext/cplusplus.cpp +0 -202
- data/ext/emwin.cpp +0 -300
- data/ext/emwin.h +0 -94
- data/ext/epoll.cpp +0 -26
- data/ext/epoll.h +0 -25
- data/ext/eventmachine_cpp.h +0 -96
- data/ext/files.cpp +0 -94
- data/ext/files.h +0 -65
- data/ext/sigs.cpp +0 -89
- data/ext/sigs.h +0 -32
- data/java/src/com/rubyeventmachine/application/Application.java +0 -194
- data/java/src/com/rubyeventmachine/application/Connection.java +0 -74
- data/java/src/com/rubyeventmachine/application/ConnectionFactory.java +0 -37
- data/java/src/com/rubyeventmachine/application/DefaultConnectionFactory.java +0 -46
- data/java/src/com/rubyeventmachine/application/PeriodicTimer.java +0 -38
- data/java/src/com/rubyeventmachine/application/Timer.java +0 -54
- data/java/src/com/rubyeventmachine/tests/ApplicationTest.java +0 -109
- data/java/src/com/rubyeventmachine/tests/ConnectTest.java +0 -148
- data/java/src/com/rubyeventmachine/tests/EMTest.java +0 -80
- data/java/src/com/rubyeventmachine/tests/TestDatagrams.java +0 -53
- data/java/src/com/rubyeventmachine/tests/TestServers.java +0 -75
- data/java/src/com/rubyeventmachine/tests/TestTimers.java +0 -90
- data/lib/evma.rb +0 -32
- data/lib/evma/callback.rb +0 -32
- data/lib/evma/container.rb +0 -75
- data/lib/evma/factory.rb +0 -77
- data/lib/evma/protocol.rb +0 -87
- data/lib/evma/reactor.rb +0 -48
- data/web/whatis +0 -7
data/ext/em.h
CHANGED
@@ -17,16 +17,6 @@ See the file COPYING for complete licensing information.
|
|
17
17
|
|
18
18
|
*****************************************************************************/
|
19
19
|
|
20
|
-
|
21
|
-
|
22
|
-
#ifdef OS_WIN32
|
23
|
-
#include "emwin.h"
|
24
|
-
#endif
|
25
|
-
|
26
|
-
|
27
|
-
// THIS ENTIRE FILE WILL EVENTUALLY BE FOR UNIX BUILDS ONLY.
|
28
|
-
//#ifdef OS_UNIX
|
29
|
-
|
30
20
|
#ifndef __EventMachine__H_
|
31
21
|
#define __EventMachine__H_
|
32
22
|
|
@@ -57,16 +47,6 @@ See the file COPYING for complete licensing information.
|
|
57
47
|
#define EmSelect select
|
58
48
|
#endif
|
59
49
|
|
60
|
-
|
61
|
-
#ifdef OS_UNIX
|
62
|
-
typedef long long Int64;
|
63
|
-
#endif
|
64
|
-
#ifdef OS_WIN32
|
65
|
-
typedef __int64 Int64;
|
66
|
-
#endif
|
67
|
-
|
68
|
-
extern Int64 gCurrentLoopTime;
|
69
|
-
|
70
50
|
class EventableDescriptor;
|
71
51
|
class InotifyDescriptor;
|
72
52
|
|
@@ -82,7 +62,7 @@ class EventMachine_t
|
|
82
62
|
static void SetMaxTimerCount (int);
|
83
63
|
|
84
64
|
public:
|
85
|
-
EventMachine_t (
|
65
|
+
EventMachine_t (EMCallback);
|
86
66
|
virtual ~EventMachine_t();
|
87
67
|
|
88
68
|
void Run();
|
@@ -95,7 +75,6 @@ class EventMachine_t
|
|
95
75
|
const unsigned long CreateTcpServer (const char *, int);
|
96
76
|
const unsigned long OpenDatagramSocket (const char *, int);
|
97
77
|
const unsigned long CreateUnixDomainServer (const char*);
|
98
|
-
const unsigned long _OpenFileForWriting (const char*);
|
99
78
|
const unsigned long OpenKeyboard();
|
100
79
|
//const char *Popen (const char*, const char*);
|
101
80
|
const unsigned long Socketpair (char* const*);
|
@@ -137,6 +116,8 @@ class EventMachine_t
|
|
137
116
|
void _HandleKqueuePidEvent (struct kevent*);
|
138
117
|
#endif
|
139
118
|
|
119
|
+
uint64_t GetCurrentLoopTime() { return MyCurrentLoopTime; }
|
120
|
+
|
140
121
|
// Temporary:
|
141
122
|
void _UseEpoll();
|
142
123
|
void _UseKqueue();
|
@@ -144,6 +125,11 @@ class EventMachine_t
|
|
144
125
|
bool UsingKqueue() { return bKqueue; }
|
145
126
|
bool UsingEpoll() { return bEpoll; }
|
146
127
|
|
128
|
+
void QueueHeartbeat(EventableDescriptor*);
|
129
|
+
void ClearHeartbeat(uint64_t);
|
130
|
+
|
131
|
+
uint64_t GetRealTime();
|
132
|
+
|
147
133
|
private:
|
148
134
|
bool _RunOnce();
|
149
135
|
bool _RunTimers();
|
@@ -151,12 +137,16 @@ class EventMachine_t
|
|
151
137
|
void _AddNewDescriptors();
|
152
138
|
void _ModifyDescriptors();
|
153
139
|
void _InitializeLoopBreaker();
|
140
|
+
void _CleanupSockets();
|
154
141
|
|
155
142
|
bool _RunSelectOnce();
|
156
143
|
bool _RunEpollOnce();
|
157
144
|
bool _RunKqueueOnce();
|
158
145
|
|
159
146
|
void _ModifyEpollEvent (EventableDescriptor*);
|
147
|
+
void _DispatchHeartbeats();
|
148
|
+
timeval _TimeTilNextEvent();
|
149
|
+
void _CleanBadDescriptors();
|
160
150
|
|
161
151
|
public:
|
162
152
|
void _ReadLoopBreaker();
|
@@ -168,19 +158,20 @@ class EventMachine_t
|
|
168
158
|
MaxEvents = 4096
|
169
159
|
};
|
170
160
|
int HeartbeatInterval;
|
171
|
-
|
161
|
+
EMCallback EventCallback;
|
172
162
|
|
173
163
|
class Timer_t: public Bindable_t {
|
174
164
|
};
|
175
165
|
|
176
|
-
multimap<
|
166
|
+
multimap<uint64_t, Timer_t> Timers;
|
167
|
+
multimap<uint64_t, EventableDescriptor*> Heartbeats;
|
177
168
|
map<int, Bindable_t*> Files;
|
178
169
|
map<int, Bindable_t*> Pids;
|
179
170
|
vector<EventableDescriptor*> Descriptors;
|
180
171
|
vector<EventableDescriptor*> NewDescriptors;
|
181
172
|
set<EventableDescriptor*> ModifiedDescriptors;
|
182
173
|
|
183
|
-
|
174
|
+
uint64_t NextHeartbeatTime;
|
184
175
|
|
185
176
|
int LoopBreakerReader;
|
186
177
|
int LoopBreakerWriter;
|
@@ -190,7 +181,16 @@ class EventMachine_t
|
|
190
181
|
|
191
182
|
timeval Quantum;
|
192
183
|
|
184
|
+
uint64_t MyCurrentLoopTime;
|
185
|
+
|
186
|
+
#ifdef OS_WIN32
|
187
|
+
unsigned TickCountTickover;
|
188
|
+
unsigned LastTickCount;
|
189
|
+
#endif
|
190
|
+
|
193
191
|
private:
|
192
|
+
bool bTerminateSignalReceived;
|
193
|
+
|
194
194
|
bool bEpoll;
|
195
195
|
int epfd; // Epoll file-descriptor
|
196
196
|
#ifdef HAVE_EPOLL
|
@@ -225,8 +225,4 @@ struct SelectData_t
|
|
225
225
|
int nSockets;
|
226
226
|
};
|
227
227
|
|
228
|
-
|
229
|
-
|
230
228
|
#endif // __EventMachine__H_
|
231
|
-
|
232
|
-
//#endif // OS_UNIX
|
data/ext/eventmachine.h
CHANGED
@@ -35,11 +35,12 @@ extern "C" {
|
|
35
35
|
EM_CONNECTION_NOTIFY_WRITABLE = 107,
|
36
36
|
EM_SSL_HANDSHAKE_COMPLETED = 108,
|
37
37
|
EM_SSL_VERIFY = 109,
|
38
|
-
EM_PROXY_TARGET_UNBOUND = 110
|
38
|
+
EM_PROXY_TARGET_UNBOUND = 110,
|
39
|
+
EM_PROXY_COMPLETED = 111
|
39
40
|
|
40
41
|
};
|
41
42
|
|
42
|
-
void evma_initialize_library (
|
43
|
+
void evma_initialize_library (EMCallback);
|
43
44
|
void evma_run_machine();
|
44
45
|
void evma_release_library();
|
45
46
|
const unsigned long evma_install_oneshot_timer (int seconds);
|
@@ -96,7 +97,6 @@ extern "C" {
|
|
96
97
|
float evma_get_heartbeat_interval();
|
97
98
|
int evma_set_heartbeat_interval(float);
|
98
99
|
|
99
|
-
const unsigned long evma__write_file (const char *filename);
|
100
100
|
const unsigned long evma_popen (char * const*cmd_strings);
|
101
101
|
|
102
102
|
const unsigned long evma_watch_filename (const char *fname);
|
@@ -105,7 +105,7 @@ extern "C" {
|
|
105
105
|
const unsigned long evma_watch_pid (int);
|
106
106
|
void evma_unwatch_pid (const unsigned long);
|
107
107
|
|
108
|
-
void evma_start_proxy(const unsigned long, const unsigned long, const unsigned long);
|
108
|
+
void evma_start_proxy(const unsigned long, const unsigned long, const unsigned long, const unsigned long);
|
109
109
|
void evma_stop_proxy(const unsigned long);
|
110
110
|
|
111
111
|
int evma_set_rlimit_nofile (int n_files);
|
@@ -113,6 +113,7 @@ extern "C" {
|
|
113
113
|
void evma_set_epoll (int use);
|
114
114
|
void evma_set_kqueue (int use);
|
115
115
|
|
116
|
+
uint64_t evma_get_current_loop_time();
|
116
117
|
#if __cplusplus
|
117
118
|
}
|
118
119
|
#endif
|
data/ext/extconf.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
require 'fileutils'
|
1
2
|
require 'mkmf'
|
2
3
|
|
3
4
|
def check_libs libs = [], fatal = false
|
@@ -12,12 +13,63 @@ def add_define(name)
|
|
12
13
|
$defs.push("-D#{name}")
|
13
14
|
end
|
14
15
|
|
16
|
+
##
|
17
|
+
# OpenSSL:
|
18
|
+
|
19
|
+
# override append_library, so it actually appends (instead of prepending)
|
20
|
+
# this fixes issues with linking ssl, since libcrypto depends on symbols in libssl
|
21
|
+
def append_library(libs, lib)
|
22
|
+
libs + " " + format(LIBARG, lib)
|
23
|
+
end
|
24
|
+
|
25
|
+
def manual_ssl_config
|
26
|
+
ssl_libs_heads_args = {
|
27
|
+
:unix => [%w[ssl crypto], %w[openssl/ssl.h openssl/err.h]],
|
28
|
+
:mswin => [%w[ssleay32 libeay32], %w[openssl/ssl.h openssl/err.h]],
|
29
|
+
}
|
30
|
+
|
31
|
+
dc_flags = ['ssl']
|
32
|
+
dc_flags += ["#{ENV['OPENSSL']}/include", ENV['OPENSSL']] if /linux/ =~ RUBY_PLATFORM and ENV['OPENSSL']
|
33
|
+
|
34
|
+
libs, heads = case RUBY_PLATFORM
|
35
|
+
when /mswin/ ; ssl_libs_heads_args[:mswin]
|
36
|
+
else ssl_libs_heads_args[:unix]
|
37
|
+
end
|
38
|
+
dir_config(*dc_flags)
|
39
|
+
check_libs(libs) and check_heads(heads)
|
40
|
+
end
|
41
|
+
|
42
|
+
if ENV['CROSS_COMPILING']
|
43
|
+
openssl_dir = File.expand_path("~/.rake-compiler/builds/openssl-1.0.0a/")
|
44
|
+
if File.exists?(openssl_dir)
|
45
|
+
FileUtils.mkdir_p Dir.pwd+"/openssl/"
|
46
|
+
FileUtils.cp Dir[openssl_dir+"/include/openssl/*.h"], Dir.pwd+"/openssl/", :verbose => true
|
47
|
+
FileUtils.cp Dir[openssl_dir+"/lib*.a"], Dir.pwd, :verbose => true
|
48
|
+
$INCFLAGS << " -I#{Dir.pwd}" # for the openssl headers
|
49
|
+
else
|
50
|
+
STDERR.puts
|
51
|
+
STDERR.puts "**************************************************************************************"
|
52
|
+
STDERR.puts "**** Cross-compiled OpenSSL not found"
|
53
|
+
STDERR.puts "**** Run: hg clone http://bitbucket.org/ged/ruby-pg && cd ruby-pg && rake openssl_libs"
|
54
|
+
STDERR.puts "**************************************************************************************"
|
55
|
+
STDERR.puts
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
# Try to use pkg_config first, fixes #73
|
60
|
+
if pkg_config('openssl') || manual_ssl_config
|
61
|
+
add_define "WITH_SSL"
|
62
|
+
else
|
63
|
+
add_define "WITHOUT_SSL"
|
64
|
+
end
|
65
|
+
|
15
66
|
add_define 'BUILD_FOR_RUBY'
|
16
67
|
add_define 'HAVE_RBTRAP' if have_var('rb_trap_immediate', ['ruby.h', 'rubysig.h'])
|
17
68
|
add_define "HAVE_TBR" if have_func('rb_thread_blocking_region')# and have_macro('RUBY_UBF_IO', 'ruby.h')
|
18
69
|
add_define "HAVE_INOTIFY" if inotify = have_func('inotify_init', 'sys/inotify.h')
|
19
70
|
add_define "HAVE_OLD_INOTIFY" if !inotify && have_macro('__NR_inotify_init', 'sys/syscall.h')
|
20
71
|
add_define 'HAVE_WRITEV' if have_func('writev', 'sys/uio.h')
|
72
|
+
|
21
73
|
have_func('rb_thread_check_ints')
|
22
74
|
have_func('rb_time_new')
|
23
75
|
|
@@ -53,11 +105,13 @@ when /solaris/
|
|
53
105
|
add_define 'OS_SOLARIS8'
|
54
106
|
check_libs(%w[nsl socket], true)
|
55
107
|
|
56
|
-
|
57
|
-
if CONFIG['CC'] == 'cc'
|
108
|
+
if CONFIG['CC'] == 'cc' and `cc -flags 2>&1` =~ /Sun/ # detect SUNWspro compiler
|
58
109
|
# SUN CHAIN
|
59
|
-
|
110
|
+
add_define 'CC_SUNWspro'
|
111
|
+
$preload = ["\nCXX = CC"] # hack a CXX= line into the makefile
|
112
|
+
$CFLAGS = CONFIG['CFLAGS'] = "-KPIC"
|
60
113
|
CONFIG['CCDLFLAGS'] = "-KPIC"
|
114
|
+
CONFIG['LDSHARED'] = "$(CXX) -G -KPIC -lCstd"
|
61
115
|
else
|
62
116
|
# GNU CHAIN
|
63
117
|
# on Unix we need a g++ link, not gcc.
|
@@ -79,19 +133,6 @@ when /darwin/
|
|
79
133
|
when /linux/
|
80
134
|
add_define 'HAVE_EPOLL' if have_func('epoll_create', 'sys/epoll.h')
|
81
135
|
|
82
|
-
# Original epoll test is inadequate because 2.4 kernels have the header
|
83
|
-
# but not the code.
|
84
|
-
# add_define 'HAVE_EPOLL' if have_header('sys/epoll.h')
|
85
|
-
# if have_header('sys/epoll.h')
|
86
|
-
# File.open("hasEpollTest.c", "w") {|f|
|
87
|
-
# f.puts "#include <sys/epoll.h>"
|
88
|
-
# f.puts "int main() { epoll_create(1024); return 0;}"
|
89
|
-
# }
|
90
|
-
# (e = system( "gcc hasEpollTest.c -o hasEpollTest " )) and (e = $?.to_i)
|
91
|
-
# `rm -f hasEpollTest.c hasEpollTest`
|
92
|
-
# add_define 'HAVE_EPOLL' if e == 0
|
93
|
-
# end
|
94
|
-
|
95
136
|
# on Unix we need a g++ link, not gcc.
|
96
137
|
CONFIG['LDSHARED'] = "$(CXX) -shared"
|
97
138
|
|
@@ -103,38 +144,6 @@ else
|
|
103
144
|
CONFIG['LDSHARED'] = "$(CXX) -shared"
|
104
145
|
end
|
105
146
|
|
106
|
-
# OpenSSL:
|
107
|
-
|
108
|
-
def manual_ssl_config
|
109
|
-
ssl_libs_heads_args = {
|
110
|
-
:unix => [%w[ssl crypto], %w[openssl/ssl.h openssl/err.h]],
|
111
|
-
:darwin => [%w[ssl crypto C], %w[openssl/ssl.h openssl/err.h]],
|
112
|
-
# openbsd and linux:
|
113
|
-
:crypto_hack => [%w[crypto ssl crypto], %w[openssl/ssl.h openssl/err.h]],
|
114
|
-
:mswin => [%w[ssleay32 libeay32], %w[openssl/ssl.h openssl/err.h]],
|
115
|
-
}
|
116
|
-
|
117
|
-
dc_flags = ['ssl']
|
118
|
-
dc_flags += ["#{ENV['OPENSSL']}/include", ENV['OPENSSL']] if /linux/ =~ RUBY_PLATFORM
|
119
|
-
|
120
|
-
libs, heads = case RUBY_PLATFORM
|
121
|
-
when /mswin/ ; ssl_libs_heads_args[:mswin]
|
122
|
-
when /mingw/ ; ssl_libs_heads_args[:unix]
|
123
|
-
when /darwin/ ; ssl_libs_heads_args[:darwin]
|
124
|
-
when /openbsd/ ; ssl_libs_heads_args[:crypto_hack]
|
125
|
-
when /linux/ ; ssl_libs_heads_args[:crypto_hack]
|
126
|
-
else ssl_libs_heads_args[:unix]
|
127
|
-
end
|
128
|
-
dir_config(*dc_flags)
|
129
|
-
check_libs(libs) and check_heads(heads)
|
130
|
-
end
|
131
|
-
|
132
|
-
# Try to use pkg_config first, fixes #73
|
133
|
-
if pkg_config('openssl') || manual_ssl_config
|
134
|
-
add_define "WITH_SSL"
|
135
|
-
else
|
136
|
-
add_define "WITHOUT_SSL"
|
137
|
-
end
|
138
147
|
|
139
148
|
# solaris c++ compiler doesn't have make_pair()
|
140
149
|
TRY_LINK.sub!('$(CC)', '$(CXX)')
|
@@ -145,4 +154,4 @@ add_define 'HAVE_MAKE_PAIR' if try_link(<<SRC, '-lstdc++')
|
|
145
154
|
SRC
|
146
155
|
TRY_LINK.sub!('$(CXX)', '$(CC)')
|
147
156
|
|
148
|
-
create_makefile "rubyeventmachine"
|
157
|
+
create_makefile "rubyeventmachine"
|
@@ -44,11 +44,13 @@ when /solaris/
|
|
44
44
|
add_define 'OS_SOLARIS8'
|
45
45
|
check_libs(%w[nsl socket], true)
|
46
46
|
|
47
|
-
|
48
|
-
if CONFIG['CC'] == 'cc'
|
47
|
+
if CONFIG['CC'] == 'cc' and `cc -flags 2>&1` =~ /Sun/ # detect SUNWspro compiler
|
49
48
|
# SUN CHAIN
|
50
|
-
|
49
|
+
add_define 'CC_SUNWspro'
|
50
|
+
$preload = ["\nCXX = CC"] # hack a CXX= line into the makefile
|
51
|
+
$CFLAGS = CONFIG['CFLAGS'] = "-KPIC"
|
51
52
|
CONFIG['CCDLFLAGS'] = "-KPIC"
|
53
|
+
CONFIG['LDSHARED'] = "$(CXX) -G -KPIC -lCstd"
|
52
54
|
else
|
53
55
|
# GNU CHAIN
|
54
56
|
# on Unix we need a g++ link, not gcc.
|
@@ -1,214 +1,214 @@
|
|
1
|
-
/*****************************************************************************
|
2
|
-
|
3
|
-
$Id: mapper.cpp 4527 2007-07-04 10:21:34Z francis $
|
4
|
-
|
5
|
-
File: mapper.cpp
|
6
|
-
Date: 02Jul07
|
7
|
-
|
8
|
-
Copyright (C) 2007 by Francis Cianfrocca. All Rights Reserved.
|
9
|
-
Gmail: garbagecat10
|
10
|
-
|
11
|
-
This program is free software; you can redistribute it and/or modify
|
12
|
-
it under the terms of either: 1) the GNU General Public License
|
13
|
-
as published by the Free Software Foundation; either version 2 of the
|
14
|
-
License, or (at your option) any later version; or 2) Ruby's License.
|
15
|
-
|
16
|
-
See the file COPYING for complete licensing information.
|
17
|
-
|
18
|
-
*****************************************************************************/
|
19
|
-
|
20
|
-
|
21
|
-
//////////////////////////////////////////////////////////////////////
|
22
|
-
// UNIX implementation
|
23
|
-
//////////////////////////////////////////////////////////////////////
|
24
|
-
|
25
|
-
|
26
|
-
#ifdef OS_UNIX
|
27
|
-
|
28
|
-
#include <sys/types.h>
|
29
|
-
#include <sys/stat.h>
|
30
|
-
#include <sys/mman.h>
|
31
|
-
#include <fcntl.h>
|
32
|
-
#include <errno.h>
|
33
|
-
|
34
|
-
#include <iostream>
|
35
|
-
#include "unistd.h"
|
36
|
-
#include <string>
|
37
|
-
#include <cstring>
|
38
|
-
#include <stdexcept>
|
39
|
-
using namespace std;
|
40
|
-
|
41
|
-
#include "mapper.h"
|
42
|
-
|
43
|
-
/******************
|
44
|
-
Mapper_t::Mapper_t
|
45
|
-
******************/
|
46
|
-
|
47
|
-
Mapper_t::Mapper_t (const string &filename)
|
48
|
-
{
|
49
|
-
/* We ASSUME we can open the file.
|
50
|
-
* (More precisely, we assume someone else checked before we got here.)
|
51
|
-
*/
|
52
|
-
|
53
|
-
Fd = open (filename.c_str(), O_RDONLY);
|
54
|
-
if (Fd < 0)
|
55
|
-
throw runtime_error (strerror (errno));
|
56
|
-
|
57
|
-
struct stat st;
|
58
|
-
if (fstat (Fd, &st))
|
59
|
-
throw runtime_error (strerror (errno));
|
60
|
-
FileSize = st.st_size;
|
61
|
-
|
62
|
-
#ifdef OS_WIN32
|
63
|
-
MapPoint = (char*) mmap (0, FileSize, PROT_READ, MAP_SHARED, Fd, 0);
|
64
|
-
#else
|
65
|
-
MapPoint = (const char*) mmap (0, FileSize, PROT_READ, MAP_SHARED, Fd, 0);
|
66
|
-
#endif
|
67
|
-
if (MapPoint == MAP_FAILED)
|
68
|
-
throw runtime_error (strerror (errno));
|
69
|
-
}
|
70
|
-
|
71
|
-
|
72
|
-
/*******************
|
73
|
-
Mapper_t::~Mapper_t
|
74
|
-
*******************/
|
75
|
-
|
76
|
-
Mapper_t::~Mapper_t()
|
77
|
-
{
|
78
|
-
Close();
|
79
|
-
}
|
80
|
-
|
81
|
-
|
82
|
-
/***************
|
83
|
-
Mapper_t::Close
|
84
|
-
***************/
|
85
|
-
|
86
|
-
void Mapper_t::Close()
|
87
|
-
{
|
88
|
-
// Can be called multiple times.
|
89
|
-
// Calls to GetChunk are invalid after a call to Close.
|
90
|
-
if (MapPoint) {
|
91
|
-
#ifdef
|
92
|
-
munmap ((char*)MapPoint, FileSize);
|
93
|
-
#else
|
94
|
-
munmap ((void*)MapPoint, FileSize);
|
95
|
-
#endif
|
96
|
-
MapPoint = NULL;
|
97
|
-
}
|
98
|
-
if (Fd >= 0) {
|
99
|
-
close (Fd);
|
100
|
-
Fd = -1;
|
101
|
-
}
|
102
|
-
}
|
103
|
-
|
104
|
-
/******************
|
105
|
-
Mapper_t::GetChunk
|
106
|
-
******************/
|
107
|
-
|
108
|
-
const char *Mapper_t::GetChunk (unsigned start)
|
109
|
-
{
|
110
|
-
return MapPoint + start;
|
111
|
-
}
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
#endif // OS_UNIX
|
116
|
-
|
117
|
-
|
118
|
-
//////////////////////////////////////////////////////////////////////
|
119
|
-
// WINDOWS implementation
|
120
|
-
//////////////////////////////////////////////////////////////////////
|
121
|
-
|
122
|
-
#ifdef OS_WIN32
|
123
|
-
|
124
|
-
#include <windows.h>
|
125
|
-
|
126
|
-
#include <iostream>
|
127
|
-
#include <string>
|
128
|
-
#include <stdexcept>
|
129
|
-
using namespace std;
|
130
|
-
|
131
|
-
#include "mapper.h"
|
132
|
-
|
133
|
-
/******************
|
134
|
-
Mapper_t::Mapper_t
|
135
|
-
******************/
|
136
|
-
|
137
|
-
Mapper_t::Mapper_t (const string &filename)
|
138
|
-
{
|
139
|
-
/* We ASSUME we can open the file.
|
140
|
-
* (More precisely, we assume someone else checked before we got here.)
|
141
|
-
*/
|
142
|
-
|
143
|
-
hFile = INVALID_HANDLE_VALUE;
|
144
|
-
hMapping = NULL;
|
145
|
-
MapPoint = NULL;
|
146
|
-
FileSize = 0;
|
147
|
-
|
148
|
-
hFile = CreateFile (filename.c_str(), GENERIC_READ|GENERIC_WRITE, FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
|
149
|
-
|
150
|
-
if (hFile == INVALID_HANDLE_VALUE)
|
151
|
-
throw runtime_error ("File not found");
|
152
|
-
|
153
|
-
BY_HANDLE_FILE_INFORMATION i;
|
154
|
-
if (GetFileInformationByHandle (hFile, &i))
|
155
|
-
FileSize = i.nFileSizeLow;
|
156
|
-
|
157
|
-
hMapping = CreateFileMapping (hFile, NULL, PAGE_READWRITE, 0, 0, NULL);
|
158
|
-
if (!hMapping)
|
159
|
-
throw runtime_error ("File not mapped");
|
160
|
-
|
161
|
-
#ifdef OS_WIN32
|
162
|
-
MapPoint = (char*) MapViewOfFile (hMapping, FILE_MAP_WRITE, 0, 0, 0);
|
163
|
-
#else
|
164
|
-
MapPoint = (const char*) MapViewOfFile (hMapping, FILE_MAP_WRITE, 0, 0, 0);
|
165
|
-
#endif
|
166
|
-
if (!MapPoint)
|
167
|
-
throw runtime_error ("Mappoint not read");
|
168
|
-
}
|
169
|
-
|
170
|
-
|
171
|
-
/*******************
|
172
|
-
Mapper_t::~Mapper_t
|
173
|
-
*******************/
|
174
|
-
|
175
|
-
Mapper_t::~Mapper_t()
|
176
|
-
{
|
177
|
-
Close();
|
178
|
-
}
|
179
|
-
|
180
|
-
/***************
|
181
|
-
Mapper_t::Close
|
182
|
-
***************/
|
183
|
-
|
184
|
-
void Mapper_t::Close()
|
185
|
-
{
|
186
|
-
// Can be called multiple times.
|
187
|
-
// Calls to GetChunk are invalid after a call to Close.
|
188
|
-
if (MapPoint) {
|
189
|
-
UnmapViewOfFile (MapPoint);
|
190
|
-
MapPoint = NULL;
|
191
|
-
}
|
192
|
-
if (hMapping != NULL) {
|
193
|
-
CloseHandle (hMapping);
|
194
|
-
hMapping = NULL;
|
195
|
-
}
|
196
|
-
if (hFile != INVALID_HANDLE_VALUE) {
|
197
|
-
CloseHandle (hFile);
|
198
|
-
hMapping = INVALID_HANDLE_VALUE;
|
199
|
-
}
|
200
|
-
}
|
201
|
-
|
202
|
-
|
203
|
-
/******************
|
204
|
-
Mapper_t::GetChunk
|
205
|
-
******************/
|
206
|
-
|
207
|
-
const char *Mapper_t::GetChunk (unsigned start)
|
208
|
-
{
|
209
|
-
return MapPoint + start;
|
210
|
-
}
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
#endif // OS_WINDOWS
|
1
|
+
/*****************************************************************************
|
2
|
+
|
3
|
+
$Id: mapper.cpp 4527 2007-07-04 10:21:34Z francis $
|
4
|
+
|
5
|
+
File: mapper.cpp
|
6
|
+
Date: 02Jul07
|
7
|
+
|
8
|
+
Copyright (C) 2007 by Francis Cianfrocca. All Rights Reserved.
|
9
|
+
Gmail: garbagecat10
|
10
|
+
|
11
|
+
This program is free software; you can redistribute it and/or modify
|
12
|
+
it under the terms of either: 1) the GNU General Public License
|
13
|
+
as published by the Free Software Foundation; either version 2 of the
|
14
|
+
License, or (at your option) any later version; or 2) Ruby's License.
|
15
|
+
|
16
|
+
See the file COPYING for complete licensing information.
|
17
|
+
|
18
|
+
*****************************************************************************/
|
19
|
+
|
20
|
+
|
21
|
+
//////////////////////////////////////////////////////////////////////
|
22
|
+
// UNIX implementation
|
23
|
+
//////////////////////////////////////////////////////////////////////
|
24
|
+
|
25
|
+
|
26
|
+
#ifdef OS_UNIX
|
27
|
+
|
28
|
+
#include <sys/types.h>
|
29
|
+
#include <sys/stat.h>
|
30
|
+
#include <sys/mman.h>
|
31
|
+
#include <fcntl.h>
|
32
|
+
#include <errno.h>
|
33
|
+
|
34
|
+
#include <iostream>
|
35
|
+
#include "unistd.h"
|
36
|
+
#include <string>
|
37
|
+
#include <cstring>
|
38
|
+
#include <stdexcept>
|
39
|
+
using namespace std;
|
40
|
+
|
41
|
+
#include "mapper.h"
|
42
|
+
|
43
|
+
/******************
|
44
|
+
Mapper_t::Mapper_t
|
45
|
+
******************/
|
46
|
+
|
47
|
+
Mapper_t::Mapper_t (const string &filename)
|
48
|
+
{
|
49
|
+
/* We ASSUME we can open the file.
|
50
|
+
* (More precisely, we assume someone else checked before we got here.)
|
51
|
+
*/
|
52
|
+
|
53
|
+
Fd = open (filename.c_str(), O_RDONLY);
|
54
|
+
if (Fd < 0)
|
55
|
+
throw runtime_error (strerror (errno));
|
56
|
+
|
57
|
+
struct stat st;
|
58
|
+
if (fstat (Fd, &st))
|
59
|
+
throw runtime_error (strerror (errno));
|
60
|
+
FileSize = st.st_size;
|
61
|
+
|
62
|
+
#ifdef OS_WIN32
|
63
|
+
MapPoint = (char*) mmap (0, FileSize, PROT_READ, MAP_SHARED, Fd, 0);
|
64
|
+
#else
|
65
|
+
MapPoint = (const char*) mmap (0, FileSize, PROT_READ, MAP_SHARED, Fd, 0);
|
66
|
+
#endif
|
67
|
+
if (MapPoint == MAP_FAILED)
|
68
|
+
throw runtime_error (strerror (errno));
|
69
|
+
}
|
70
|
+
|
71
|
+
|
72
|
+
/*******************
|
73
|
+
Mapper_t::~Mapper_t
|
74
|
+
*******************/
|
75
|
+
|
76
|
+
Mapper_t::~Mapper_t()
|
77
|
+
{
|
78
|
+
Close();
|
79
|
+
}
|
80
|
+
|
81
|
+
|
82
|
+
/***************
|
83
|
+
Mapper_t::Close
|
84
|
+
***************/
|
85
|
+
|
86
|
+
void Mapper_t::Close()
|
87
|
+
{
|
88
|
+
// Can be called multiple times.
|
89
|
+
// Calls to GetChunk are invalid after a call to Close.
|
90
|
+
if (MapPoint) {
|
91
|
+
#ifdef CC_SUNWspro
|
92
|
+
munmap ((char*)MapPoint, FileSize);
|
93
|
+
#else
|
94
|
+
munmap ((void*)MapPoint, FileSize);
|
95
|
+
#endif
|
96
|
+
MapPoint = NULL;
|
97
|
+
}
|
98
|
+
if (Fd >= 0) {
|
99
|
+
close (Fd);
|
100
|
+
Fd = -1;
|
101
|
+
}
|
102
|
+
}
|
103
|
+
|
104
|
+
/******************
|
105
|
+
Mapper_t::GetChunk
|
106
|
+
******************/
|
107
|
+
|
108
|
+
const char *Mapper_t::GetChunk (unsigned start)
|
109
|
+
{
|
110
|
+
return MapPoint + start;
|
111
|
+
}
|
112
|
+
|
113
|
+
|
114
|
+
|
115
|
+
#endif // OS_UNIX
|
116
|
+
|
117
|
+
|
118
|
+
//////////////////////////////////////////////////////////////////////
|
119
|
+
// WINDOWS implementation
|
120
|
+
//////////////////////////////////////////////////////////////////////
|
121
|
+
|
122
|
+
#ifdef OS_WIN32
|
123
|
+
|
124
|
+
#include <windows.h>
|
125
|
+
|
126
|
+
#include <iostream>
|
127
|
+
#include <string>
|
128
|
+
#include <stdexcept>
|
129
|
+
using namespace std;
|
130
|
+
|
131
|
+
#include "mapper.h"
|
132
|
+
|
133
|
+
/******************
|
134
|
+
Mapper_t::Mapper_t
|
135
|
+
******************/
|
136
|
+
|
137
|
+
Mapper_t::Mapper_t (const string &filename)
|
138
|
+
{
|
139
|
+
/* We ASSUME we can open the file.
|
140
|
+
* (More precisely, we assume someone else checked before we got here.)
|
141
|
+
*/
|
142
|
+
|
143
|
+
hFile = INVALID_HANDLE_VALUE;
|
144
|
+
hMapping = NULL;
|
145
|
+
MapPoint = NULL;
|
146
|
+
FileSize = 0;
|
147
|
+
|
148
|
+
hFile = CreateFile (filename.c_str(), GENERIC_READ|GENERIC_WRITE, FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
|
149
|
+
|
150
|
+
if (hFile == INVALID_HANDLE_VALUE)
|
151
|
+
throw runtime_error ("File not found");
|
152
|
+
|
153
|
+
BY_HANDLE_FILE_INFORMATION i;
|
154
|
+
if (GetFileInformationByHandle (hFile, &i))
|
155
|
+
FileSize = i.nFileSizeLow;
|
156
|
+
|
157
|
+
hMapping = CreateFileMapping (hFile, NULL, PAGE_READWRITE, 0, 0, NULL);
|
158
|
+
if (!hMapping)
|
159
|
+
throw runtime_error ("File not mapped");
|
160
|
+
|
161
|
+
#ifdef OS_WIN32
|
162
|
+
MapPoint = (char*) MapViewOfFile (hMapping, FILE_MAP_WRITE, 0, 0, 0);
|
163
|
+
#else
|
164
|
+
MapPoint = (const char*) MapViewOfFile (hMapping, FILE_MAP_WRITE, 0, 0, 0);
|
165
|
+
#endif
|
166
|
+
if (!MapPoint)
|
167
|
+
throw runtime_error ("Mappoint not read");
|
168
|
+
}
|
169
|
+
|
170
|
+
|
171
|
+
/*******************
|
172
|
+
Mapper_t::~Mapper_t
|
173
|
+
*******************/
|
174
|
+
|
175
|
+
Mapper_t::~Mapper_t()
|
176
|
+
{
|
177
|
+
Close();
|
178
|
+
}
|
179
|
+
|
180
|
+
/***************
|
181
|
+
Mapper_t::Close
|
182
|
+
***************/
|
183
|
+
|
184
|
+
void Mapper_t::Close()
|
185
|
+
{
|
186
|
+
// Can be called multiple times.
|
187
|
+
// Calls to GetChunk are invalid after a call to Close.
|
188
|
+
if (MapPoint) {
|
189
|
+
UnmapViewOfFile (MapPoint);
|
190
|
+
MapPoint = NULL;
|
191
|
+
}
|
192
|
+
if (hMapping != NULL) {
|
193
|
+
CloseHandle (hMapping);
|
194
|
+
hMapping = NULL;
|
195
|
+
}
|
196
|
+
if (hFile != INVALID_HANDLE_VALUE) {
|
197
|
+
CloseHandle (hFile);
|
198
|
+
hMapping = INVALID_HANDLE_VALUE;
|
199
|
+
}
|
200
|
+
}
|
201
|
+
|
202
|
+
|
203
|
+
/******************
|
204
|
+
Mapper_t::GetChunk
|
205
|
+
******************/
|
206
|
+
|
207
|
+
const char *Mapper_t::GetChunk (unsigned start)
|
208
|
+
{
|
209
|
+
return MapPoint + start;
|
210
|
+
}
|
211
|
+
|
212
|
+
|
213
|
+
|
214
|
+
#endif // OS_WINDOWS
|