Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】PhpToken::__toString()メソッドの使い方

__toStringメソッドの使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

__toStringメソッドは、PhpTokenオブジェクトが表すトークンのテキスト内容を文字列として取得するメソッドです。このメソッドは、PHPの特定のオブジェクトを文字列として扱おうとした際に自動的に呼び出される「マジックメソッド」と呼ばれる特別なメソッドの一つです。

PhpTokenクラスは、PHP 8で導入されたクラスで、PHPのソースコードを個々の意味のある最小単位である「トークン」に分解するために使用されます。例えば、変数名、キーワード、演算子、文字列リテラルなどがそれぞれ一つのトークンとして扱われます。

PhpTokenクラスのインスタンスは、type(トークンの種類)、text(トークンの実際のテキスト内容)、line(行番号)、pos(開始位置)などの情報を持っています。この__toStringメソッドを呼び出すと、PhpTokenオブジェクトが保持するtextプロパティの値、つまりそのトークンの具体的なテキスト内容が文字列として返されます。

例えば、PHPのコード中に存在する$userNameという変数名をPhpTokenオブジェクトとして扱っている場合、このオブジェクトに対してechoprintなどの文字列を出力する操作を行うと、自動的に__toStringメソッドが実行され、$userNameという文字列が返されます。これにより、デバッグ時や、プログラム内でトークンの実際のテキスト内容を文字列として簡潔に利用したい場合に役立ちます。

構文(syntax)

1<?php
2$code = '<?php echo "Hello";';
3$tokens = PhpToken::getAll($code);
4echo $tokens[0];
5?>

引数(parameters)

引数なし

引数はありません

戻り値(return)

string

このメソッドは、PhpToken オブジェクトの文字列表現を返します。

サンプルコード

PHP 8 PhpToken::__toString()の利用

1<?php
2
3/**
4 * PhpTokenクラスの__toStringマジックメソッドの動作を示す関数。
5 *
6 * このメソッドは、PhpTokenオブジェクトが文字列として扱われたときに自動的に呼び出され、
7 * そのトークンのテキストコンテンツを返します。
8 *
9 * @param string $phpCode 解析するPHPコード文字列
10 * @return void
11 */
12function demonstratePhpTokenToString(string $phpCode): void
13{
14    echo "--- Original PHP Code ---\n";
15    echo $phpCode . "\n\n";
16
17    // PhpToken::tokenize() メソッドを使ってPHPコードをトークンに分解します。
18    // このメソッドはPHP 8以降で利用可能です。
19    $tokens = PhpToken::tokenize($phpCode);
20
21    echo "--- Token Information and __toString() Usage ---\n";
22
23    foreach ($tokens as $token) {
24        // トークンの基本情報を表示します(ID、名前、テキスト)。
25        echo "Token ID: {$token->id}, Name: " . ($token->name ?? 'N/A') . ", Text: '{$token->text}'\n";
26
27        // PhpToken オブジェクトを直接 echo で出力したり、文字列結合したりすると、
28        // PHPは自動的にこのオブジェクトの__toString()メソッドを呼び出します。
29        // PhpTokenの__toString()は、そのトークンのテキスト内容を返します。
30        echo "  __toString() output (via echo \$token): '" . $token . "'\n"; 
31        
32        // 直接 text プロパティにアクセスした場合の結果と比較します。
33        echo "  Direct text property (\$token->text): '" . $token->text . "'\n"; 
34        
35        // __toString() の結果がトークンのtextプロパティと一致することを確認します。
36        if ((string) $token === $token->text) {
37            echo "  Result matches token's text property.\n\n";
38        } else {
39            echo "  Mismatch detected! This should not normally happen.\n\n";
40        }
41    }
42}
43
44// PhpToken::__toString()の動作を示すための簡単なPHPコードを定義します。
45$sampleCode = '<?php echo "Hello World!"; $var = 123; /* comment */';
46
47// デモンストレーションを実行します。
48demonstratePhpTokenToString($sampleCode);
49

PHP 8で導入されたPhpTokenクラスは、PHPコードをより詳細に分析するため、コードを「トークン」と呼ばれる最小単位に分解する際に使用されます。このPhpTokenクラスに定義されている__toStringメソッドは、PHPの「マジックメソッド」の一つであり、PhpTokenオブジェクトが文字列として扱われるときに自動的に呼び出される特別なメソッドです。

このメソッドは引数を一切とりませんが、呼び出されると、そのPhpTokenオブジェクトが表すトークンの実際のテキスト内容を文字列として返します。例えば、echo $token;のようにPhpTokenオブジェクトを直接出力しようとしたり、文字列結合演算子(.)を使って他の文字列と連結しようとしたりすると、PHPは内部的にこの__toStringメソッドを呼び出し、オブジェクトのテキスト表現を取得します。

提供されたサンプルコードでは、まずPhpToken::tokenize()メソッドを使用してPHPコードを個々のトークンに分解しています。その後のループ処理では、各PhpTokenオブジェクトをecho $token;のように直接出力し、__toStringメソッドが自動的に呼び出される様子を示しています。この出力は、トークンが本来持っているテキストコンテンツである$token->textプロパティの内容と完全に一致することが確認できます。この機能は、PHPコードの解析やデバッグ作業において、トークンの内容を簡潔に表示したい場合に非常に便利です。

PhpTokenオブジェクトを文字列として扱う際、echo文や文字列結合などで直接使用すると、内部的に__toString()メソッドが自動で呼び出され、そのトークン自身のテキスト内容($token->textプロパティと同じ値)が返されます。

トークンの種類やIDなどの情報を得たい場合は、$token->name$token->idのように、それぞれのプロパティに明示的にアクセスしてください。__toString()は常にトークンテキストのみを返すため、それ以外の情報が必要な場合はこの点に注意し、直接プロパティを参照するようにしましょう。オブジェクトを意図せず文字列化してしまい、期待しない値が得られないよう理解しておくことが重要です。この機能はPHP 8以降で利用可能です。

PHPトークンを__toString()で文字列化する

1<?php
2
3// PHPコード文字列を定義します。
4// この文字列がPhpToken::tokenize()によってトークンに分解されます。
5$phpCode = '<?php echo "Hello World!"; ?>';
6
7// PhpToken::tokenize() メソッドを使用してPHPコードをトークンの配列に分解します。
8// 各要素はPhpTokenオブジェクトです。
9$tokens = PhpToken::tokenize($phpCode);
10
11echo "PHPコードをトークンに分解し、各トークンの内容を文字列として表示します。\n\n";
12
13// 分解されたトークン配列をループ処理します。
14foreach ($tokens as $token) {
15    // PhpTokenオブジェクトを文字列コンテキスト(例: echoや文字列結合)で使用すると、
16    // 内部的に __toString() マジックメソッドが呼び出され、そのトークンの文字列表現が返されます。
17    echo "タイプ: " . $token->getTokenName() . ",\t内容: '" . $token . "'\t(行: " . $token->line . ", カラム: " . $token->pos . ")\n";
18}
19
20echo "\n最初のトークンを文字列として直接使用する例:\n";
21
22// 配列が空でないことを確認します。
23if (!empty($tokens)) {
24    // 配列の最初のPhpTokenオブジェクトを取得します。
25    $firstToken = $tokens[0];
26
27    // PhpTokenオブジェクトを直接echoすることで、__toString() メソッドが呼び出され、
28    // そのトークンの内容(この場合は'<?php ')が文字列として出力されます。
29    echo "最初のトークンの内容: '" . $firstToken . "'\n";
30}
31
32?>

PHP 8のPhpToken::__toStringメソッドは、PhpTokenオブジェクトを文字列として扱おうとした際に自動的に呼び出される特殊な(マジック)メソッドです。このメソッドは引数を一切取らず、そのPhpTokenオブジェクトが表す実際のコードの内容を文字列として返します。

提供されたサンプルコードでは、まずPHPのコード文字列をPhpToken::tokenize()メソッドによって個々の「トークン」に分解しています。トークンとは、PHPコードを構成する最小単位の要素(キーワード、変数名、演算子、文字列など)のことです。分解された各PhpTokenオブジェクトは、ループ処理で一つずつ取り出されます。

ここで重要なのは、echo文の中で$tokenのようにPhpTokenオブジェクトを直接文字列コンテキストで使用している点です。PHPはこのような場合、そのオブジェクトに__toString()メソッドが定義されていれば、自動的にそのメソッドを呼び出し、返された文字列を使って出力を行います。これにより、各トークンの種類だけでなく、そのトークンが実際にどのような文字列内容を持っているかを簡単に確認できます。例えば、<?php という開始タグのトークンは、__toString()メソッドを通じて'<?php 'という文字列として表示されます。この機能は、コードの構文解析やデバッグにおいて非常に便利です。

PhpTokenオブジェクトをechoや文字列結合などの文字列コンテキストで利用すると、__toString()マジックメソッドが自動的に呼び出されます。このメソッドは明示的に呼び出す必要がなく、オブジェクトが文字列として扱われる際に、そのトークンの文字列表現、つまり元のPHPコードにおけるその部分を返します。戻り値は常にstring型ですので、型を意識して利用してください。この機能は、PHPコードを分析するツールなどで、各トークンの具体的な文字列内容を取得する際に特に役立ちます。オブジェクトの内部データを文字列として簡単に表示できる便利な仕組みですが、予期せぬ文字列変換が起きないよう、オブジェクトの振る舞いを理解して活用することが重要です。

関連コンテンツ