Packages and Imports
Klyn keeps import rules deliberately strict so that name resolution stays predictable and fast. The language distinguishes clearly between packages, types, and fully qualified names.
Only the base package klyn is imported automatically. This gives immediate access
to core language types and helpers, but not to subpackages such as klyn.math or
klyn.collections.
# Works because klyn is implicit
value as Int = 10
# Requires an explicit import
import klyn.math
r = Rational(1, 3)
A package declaration belongs at the top of the file and must match the folder layout.
package my.app.core
public class User:
pass
The file must live under my/app/core/User.kn if User is the public
class declared in that file.
| Rule | Meaning |
|---|---|
| Import packages or qualified types | import klyn.math and import klyn.math.Rational are valid. Prefer package imports when several types are used. |
| Imports are module-level only | Do not place an import inside a function, method, or class body. |
| Fully qualified access remains available | You can always write klyn.math.Rational(1, 3) when you want a precise name. |
Qualified access is useful when two packages expose similarly named types or when you want to keep a script explicit without adding an import.
r = klyn.math.Rational(1, 3)
assert r.numerator == 1
assert r.denominator == 3
value = 10
import klyn.math # invalid: imports must stay at the beginning
def build():
import klyn.math # invalid: import inside a function
- Use one public top-level type per file.
- Keep the file name identical to that public type.
- Keep the package path aligned with the folder path.
- Prefer explicit imports over ambiguous name resolution.
Continue with Class Loading to understand where imported classes are searched and why the standard library always has priority.