新しくperlで標準で欲しい関数は?
結局自分で作ればいいんだが、 標準で「これがあれば便利なのに・・・」 と思う関数は、どんなもの? 便宜的に名前をつけて、仕様を説明してみてくれ。 [日本語文字列で文字コードを気にせず検索できる] に一票 >>42 41じゃないけど。 if ( $a == 1 /* 〜判定 */ or $a == 2 /* 〜判定 */ ) みたいのがほしい。 書いてみたら意味不明だった…これなら今のPerlでできるじゃん。。 ↑を一行にまとめてあるような場合の話ね。 hashをマージする関数は欲しいなぁ。書いても3行なんですけどね。 文字コード変換専用の関数があればいいかもね。いちいちjcode.plを 呼び出しているCGIが多くてウンザリするから。 まあわたしの場合は1つのサブスティチュートに書き替えているけどね。 画像ファイルの拡大/縮小 くらいだけでもできたらうれしい。 >>51 それはモジュールでやるべきことでしょう。さすがに。 >>49 たしかに欲しい。 "Hello,world!!\n"を印字する関数。書いても1行なんですけどね。 >>55 あらゆる言語で車輪の再開発がなされる部分だしね。 ビルトインクラスPerlWorldにジョークでHelloメソッドがあったら笑う。 こういう事したい if $sita < $naka < $ue; 関数じゃないけど、C言語みたいに、 sub funcname($val1,$val2,...,$valn){...} こういう風にサブルーティンを書けるようにしてほしい。 もちろん仮引数はローカル変数で。 >>3 Parrotの構文ツリー形式を吐くパーサを自分で書けばいいよ。 実例としてはparrot/languages/jako辺りのパーサ/コンパイラを見てくれ。 http://dev.perl.org/perl6/architecture ------ The parser will permit you to change its rules. Rule sets define major languages (Perl, C, Python, Java, etc.) and you can write new rules to define minor languages (Perl without $ @ % sigils, Python with curly braces, etc.). ------ >>6 Perl6 RFCでも、スレッドに関して幾つか提案がなされてるけど、 (1, 178, 185ほか)RFC185のような実装になるみたい。 RFC 185: Thread Programming Model http://dev.perl.org/rfc/185.html >>14 ./Configureの際に指定できるよ。 ...最近は設定プログラムにGNU Autoconfを利用した物がほとんどで、 Perlで使っているMetaconfig(by Larry Wall他)は滅多に見かけない...。 (autoconfは大抵質問してこないから楽だけど。) >>25 Perl6ではXS の代わりに Inline::* 系が標準になるので、 他言語で拡張パッケージを書くのはかなり楽になると思います。 >>41-42 >>47-48 RFC5, 102で提案されているけど、Larryは http://dev.perl.org/perl6/apocalypse/2 の"Inline Comments for Perl" で述べているとおり導入に消極的。 その代わりにプラグマinline_commentとかが追加されたりして。 Perl5でcppの使える環境なら-Pオプションで、コンパイル前に Cプリプロセッサに食わせてやることで実現が可能だけど。 Perl6の"is"オペーレータで同様のことが出来るかも。 if ( test1() is "checking something" && test2() is "眠いな" ) { # hogehoge } >>43 , 50 PerlIO::TextCodecクラスみたいなのが追加されたら便利かも。 (´-`).。oO(以下↓は妄想.....) *------* #!/usr/bin/perl6 use IO; my $in = new IO::TextStream(@ARGV[0]); #Perl6の配列要素参照は@array[index] my $out = new IO::TextStream(@ARGV[1]); $in.open("r") or $out.open("w") or die "open() failed"; $*in is chomped; # 入力は自動的に改行を削除 $out.setCodec(PerlIO::TextCodec::euc_JP); # 出力はeuc-jpで、とか while (!$in.end) { my string $line = $in.readline(); # 勝手にunicode文字列に変換して$lineへ $out.writeline($line); # $outのコーデックでunicode->euc-jp自動変換 $out << codec("euc-jp") << $line << endl; # まにぴゅれーたすたいる print $out: $line.locale8bit(); #ロケールに応じたエンコーディングで出力 my $codec = new PerlIO::TextCodec("shiftjis"); print $out: $codec.fromUnicode($line); } $in.close(); $out.close(); *-----* >>49 それは無いかなぁ >>51-52 それはライブラリのお仕事かなぁ >>60 Perl6では可能ですよ。詳しくは RFC025 http://dev.perl.org/rfc/25.html と、 Apocalypse 3<Operators> の "multiway comparisons" の項を見てね。 http://dev.perl.org/perl6/apocalypse/3 >>62 RFC26 http://dev.perl.org/rfc/26.html で提案され、Perl6で 取り入れられる予定です。Damian Conway氏のExegesis 2 "Take that! And that!" に実例が出てきます。 また、省略時パラメータは //= で行います。 ですから、例えばC++で(今書いてたコードから拝借) void QMenu::insert(const QString& text, int index = -1) { // なんやかや } をPerl6では、 sub QMenu::insert(string $name is constant, int $index //= -1) { # なんやかや } と書けます。 >>65 良くわからんけど、仮引き数は全部constになるのかな つまり、内部的に実引き数へのポインタが@_で@_へのポインタが 仮引き数になるけど、仮引き数のプロパティはconstantになるとか何とか・・・・ んー、結構良いけど何となく嫌 (^ー^; Damian 氏はC++ファンなんだろうか・・・ >>64 げげ、Perl6 で配列要素の参照方法変わるんですか... 本物の匿名型グロブを返すgensym()が欲しい。 いやなんとなく。 >>73 http://www.math.keio.ac.jp/ ~matumoto/mt.html なんかがよさげですね。。C,C++の標準関数になればみんな幸せになりそうですが・・ >>78 チャンチャラチャンチャラ (⌒) / (^ @^) - (⊃⊂) ヽ オッカシー (⌒) / (・ @^) - ○( ⊂) ヽ #include "perl6.h" #include "perl6/dbi.h" // usage: program perl-expr files int main(int argc, char** argv){ PERL6_MAIN_BEGIN; Perl::SV dbh = Perl::DBI::connect("dbi:foo:bar.db"); Perl::SV sth = dbh->prepare("SELECT * FROM hoge"); sth->execute(); Perl::SV row; while(row = sth->fetchrow_arrayref){ Perl::println(Perl::join(" ", row)); } sth->finish(); dbh->disconnect(); PERL6_MAIN_END; return 0; } >>80 それは何? C/C++のコードではないようだし。 sort のお話ですにゃ。 今の Perl は、巨大な配列を sort すると、効率が悪くなります;; @sorted = sort(@array); @array の要素数が増えるにしたがって、処理時間が爆発します。 これは Perl の sort() 関数が、効率の悪いアルゴリズムを 使っているせいでしょうか? かんたんな実験により、配列の要素数 を N とすると、perl の sort() 時の 比較回数はおよそ N * log N 回のオーダーという結果がでました。これは、 配列が 100 万要素だったとしても、たかだか N の20倍程度の比較回数にすぎません。 おそらくは最高レベルの効率です。私はこれに文句をつけることはできません。 では、sort() 自体は実用じゅうぶん速いのに、 なぜ上の1行は爆発的に遅くなるのでしょうか?試しにこう書いてみました。 sort(@array); これは@array が100万要素を超えていても、じゅうぶん高速でした。 (当然、ボイドコンテキストなので、結果は捨てられるので、意味はありません) ということは、巨大な配列の「複製」のために、ものすごく時間を 取られているということです。それはありうることです。 ソート結果を直接 @array に代入してしまう関数があれば、 これは解決できると思います。そういう sort関数を希望ですにゃ。 ( 私は ruby 使いじゃないのですが、 ruby には、「破壊的 sort」が用意されているらしいんですねぇ・・・ さすがにゃ) switch欲しい…… サブルーチンで作ってみようと努力したが構造的に不可能だった鬱 うるせーバカ。 初心者は黙ってろ スレのレベルが下がる >>85 > Exegesesを見る限り、destructive sortがPerl6に取り込まれる可能性はなさそう。 そうなんですか。むむー。 せめてsortを多重定義できればいいんですがねぇ。tieのSORTでもいいですが。 それにしても新構文はかなり奇怪ですなあ。 ↓かなり驚きましたよ。 if @array =~ $elem {...} # true if @array contains $elem if $key =~ %hash {...} # true if %hash{$key} if $value =~ (1..10) {...} # true if $value is in the list if $value =~ ('a',/\s/,7) {...} # true if $value is eq to 'a' # or if $value contains whitespace # or if $value is == to 7 標準関数よりも、標準ライブラリを充実させて欲しい シェルもろくに使えない奴らに「複雑な設定が必要」なんて言われもない 批判を受けるのはもういやだ。 女性の股を開く関数。 もしくは、チョンを殺してくれる関数。 >>85 そうにゃんだ。残念。 でも明快なお答えをありがとう。 >>100 ぜい肉をとるために、getほにゃららっていう network 関連の関数を モジュールに追い出すべきという意見はどうでしょう。 ・ネットワーク関連の関数をモジュールに追い出し ・数学関数をモジュールに追い出し ・format writeはイラネーヨ いっそのこと関数全部モジュールに追い出してしまえ! >>100 痩せすぎているので、少しは太れよってみんなから言われるよ そういうセリフ吐く奴ってoffで合うと大概口だけいかにももててますアピールの きもい系のヤシなんだよねw /bin/grepを呼ぶのにエスケープの手間がかかるんで ファイルからgrepする関数が欲しい。 @res = fgrep(/hoge/, /\.log$/,"/var/log/"); みたいな。 >>109 それこライブラリの仕事だろ。 それ以前にgrepとfgrepという全く別の関数が存在することも大いに問題だし。 どうしてもというならShell.pmでも使っとけ。 #!/bin/perl use Shell qw(fgrep); $ENV{PATH} = '/bin'; @res = fgrep 'hoge', '/var/log'; 今は Time::Local があるからまあ許すが その昔なぜ localtime が標準で実装されてて timelocal がなかったのか不思議だ。 Thread.pmがActivePerlでまともに使えるようになってほしい。 Perl5.8.0ではちゃんと動くのか? mmapを標準関数、もしくはcore moduleでおねがいぃ god("jpeg画像を120*120にリサイズする"); god("テキトーなデザインを出力する"); god("このソースが人に読まれない"); っていうのが欲しいです。 CSVファイルを扱う関数。 任意の項目によるソートとかいろいろ。 >>116 DBIモジュールが標準モジュールになったら使うよ。 >>49 俺様の力作使ってはくれまいか? sub merge { return(@_); } >>118 usage: %c = merge ( %a, %b ); こんな感じ? 確かにシンプルだ……。 >>49 は、キーがかぶった場合の仕様を作らなかったから、これでもいいと言える。 勉強になります。 use Benchmark; timethis(20000, sub{ -f 'index.html'}); exit; timethis 20000: 10 wallclock secs ( 9.77 usr + 0.00 sys = 9.77 CPU) @ 2047.08/s (n=20000) 遅すぎ、、、 もっと速くしてくれ。 >>49 >書いても3行なんですけどね。 %c = ( %a, %b ); どこらへんに三行要るんだろう? >>122 これは、 OSに処理を依頼しているわけですから、 どの言語でやっても遅くなると思いますよ。 >>124 そうなのですか、、、 うぅ、残念です。 >>123 元質問のひとは、一時的にメモリにギュバーっと展開しちゃうのは 嫌なのではないでしょうか Perlはじめたころ println() が欲しかった。 今でも欲すぃ 5.8で標準モジュールに追加されたList::UtilとScalar::Utilは便利なんだけど、 Scalar::Utilは実装のほとんどをList::Utilに頼ってるんだから、 一緒にしてUtilityとでもすればよかったと思う。 >>121 mergeってC++のSTLにあるような関数だと思うけど。 >>129 そうだね、どうせuse Socketしないとまともに使えないんだから、 Socketモジュールに入れても混乱は少ない気がする。 ━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━― PHPのurlencode htmlspecialchrs nl2br っていうか、自分でこしらえたけど ∧_∧ ピュ.ー ( ^^ ) <これからも僕を応援して下さいね(^^)。 =〔~∪ ̄ ̄〕 = ◎――◎ 山崎渉 __∧_∧_ |( ^^ )| <寝るぽ(^^) |\⌒⌒⌒\ \ |⌒⌒⌒~| 山崎渉 ~ ̄ ̄ ̄ ̄ read.cgi ver 07.5.0 2024/04/24 Walang Kapalit ★ | Donguri System Team 5ちゃんねる