Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Identifier "PhantomCamera2D" not declared in the current scope #298

Closed
HeavensSword opened this issue May 12, 2024 · 5 comments
Closed

Identifier "PhantomCamera2D" not declared in the current scope #298

HeavensSword opened this issue May 12, 2024 · 5 comments

Comments

@HeavensSword
Copy link

HeavensSword commented May 12, 2024

Issue description

I'm getting the error "Parse Error: Identifier "PhantomCamera2D" not declared in the current scope." intermittently when hitting play from the Godot editor. This has been happening more frequently it seems like, especially after updating to the latest version. Sometimes it runs, other times it fails.

When the error occurs, it points to this line (348):

## Called when a [param PhantomCamera] is added to the scene.[br]
## [b]Note:[/b] This can only be called internally from a
## [param PhantomCamera] node.
func pcam_added_to_scene(pcam: Node) -> void:
    if is_instance_of(pcam, PhantomCamera2D) or is_instance_of(pcam, PhantomCamera3D): <-- This line 
        _pcam_list.append(pcam)

        if not pcam.tween_on_load:
            pcam.set_has_tweened(self, true) # Skips its tween if it has the highest priority on load

        _find_pcam_with_highest_priority()

    else:
        printerr("This function should only be called from PhantomCamera scripts")

Steps to reproduce

I'm really unsure as it seems to happen randomly upon hitting play. I'm not even using PhantomCamera2D in my game.

(Optional) Minimal reproduction project

No response

@ramokz
Copy link
Owner

ramokz commented May 12, 2024

If you have updated the addon from version 0.6.x ⇾ 0.7 within a project, then it's entirely possible that there's some lingering code in one of the hidden Godot directories that hasn't properly updated the name change of phantom_camera_2D to phantom_camera_2d — lowercased “d” at the end. Creating a new project and transferring over the res:// content might solve it then.

If the above doesn't help, would you be able to share a Minimal Reproduction Project (MRP) where that issue happens?
Mainly so I can see what setup and logic could potentially trigger this.
Haven't come across it myself, and there's not much I can do until I can replicate and verify that a fix would work.

@sci-comp
Copy link

sci-comp commented Jul 2, 2024

Hello,

This is an issue for me as well-- but, in my case at least, I've narrowed the issue down to the use of GDScript's class_name within a Mono build of Godot.

I've seen Nathan Hoad's users (the Godot Dialgue Manger addon) mention this issue as well, though, as far as I know, no one has more information as to a solution or cause, or has created a reproducible project.

A workaround to avoid getting an error is to click build, then play.

image

@sci-comp
Copy link

I no longer encounter the error I described after having upgraded into 4.3rc1 (I think around beta1 is when my issue was resolved, I don't know which PR was relevant).

@ramokz
Copy link
Owner

ramokz commented Jul 30, 2024

It was resolved in, if my reading is correct, Godot 4.3 Beta 3 in this PR.
Has been a long-standing issue with removing or changing classes in GDScript.

@ramokz
Copy link
Owner

ramokz commented Jul 30, 2024

Closing the issue as Godot 4.3 should be addressing, or at least mitigating, this issue.
If it's still being encountered after updating to that Godot version, or later, please do reopen it.

@ramokz ramokz closed this as completed Jul 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants