68user's page 掲示板

Prev< No. 1449〜1454> Next  [最新発言に戻る] [過去ログ一覧]
No. 1449 # kiki@TL [E-mail] 2000/12/11 (月) 20:34:30
一応インストールは成功しているみたいです。GNOME+enlightenmentで「サウンドを有効にする」ボタンを押したらでは正常に動いたのですが、その後デスクトップのタスクバーが出なくなり、仕方なく再インストールして一からやり直したんですが、GNOM+Sawmillでは無理なんでしょうか?
PCはNECのLAVIE「LV16CWS」(ノート型)です。サウンドカードはESS社 ES1869Sで、動作確認の取れたOSSの最新版ファイルをインストール済みです。ディストリビューションは、Turbo Linux6.0です。
音だけじゃなくて、スクリーンセイバーもKDEだと動くのにGNOMEではプレビューでは見れても、実際には動きません。ウィンドウマネージャーとの愛称って在るんですかね???誰かアドバイスお願いします。
あとメモリーの自動認識ができないのですが、方法ありますか?解れば教えて下さい。96MBなのでデフォルトでは認識しないようです。宜しくお願いします。

No. 1450 # hayata [E-mail] 2000/12/11 (月) 23:21:46
skel.103Mさん @hayataです。
No.1437でのアドバイスありがとうございます。
出張でこちらの掲示板を見落としてしまいました。これからアドバイスに沿って再挑戦してみます。
成功しましたは報告いたします。
ではでは

No. 1451 # Mie 2000/12/12 (火) 14:13:12
1430の回答、ありがとうございました。
すぐに応答くださったのに、質問を投げた私が、反応が鈍く、
大変失礼いたしました。
「ヘルスチェック」という言い方は、どうやら「職場方言」のようですが、
68userさんの御推測の通りのものです。
回答いただいたうちの、3、及び4を、使用してみようと思っています。
ありがとうございました。
また、なにかの折りには、よろしくお願いいたします。

No. 1452 # rosegarden 2000/12/12 (火) 14:16:04
>とはいえ、! で fold されていたというのは気になりますね。
qpopper の場合一行の最大は \0 込みで 1024 bytes です。
ソースを見ると早いでしょう。

        /* Send the header of the message followed by a blank line */
        while (fgets(buffer, MAXMSGLINELEN, p->drop)) {
                if (!strncasecmp(buffer, "Content-Length:", 15) ||
                        !strncasecmp(buffer, "X-UIDL:", 7)) { /* Skip UIDLs */
                        continue; /* Content-Length is MTA dependent, don't send to MUA */
                }

\0 込みと言うのは、fgets 使っているための仕様です。

もしも、512 文字というのが 2 バイト文字の意味で、512 文字なら
ちょうどこの制限に引っかかります。\0 込みなので、iso2022-jp なら
途中出来られると ! なんていくらでも出て来ます。iso-2022-jp なら
「。」なんて「!#」とかなりますから。
ただ、普通は困りませんね。rfc で決められている一行の推奨値は
70 bytes + αですから。

問題は本当に POP3 サーバだけの制限なのかということです。
実験の際に使った MUA や MTA の制限も関係あります。
sendmail 8.11.1 のソースを見たら行の長さ関係は 2048 bytes でした。
また POP3 サーバなどをinetd を通している場合 inetd 自体の制限も
あります。8192 bytes かな? FreeBSD の inted の場合。ヘッダーしか見て
いないので断定できませんけど。
もっとも、自分で /var/mail/ のファイルにメールらしきものを手動で
append して実験した場合は話は別ですが。
他にも実験を telnet でやったのなら、telnet などの制限も考えられます。
FreeBSD なら ring buffer 使っているので、
そういう制限はありませんが、OS のベンダによってこの実装は変わるでしょうね。

No. 1453 # 68user 2000/12/12 (火) 21:34:23
> qpopper の場合一行の最大は \0 込みで 1024 bytes です。
それはヘッダの出力で、本文はその下の
        /* Send the message body */
        while(fgets(buffer, MAXMSGLINELEN, p->drop)) {
                /* Decrement the lines sent (for a TOP command) */
                if (--msg_lines <= 0) break;
                pop_sendline(p,buffer);
                if (hangup)
                    return(pop_msg(p, POP_FAILURE, "SIGHUP or SIGPIPE flagged"));
        }
でないでしょうか。で、pop_sendline は
    pop_sendline(POP *p, char *buffer){
            char * bp;
            /* Look for a <NL> in the buffer */
            if (bp = index(buffer,NEWLINE)) *bp = 0;
            /* Send the line to the client */
            (void)fputs(buffer,p->output);
            /* Put a <CR><NL> if a newline was removed from the buffer */
            if (bp) (void)fputs ("\r\n",p->output);
    }
となっているので (一部略)、fgets で得たデータに改行が
含まれない場合も、余計な改行は付加されないように思う
のですがどうでしょう
# 改行なしだと bp==NULL になって fputs("\r\n") は実行されない。

rosegarden さんは qpopper-2.x 系列を見ておられるよう
ですが、僕が見たのは qpopper-2.2 (ってこりゃまた古いな)
の pop_send.c です。

No. 1454 # rosegarden 2000/12/12 (火) 22:59:02
>rosegarden さんは qpopper-2.x 系列を見ておられるよう
>ですが、僕が見たのは qpopper-2.2 (ってこりゃまた古いな)
>の pop_send.c です。
私が見たのは、qpopper-2.3 のソースですね。古いことにはかわりないんですが…。
確かに、
>それはヘッダの出力で、本文はその下の
> /* Send the message body */
> while(fgets(buffer, MAXMSGLINELEN, p->drop)) {
は御指摘の通りです。本質的にソースに差異はありません。でも、
これも結局
#define MAXLINELEN 1024
#define MAXMSGLINELEN MAXLINELEN
なんで、結果的には同じですね。ただし、結果的に同じだっただけで、
私の間違いは間違いです。御指摘ありがとうございます。
なお、上のは同じバージョンの popper.h の define です。
>となっているので (一部略)、fgets で得たデータに改行が
>含まれない場合も、余計な改行は付加されないように思う
>のですがどうでしょう
まず、fgets は man 3 fgets すると
>The fgets() function reads at most one less than the number of characters
>specified by size from the given stream and stores them in the string str.
最大で size で指定された文字から一文字少ない文字をバッファに読み込む
とあります。これは \0 をappendしないといけないからです。
サンプルプログラムを次のようにします。
#include <stdio.h>

int
main( int argc, char **argv )
{
                FILE *fp;
                char buff[256];

                if( argc != 2 ){
                                fprintf( stderr, "usage : fgets FILENAME\n" );
                                exit(1);
                }

                if( ( fp = fopen( argv[1], "r" ) ) == NULL ){
                                fprintf( stderr, "Cannot read %s\n", argv[1] );
                                exit(1);
                }
                while( fgets( buff, 10, fp ) ){
                                puts(buff);
                }
                exit(0);
}
さらにこれを
gcc -g -O -o fgets fgets.c
としてコンパイルして gdb で buff の中を見ます。
(gdb) break 18
Breakpoint 1 at 0x8048604: file fgets.c, line 18.
(gdb) set arg fgets.c
(gdb) run
Starting program: /home/user/tmp/fgets fgets.c

Breakpoint 1, main (argc=2, argv=0xbfbff740) at fgets.c:18
18 while( fgets( buff, 10, fp ) ){
(gdb) display buff
1: buff = "\201\203 (ゴミのため略)
(gdb) n
19 puts(buff);
1: buff = "#include \000\005( 以下ゴミ )
(gdb) q
こんな感じですね。
># 改行なしだと bp==NULL になって fputs("\r\n") は実行されない。
これは違うと思います。bp == NULL なら単に \r\n を append するだけ
で bp != NULL なら \n を \0 で潰してから、\r\n を append だと
思います。良く見てください、元のコードを *bp = '\0' となっています。
bp は index が拾って来た \n のあるところのポインタです。

Prev< No. 1449〜1454> Next  [最新発言に戻る] [過去ログ一覧]