Scope resolution operator

In computer programming, scope is an enclosing context where values and expressions are associated. The scope resolution operator helps to identify and specify the context to which an identifier refers, particularly by specifying a namespace or class. The specific uses vary across different programming languages with the notions of scoping. In many languages, the scope resolution operator is written ::.

In some languages, notably those influenced by Modula-3 (including Python and Go), modules are objects, and scope resolution within modules is a special case of usual object member access, so the usual method operator . is used for scope resolution. Other languages, notably C++ and Ruby, feature both scope resolution and method access, which interact in various ways; see examples below.

C++

class A {
public:
    static int i; // scope of i is A
};

namespace B {
    int c = 2;
} // namespace B

int A::i = 4; // scope operator refers to the integer i declared in the class A
int x = B::c; // scope operator refers to the integer c declared in the namespace B

PHP

In PHP, the scope resolution operator is also called Paamayim Nekudotayim (Hebrew: פעמיים נקודותיים, pronounced [paʔaˈmajim nekudoˈtajim], the second word a colloquial corruption of נקודתיים, pronounced [nekudaˈtajim]), which means “double colon” in Hebrew.

The name "Paamayim Nekudotayim" was introduced in the Israeli-developed[1] Zend Engine 0.5 used in PHP 3. Initially the error message simply used the internal token name for the ::, T_PAAMAYIM_NEKUDOTAYIM causing confusion for non-Hebrew speakers. This was clarified in PHP 5.4 as below.

$ php -r ::
Parse error:  syntax error, unexpected '::' (T_PAAMAYIM_NEKUDOTAYIM)

As of PHP 8, the Hebrew name has been removed from the error message

$  php -r ::

Parse error: syntax error, unexpected token "::", expecting end of file in Command line code on line 1


Ruby

In Ruby, scope resolution can be specified using the module keyword.

module Example
  Version = 1.0

  class << self # We are accessing the module's singleton class
    def hello(who = "world")
      "Hello #{who}"
    end
  end
end #/Example

Example::hello # => "Hello world"
Example.hello "hacker" # => "Hello hacker"

Example::Version # => 1.0
Example.Version # NoMethodError

# This illustrates the difference between the message (.) operator and the scope operator in Ruby (::)
# We can use both ::hello and .hello, because hello is a part of Example's scope and because Example
# responds to the message hello.
#
# We can't do the same with ::Version and .Version, because Version is within the scope of Example, but
# Example can't respond to the message Version, since there is no method to respond with.

Scope is also affected by sigils which preface variable names:

References

  1. ^ "Scope Resolution Operator". PHP 5 Manual. Retrieved 2007-08-09.