Misplaced Pages

Qualification principle

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "Qualification principle" – news · newspapers · books · scholar · JSTOR (June 2024) (Learn how and when to remove this message)

In programming language theory, the qualification principle states that any semantically meaningful syntactic class may admit local definitions. In other words, it's possible to include a block in any syntactic class, provided that the phrases of that class specify some kind of computation. (Watt 1990)

A common examples for of this principle includes:

  • block command -- a command containing a local declaration, which is used only for executing this command. In the following excerpt from a C program, tmp variable declared is local to the surrounding block command:
if (a > b) {
    int tmp;
    tmp = a;
    a = b;
    b = tmp;
}
  • block expression -- an expression containing a local declaration, which is used only for evaluating this expression. In the following excerpt from ML program, local declaration of g can be used only during evaluation of the following expression:
let
    val g = 9.8
in
    m * g * h
end
  • block declaration is one containing a local declaration, the bindings produced by which are used only for elaborating the block declaration. In the following excerpt from ML program, local declaration of function leap, using an auxiliary function multiple:
local
    fun multiple (n: int, d: int) = 
          (n mod d = 0)
in
    fun leap (y: int) = 
          (multiple (y,4)
          andalso not multiple (y, 100))
          orelse multiple (y,400) 
end

References


Stub icon

This programming-language-related article is a stub. You can help Misplaced Pages by expanding it.

Stub icon

This computer science article is a stub. You can help Misplaced Pages by expanding it.

Categories: