Rubyはシンプルかつ強力なオブジェクト指向スクリプト言語です. Rubyは純粋なオブジェクト指向言語として設計されているので, オブジェクト指向プログラミングを手軽に行う事が出来ます.もちろん普通の手続き型のプログラミングも可能です.
Rubyはテキスト処理関係の能力などに優れ,Perlと同じくらい強力です.さらにシンプルな文法と, 例外処理やイテレータなどの機構によって,より分かりやすいプログラミングが出来ます.
- シンプルな文法
- 普通のオブジェクト指向機能(クラス,メソッドコールなど)
- 特殊なオブジェクト指向機能(Mixin,特異メソッドなど)
- 演算子オーバーロード
- 例外処理機能
- イテレータとクロージャ
- ガーベージコレクタ
- ダイナミックローディング (アーキテクチャによる)
- 移植性が高い.多くのUnix-like/POSIX互換プラットフォーム上で動くだけでなく,Windows, macOS, Haikuなどの上でも動く cf. https://docs.ruby-lang.org/en/master/maintainers_md.html#label-Platform+Maintainers
サードパーティーツールを使った方法を含むRubyのインストール方法の一覧は
https://www.ruby-lang.org/ja/downloads/
を参照してください.
ミラーをGitHubに公開しています. 以下のコマンドでリポジトリを取得できます.
$ git clone https://github.com/ruby/ruby.git
他のブランチの一覧は次のコマンドで見られます.
$ git ls-remote https://github.com/ruby/ruby.git
Rubyリポジトリの本来のmasterは https://git.ruby-lang.org/ruby.git にあります. コミッタはこちらを使います.
RubyのホームページのURLは
です.
Rubyのメーリングリストがあります.参加希望の方は ruby-list-request@ml.ruby-lang.org まで件名に
join
と書いて送って下さい.
Ruby開発者向けメーリングリストもあります.こちらではrubyのバグ,将来の仕様拡張など実装上の問題について議論されています. 参加希望の方は ruby-dev-request@ml.ruby-lang.org までruby-listと同様の方法でメールしてください.
Ruby拡張モジュールについて話し合うruby-extメーリングリストと数学関係の話題について話し合うruby-mathメーリングリストと 英語でrubyについて話し合うruby-talkメーリングリストもあります.参加方法はどれも同じです.
以下の手順で行ってください.
-
(Gitリポジトリから取得したソースをビルドする場合)
./autogen.sh
を実行して新しくconfigure
を生成する -
configure
を実行してMakefile
などを生成する環境によってはデフォルトのCコンパイラ用オプションが付きます.
configure
オプションでoptflags=..
warnflags=..
等で上書きできます. -
(必要ならば)
include/ruby/defines.h
を編集する多分,必要無いと思います.
-
(必要ならば)
ext/Setup
に静的にリンクする拡張モジュールを指定するext/Setup
に記述したモジュールは静的にリンクされます.ダイナミックローディングをサポートしていないアーキテクチャでは
Setup
の1行目の「option nodynamic
」という行のコ メントを外す必要があります. また,このアーキテクチャで拡張モジュールを利用するためには,あらかじめ静的にリンクをしておく必要があります. -
make
を実行してコンパイルする -
make check
でテストを行う.「
check succeeded
」と表示されれば成功です.ただしテストに成功しても完璧だと保証されている訳ではありません. -
make install
以下のディレクトリを作って,そこにファイルをインストー ルします.
${DESTDIR}${prefix}/bin
${DESTDIR}${prefix}/include/ruby-${MAJOR}.${MINOR}.${TEENY}
${DESTDIR}${prefix}/include/ruby-${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
${DESTDIR}${prefix}/lib
${DESTDIR}${prefix}/lib/ruby
${DESTDIR}${prefix}/lib/ruby/${MAJOR}.${MINOR}.${TEENY}
${DESTDIR}${prefix}/lib/ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
${DESTDIR}${prefix}/lib/ruby/site_ruby
${DESTDIR}${prefix}/lib/ruby/site_ruby/${MAJOR}.${MINOR}.${TEENY}
${DESTDIR}${prefix}/lib/ruby/site_ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
${DESTDIR}${prefix}/lib/ruby/vendor_ruby
${DESTDIR}${prefix}/lib/ruby/vendor_ruby/${MAJOR}.${MINOR}.${TEENY}
${DESTDIR}${prefix}/lib/ruby/vendor_ruby/${MAJOR}.${MINOR}.${TEENY}/${PLATFORM}
${DESTDIR}${prefix}/lib/ruby/gems/${MAJOR}.${MINOR}.${TEENY}
${DESTDIR}${prefix}/share/man/man1
${DESTDIR}${prefix}/share/ri/${MAJOR}.${MINOR}.${TEENY}/system
RubyのAPIバージョンが'x.y.z'であれば,
${MAJOR}
は 'x'で,${MINOR}
は'y',${TEENY}
は'z'です.注意: APIバージョンの
teeny
は,Rubyプログラムのバージョンとは異なることがあります.root
で作業する必要があるかもしれません.
もし,コンパイル時にエラーが発生した場合にはエラーのログとマシン,OSの種類を含むできるだけ詳しいレポートを作者に送って下さると他の方のためにもなります.
UNIXであれば configure
がほとんどの差異を吸収してくれるはずですが,思わぬ見落としがあった場合(ある事が多い),作者にその
ことを報告すれば,解決できる可能性があります.
アーキテクチャにもっとも依存するのはGC部です.RubyのGCは対象
のアーキテクチャがsetjmp()
またはgetcontext()
によって全てのレジスタを jmp_buf
や ucontext_t
に格納することと, jmp_buf
や ucontext_t
とスタックが32bitアラインメントされていることを仮定
しています.特に前者が成立しない場合の対応は非常に困難でしょう. 後者の解決は比較的簡単で, gc.c
でスタックをマークしている
部分にアラインメントのバイト数だけずらしてマークするコードを追加するだけで済みます.defined(__mc68000__)
で括られてい
る部分を参考にしてください.
レジスタウィンドウを持つCPUでは,レジスタウィンドウをスタックにフラッシュするアセンブラコードを追加する必要があるかもしれません.
COPYING.ja ファイルを参照してください.
Rubyに関する質問は Ruby-Talk(英語)や Ruby-List(日本語)や, stackoverflow などのWebサイトに投稿してください.
バグ報告は https://bugs.ruby-lang.org で受け付けています.
Rubyのオリジナル版は,1995年にまつもとゆきひろ氏によって設計・開発されました.