[#46105] [ruby-trunk - Feature #6687][Open] Enumerable#with — "merborne (kyo endo)" <redmine@...>

14 messages 2012/07/02

[#46133] [ruby-trunk - Feature #6688][Open] Object#replace — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

24 messages 2012/07/03

[#46160] [ruby-trunk - Feature #6693][Open] Don't warn for unused variables starting with _ — "marcandre (Marc-Andre Lafortune)" <ruby-core@...>

15 messages 2012/07/04

[#46200] [ruby-trunk - Bug #6702][Open] Date should be either required or not — "rosenfeld (Rodrigo Rosenfeld Rosas)" <rr.rosas@...>

14 messages 2012/07/05

[#46296] [ruby-trunk - Feature #6717][Open] Method like #instance_eval that returns self (like #tap) — "alexeymuranov (Alexey Muranov)" <redmine@...>

10 messages 2012/07/10

[#46320] [ruby-trunk - Feature #6721][Open] Object#yield_self — "alexeymuranov (Alexey Muranov)" <redmine@...>

25 messages 2012/07/11

[#46339] [ruby-trunk - Bug #6724][Open] waaaaaaant! ( — "zenspider (Ryan Davis)" <redmine@...>

11 messages 2012/07/11

[#46377] [ruby-trunk - Feature #6727][Open] Add Array#rest (with implementation) — "duckinator (Nick Markwell)" <nick@...>

25 messages 2012/07/13

[#46492] [ruby-trunk - Feature #6737][Open] Add Hash#read and alias as #[]. — "trans (Thomas Sawyer)" <transfire@...>

12 messages 2012/07/15

[#46500] [ruby-trunk - Feature #6739][Open] One-line rescue statement should support specifying an exception class — Quintus (Marvin Gülker) <sutniuq@...>

22 messages 2012/07/15

[#46562] [ruby-trunk - Feature #6758][Open] Object#sequence — "merborne (kyo endo)" <redmine@...>

19 messages 2012/07/20

[#46574] [ruby-trunk - Feature #6762][Open] Control interrupt timing — "ko1 (Koichi Sasada)" <redmine@...>

39 messages 2012/07/20

[#46641] [ruby-trunk - Bug #6780][Open] cannot compile zlib module, when cross-compiling. — "jinleileiking (lei king)" <jinleileiking@...>

14 messages 2012/07/23

[#46659] [ruby-trunk - Bug #6783][Open] Infinite loop in inspect, not overriding inspect, to_s, and no known circular references. Stepping into inspect in debugger locks it up with 100% CPU. — "garysweaver (Gary Weaver)" <garysweaver@...>

8 messages 2012/07/23

[#46792] [ruby-trunk - Bug #6799][Open] Digest::*.hexdigest returns an ASCII-8BIT String — "Eregon (Benoit Daloze)" <redmine@...>

11 messages 2012/07/26

[#46799] [ruby-trunk - Feature #6801][Open] String#~ for a here document — "merborne (kyo endo)" <redmine@...>

12 messages 2012/07/27

[#46829] [ruby-trunk - Feature #6806][Open] Support functional programming: forbid instance/class variables for ModuleName::method_name, allow for ModuleName.method_name — "alexeymuranov (Alexey Muranov)" <redmine@...>

7 messages 2012/07/28

[#46832] [ruby-trunk - Bug #6807][Open] Can't compile ruby without ruby — "devcurmudgeon (Paul Sherwood)" <storitel@...>

13 messages 2012/07/28

[#46834] [ruby-trunk - Feature #6808][Open] Implicit index for enumerations — "trans (Thomas Sawyer)" <transfire@...>

15 messages 2012/07/28

[#46838] [ruby-trunk - Bug #6810][Open] `module A::B; end` is not equivalent to `module A; module B; end; end` with respect to constant lookup (scope) — "alexeymuranov (Alexey Muranov)" <redmine@...>

17 messages 2012/07/28

[#46896] (Half-baked DRAFT) new `require' framework — SASADA Koichi <ko1@...>

Hi,

22 messages 2012/07/31

[ruby-core:46896] (Half-baked DRAFT) new `require' framework

From: SASADA Koichi <ko1@...>
Date: 2012-07-31 12:29:46 UTC
List: ruby-core #46896
Hi,

This is `pre'-feature request.  I can't make up complete feature
request.  I post it to summaries current consideration.

----------------------

= Abstract

Now, `require' only loads `.rb' script or `.so' files from `file system'.

(Proposal-1)
This proposal extends the current limitation of require:

  (1) load script which is represented by other than `.rb' and `.so'.
    (example: pre-compiled file, encrypted file)

  (2) load script from location from other than `file system'.
    (example: require from zip archive, require over network,
     require files provided by gem efficiently using file location db)

(Proposal-2)
However, Proposal-1 is too big and we have not-enough time to discuss
about it.  I propose alternative feature: `require' contractible
primitives.  Break down `require' process and add primitives which can
implement `customized require' in Ruby (or C level).
Using (Proposal-2), we can make gem which provides (Proposal-1).  We can
try and discuss about good design of (Proposal-1).


= Background

Now, `require' only loads `.rb' script or `.so' files from `file system'.

(Problem example 1)
We can't specify .rb file in a zip archive, a tar archive, and so on.

(Problem example 2)
If `n' gems are installed, `n' paths are added to $LOAD_PATH by default.
 If `n' is large, then performance of `require' slows down heavily.

(Problem example 3)
Pre-compile (AOT: Ahead-of-Compile) is known technique to reduce loading
time.  However, we don't have any way to load data other than `.so' and
`.rb'.
AOT compiler `CastOff' <https://github.com/soba1104/CastOff> compile .rb
file into .so file.  It is a few way to make an AOT compiler.  However,
making .rb files into .so files increase binaries total size (about 10
times larger).


== Related work

=== JRuby

JRuby can require file from `.jar' (and .war file? sorry i'm not sure).
 JRuby also extends file path like VFS (virtual file system).  JRuby can
open a file in a .jar file like file system.
(JRuby GURU: Please complement this section!)

=== Rubinius

Rubinius supports AOT compile (a ruby script to a compiled file).
(Rubinius GURU: Please complement it!)

=== Python: PEP-273, PEP-302

Python can import file from Java file (described in PEP-273).
Python extends PEP-273 to import any format file by PEP-302.
This proposal (Proposal1) is based on PEP-302.

However, PEP-302 can only support to import `.py' and `.pyc' files, not
other file format.

=== Java Jigsaw project <http://openjdk.java.net/projects/jigsaw/>

(Java GURU: Help me to complement it!)

=== Other languages

any other similar interfaces?

= Proposal (1)

Make an `extensible require' framework for require().
It's my draft (not implemented yet):
  <http://www.atdot.net/sp/view/tcy08m/readonly>

== Interface description

(snip... not described yet)

== Usecase

(snip... not described yet)

= Proposal (2)

(snip... not described yet, sorry ;-)

= Discussion

== (Proposal-1) (1) is needed?
  (Python's PEP-302 doesn't support it.  It seems overkill)

== Need VFS?

We can't introduce VFS in 2.0 (because there are no enough time to
introduce it.

== Other considerations?


----

As you can see, it is only draft.
I send it because today is last day of July :)
(Aug is dead-line of big-feature for Ruby 2.0)

Thanks,
Koichi

-- 
// SASADA Koichi at atdot dot net

In This Thread

Prev Next