243

I've just updated my php version to 7.4, and i noticed this error pops up:

Array and string offset access syntax with curly braces is deprecated

here is part of my code which is triggering the above error:

public function getRecordID(string $zoneID, string $type = '', string $name = ''): string
{
    $records = $this->listRecords($zoneID, $type, $name);
    if (isset($records->result{0}->id)) {
        return $records->result{0}->id;
    }
    return false;
}

there are few libraries in my project which is using curly braces to get individual characters inside a string, whats the best way to change the syntax issue?

5
  • 4
    @AbraCadaver how is this duplicate of what you have suggested? Commented Dec 3, 2019 at 18:26
  • 1
    What do you mean by "best way to fix this issue"? What exactly keeps you from simply fixing this issue by changing the code? Commented Dec 6, 2020 at 11:42
  • 16
    @NicoHaase I guess he doesn't know what the right way to change it is? Which is probably why he's here asking on stackoverflow. Commented Feb 4, 2021 at 15:03
  • 2
    The specific answer in @Abra's canonical can be found here: stackoverflow.com/a/59158847/2943403 Commented Dec 15, 2021 at 13:56
  • 2
    Having "collection answers" is all right. Using them to close a specific answer is an abuse. Commented Dec 31, 2022 at 8:31

2 Answers 2

461

It's really simple to fix the issue, however keep in mind that you should fork and commit your changes for each library you are using in their repositories to help others as well.

Let's say you have something like this in your code:

$str = "test";
echo($str{0});

since PHP 7.4 curly braces method to get individual characters inside a string has been deprecated, so change the above syntax into this:

$str = "test";
echo($str[0]);

Fixing the code in the question will look something like this:

public function getRecordID(string $zoneID, string $type = '', string $name = ''): string
{
    $records = $this->listRecords($zoneID, $type, $name);
    if (isset($records->result[0]->id)) {
        return $records->result[0]->id;
    }
    return false;
}
Sign up to request clarification or add additional context in comments.

6 Comments

Do you happen to know when the $string{$pos} syntax was introduced in PHP? It must be ancient.
Ah, technically it was to be deprecated in PHP 5.1 (June 2008), but they forgot to add the code to notify people 😅: wiki.php.net/rfc/…
since which php version does this work? php5.1?
@helle it was part of the language before it gets deprecated
This is the correct fix, as explained in the 7.4 documentation: php.net/manual/en/…
|
-1

"Array and string offset access"

I was confused because I was not doing string access. But the problem is much more general - to access any "array" (hash), you use the square brackets.

So:

$list = ("name1" => "value", "name2" => "value")

is accessed like:

$list["name2"]

which is not natural for languages (perl) where a has is accessed differently than a list. Although python treats it like an array also..

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.