CI. Newt 関数
導入
これは RedHat Newt ライブラリのための PHP 拡張モジュールで、 ユーザに優しいアプリケーションを作成するための、ターミナルベースの ウィンドウやウィジェットのライブラリです。 PHP でこの拡張モジュールを有効にすることで Newt ウィジェットが使用可能に なります。この中にはウィンドウやボタン・チェックボックス・ラジオボタン・ ラベル・エディットボックス・スクロールバー・テキストエリア・スケールなどが 含まれます。この拡張モジュールの使用方法は、もとの C 言語用の API と非常によく似ています。
要件
このモジュールは RedHat Newt ライブラリの関数を使用します。 libnewt バージョン >= 0.51.0 が必要です。
インストール手順
この PECL 拡張 モジュールは PHP にバンドルされていません。 この PECL 拡張モジュールをインストールする方法は、 マニュアルの PECL 拡張モジュールのインストール という章にあります。 新規リリース・ダウンロード・ソースファイル・管理者情報・CHANGELOG といった関連する情報については、次の場所にあります。 http://pecl.php.net/package/newt .
PHP 4 の場合、この
PECL
拡張モジュール のソースは、PHP のソースの
ext/
ディレクトリ、または 上の
PECL
リンクで入手可能です。 これらの関数を使用するには、
--with-newt[=DIR]
オプションを使用し、newt サポートを有効にした上で CGI あるいは CLI 版の PHP を コンパイルする必要があります。
注意: この拡張モジュールは、Windows プラットフォームでは使用できません。
この拡張モジュールをコンパイルするには、 curses ライブラリおよび slang ライブラリも必要です。 これらのライブラリの場所を指定するには、以下の設定オプションを 使用します。 --with-curses-dir=/path/to/libcurses --with-slang-dir=/path/to/libslang
リソース型
この拡張モジュールは 2 つのリソース型 "newt component" および "newt grid" を使用します。 リソース型 "newt component" は関数から返されるもので、一般的な newt ウィジェット(例: newt_button() )を作成します。 リソース型 "newt grid" はコンポーネントの特別なリンク ID で、これは newt グリッドファクトリ関数(例: newt_create_grid() ) によって返されます。
定義済み定数
以下の定数が定義されています。 この関数の拡張モジュールが PHP 組み込みでコンパイルされているか、 実行時に動的にロードされている場合のみ使用可能です。
Newt フォームの終了原因
表 1. Newt フォームの終了原因
| 定数 | 意味 |
|---|---|
| NEWT_EXIT_HOTKEY | newt_form_add_hot_key() で定義したホットキーが押されました |
| NEWT_EXIT_COMPONENT | 何らかのコンポーネントがフォームを終了させました |
| NEWT_EXIT_FDREADY | newt_form_watch_fd() で指定したファイル記述子の 読み込みあるいは書き込みの準備が完了しました |
| NEWT_EXIT_TIMER | newt_form_set_timer() で指定した時間が 経過しました |
Newt 色セット
表 2. Newt 色セット
| 定数 | 意味 |
|---|---|
| NEWT_COLORSET_ROOT | |
| NEWT_COLORSET_BORDER | |
| NEWT_COLORSET_WINDOW | |
| NEWT_COLORSET_SHADOW | |
| NEWT_COLORSET_TITLE | |
| NEWT_COLORSET_BUTTON | |
| NEWT_COLORSET_ACTBUTTON | |
| NEWT_COLORSET_CHECKBOX | |
| NEWT_COLORSET_ACTCHECKBOX | |
| NEWT_COLORSET_ENTRY | |
| NEWT_COLORSET_LABEL | |
| NEWT_COLORSET_LISTBOX | |
| NEWT_COLORSET_ACTLISTBOX | |
| NEWT_COLORSET_TEXTBOX | |
| NEWT_COLORSET_ACTTEXTBOX | |
| NEWT_COLORSET_HELPLINE | |
| NEWT_COLORSET_ROOTTEXT | |
| NEWT_COLORSET_ROOTTEXT | |
| NEWT_COLORSET_EMPTYSCALE | |
| NEWT_COLORSET_FULLSCALE | |
| NEWT_COLORSET_DISENTRY | |
| NEWT_COLORSET_COMPACTBUTTON | |
| NEWT_COLORSET_ACTSELLISTBOX | |
| NEWT_COLORSET_SELLISTBOX |
Newt コンポーネントのフラグ
表 5. Newt コンポーネントのフラグ
| 定数 | 意味 |
|---|---|
| NEWT_FLAG_RETURNEXIT | コンポーネントがアクティブになった際にフォームを終了します |
| NEWT_FLAG_HIDDEN | コンポーネントは非表示です |
| NEWT_FLAG_SCROLL | コンポーネントはスクロール可能です |
| NEWT_FLAG_DISABLED | コンポーネントは使用不能です |
| NEWT_FLAG_BORDER | |
| NEWT_FLAG_WRAP | テキストを折り返します |
| NEWT_FLAG_NOF12 | F12 を押してもフォームを終了しません |
| NEWT_FLAG_MULTIPLE | |
| NEWT_FLAG_SELECTED | コンポーネントは選択されています |
| NEWT_FLAG_CHECKBOX | コンポーネントはチェックボックスです |
| NEWT_FLAG_PASSWORD | 入力コンポーネントはパスワード入力欄です |
| NEWT_FLAG_SHOWCURSOR | カーソルを表示します |
Newt キー
表 12. Newt キー
| 定数 | 意味 |
|---|---|
| NEWT_KEY_TAB | |
| NEWT_KEY_ENTER | |
| NEWT_KEY_SUSPEND | |
| NEWT_KEY_ESCAPE | |
| NEWT_KEY_RETURN | |
| NEWT_KEY_EXTRA_BASE | |
| NEWT_KEY_UP | |
| NEWT_KEY_DOWN | |
| NEWT_KEY_LEFT | |
| NEWT_KEY_RIGHT | |
| NEWT_KEY_BKSPC | |
| NEWT_KEY_DELETE | |
| NEWT_KEY_HOME | |
| NEWT_KEY_END | |
| NEWT_KEY_UNTAB | |
| NEWT_KEY_PGUP | |
| NEWT_KEY_PGDN | |
| NEWT_KEY_INSERT | |
| NEWT_KEY_F1 | |
| NEWT_KEY_F2 | |
| NEWT_KEY_F3 | |
| NEWT_KEY_F4 | |
| NEWT_KEY_F5 | |
| NEWT_KEY_F6 | |
| NEWT_KEY_F7 | |
| NEWT_KEY_F8 | |
| NEWT_KEY_F9 | |
| NEWT_KEY_F10 | |
| NEWT_KEY_F11 | |
| NEWT_KEY_F12 | |
| NEWT_KEY_RESIZE |
例
この例は、RedHat の 'setup' ユーティリティダイアログを PHP に移植した もので、テキストモードで動作します。
- 目次
- newt_bell -- ビープ音を端末に送信する
- newt_button_bar --
- newt_button --
- newt_centered_window -- 画面の中央に指定したサイズのウィンドウをオープンする
- newt_checkbox_get_value --
- newt_checkbox_set_flags --
- newt_checkbox_set_value --
- newt_checkbox_tree_add_item -- *
- newt_checkbox_tree_find_item --
- newt_checkbox_tree_get_current --
- newt_checkbox_tree_get_entry_value --
- newt_checkbox_tree_get_multi_selection --
- newt_checkbox_tree_get_selection --
- newt_checkbox_tree_multi --
- newt_checkbox_tree_set_current --
- newt_checkbox_tree_set_entry_value --
- newt_checkbox_tree_set_entry --
- newt_checkbox_tree_set_width --
- newt_checkbox_tree --
- newt_checkbox --
- newt_clear_key_buffer -- 追加の入力を待たずに、端末の入力バッファの内容をクリアする
- newt_cls --
- newt_compact_button --
- newt_component_add_callback --
- newt_component_takes_focus --
- newt_create_grid --
- newt_cursor_off --
- newt_cursor_on --
- newt_delay --
- newt_draw_form --
- newt_draw_root_text -- 指定した位置に文字列を表示する
- newt_entry_get_value --
- newt_entry_set_filter --
- newt_entry_set_flags --
- newt_entry_set --
- newt_entry --
- newt_finished -- newt インターフェースを終了する
- newt_form_add_component -- フォームにコンポーネントを追加する
- newt_form_add_components -- フォームに複数のコンポーネントを追加する
- newt_form_add_host_key --
- newt_form_destroy -- フォームを破壊する
- newt_form_get_current --
- newt_form_run -- フォームを実行する
- newt_form_set_background --
- newt_form_set_height --
- newt_form_set_size --
- newt_form_set_timer --
- newt_form_set_width --
- newt_form_watch_fd --
- newt_form -- フォームを作成する
- newt_get_screen_size -- 参照で渡された引数に、現在の端末の大きさを格納する
- newt_grid_add_components_to_form --
- newt_grid_basic_window --
- newt_grid_free --
- newt_grid_get_size --
- newt_grid_h_close_stacked --
- newt_grid_h_stacked --
- newt_grid_place --
- newt_grid_set_field --
- newt_grid_simple_window --
- newt_grid_v_close_stacked --
- newt_grid_v_stacked --
- newt_grid_wrapped_window_at --
- newt_grid_wrapped_window --
- newt_init -- newt を初期化する
- newt_label_set_text --
- newt_label --
- newt_listbox_append_entry --
- newt_listbox_clear_selection --
- newt_listbox_clear --
- newt_listbox_delete_entry --
- newt_listbox_get_current --
- newt_listbox_get_selection --
- newt_listbox_insert_entry --
- newt_listbox_item_count --
- newt_listbox_select_item --
- newt_listbox_set_current_by_key --
- newt_listbox_set_current --
- newt_listbox_set_data --
- newt_listbox_set_entry --
- newt_listbox_set_width --
- newt_listbox --
- newt_listitem_get_data --
- newt_listitem_set --
- newt_listitem --
- newt_open_window -- 指定したサイズと位置でウィンドウをオープンする
- newt_pop_help_line -- 現在のヘルプ行をスタックの内容で置き換える
- newt_pop_window -- トップウィンドウを画面から消去する
- newt_push_help_line -- 現在のヘルプ行をスタックに保存し、新しい行を表示する
- newt_radio_get_current --
- newt_radiobutton --
- newt_redraw_help_line --
- newt_reflow_text --
- newt_refresh -- 画面の変更された部分を更新する
- newt_resize_screen --
- newt_resume -- newt_suspend() をコールした後に newt インターフェースの使用を再開する
- newt_run_form -- フォームを実行する
- newt_scale_set --
- newt_scale --
- newt_scrollbar_set --
- newt_set_help_callback --
- newt_set_suspend_callback -- ユーザがサスペンドキーを押した際に起動するコールバック関数を設定する
- newt_suspend -- 端末を元の状態に戻すよう、newt に通知する
- newt_textbox_get_num_lines --
- newt_textbox_reflowed --
- newt_textbox_set_height --
- newt_textbox_set_text --
- newt_textbox --
- newt_vertical_scrollbar --
- newt_wait_for_key -- キーが押されるまで結果を返さない
- newt_win_choice --
- newt_win_entries --
- newt_win_menu --
- newt_win_message --
- newt_win_messagev --
- newt_win_ternary --