trycua/cua

Variable shadowing in computer class breaks shared directories.

Open

#124 opened on Apr 23, 2025

View on GitHub
 (3 comments) (0 reactions) (0 assignees)HTML (1,051 forks)batch import
good first issue

Repository metrics

Stars
 (16,722 stars)
PR merge metrics
 (Avg merge 1d) (166 merged PRs in 30d)

Description

This section in the Computer.__init__ method:

 if shared_directories:
    for path in shared_directories:
        abs_path = os.path.abspath(os.path.expanduser(path))  # type: ignore[attr-defined]
        if not os.path.exists(abs_path):  # type: ignore[attr-defined]
            raise ValueError(f"Shared directory does not exist: {path}")
        self.shared_paths.append(abs_path)

fails with:

abs_path = os.path.abspath(os.path.expanduser(path))  # type: ignore[attr-defined]
               ^^^^^^^
AttributeError: 'str' object has no attribute 'path'

because the module name is being shadowed by the init variable os, which is a string (macos, linux).

Please fix.

Contributor guide