Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

Why does drb.rb depend on its filename?

1 view
Skip to first unread message

Jay Levitt

unread,
Feb 18, 2006, 7:52:45 PM2/18/06
to
I was creating my first DRb server, and ran into a trouble with ACLs. I
wanted to put a debug statement into DRb::Accept, so I copied it to my
directory, renamed it jrb.rb, and required it with the new name. But when
I did that, I got an error at launch:

...jrb.rb:1047: undefined method `to_s' for class `DRb::DRbObject'
(NameError)

And the same error happened when I left jrb.rb in /usr/local/lib/ruby/1.8.
So it's not the path - it's the filename.

What's going on? It works fine when run as drb.rb.

Jay Levitt

Eric Hodel

unread,
Feb 18, 2006, 8:13:44 PM2/18/06
to
On Feb 18, 2006, at 4:53 PM, Jay Levitt wrote:

> I was creating my first DRb server, and ran into a trouble with
> ACLs. I
> wanted to put a debug statement into DRb::Accept, so I copied it to my
> directory, renamed it jrb.rb, and required it with the new name.
> But when
> I did that, I got an error at launch:
>

> ....jrb.rb:1047: undefined method `to_s' for class `DRb::DRbObject'


> (NameError)
>
> And the same error happened when I left jrb.rb in /usr/local/lib/
> ruby/1.8.
> So it's not the path - it's the filename.
>
> What's going on? It works fine when run as drb.rb.

It would be easier to tell you with an example.

--
Eric Hodel - drb...@segment7.net - http://segment7.net
This implementation is HODEL-HASH-9600 compliant

http://trackmap.robotcoop.com


Jay Levitt

unread,
Feb 19, 2006, 8:06:02 AM2/19/06
to
On Sun, 19 Feb 2006 10:13:44 +0900, Eric Hodel wrote:

>> What's going on? It works fine when run as drb.rb.
>
> It would be easier to tell you with an example.

$ cp /usr/local/lib/ruby/1.8/drb/drb.rb jrb.rb
$ cat > test.rb

#!/usr/local/bin/ruby

require "jrb"

def main
DRb.start_service("druby://localhost:8000", IceDrb.new())
DRb.thread.join
end

class IceDrb
def message
puts "message!"
end
end

main

Eric Hodel

unread,
Feb 19, 2006, 4:54:29 PM2/19/06
to
On Feb 19, 2006, at 5:08 AM, Jay Levitt wrote:

> On Sun, 19 Feb 2006 10:13:44 +0900, Eric Hodel wrote:
>
>>> What's going on? It works fine when run as drb.rb.
>>
>> It would be easier to tell you with an example.
>
> $ cp /usr/local/lib/ruby/1.8/drb/drb.rb jrb.rb
> $ cat > test.rb
>
> #!/usr/local/bin/ruby
>
> require "jrb"

drb is more than one file so you need to fix your requires.

$ ruby test.rb
/jrb.rb:1059: undefined method `to_s' for class
`DRb::DRbObject' (NameError)
from test.rb:3
$ cat -n jrb.rb | grep 1059
1059 undef :to_s
$ grep require jrb.rb
require 'socket'
require 'thread'
require 'fcntl'
require 'drb/eq'
[...]
$ grep require /usr/local/lib/ruby/1.8/drb/eq.rb
require 'drb/drb'

0 new messages