3.9 KiB
3.9 KiB
Nyash Style Guide (Phase 15)
Goals
- Keep Nyash sources readable and structured. Favor simple, predictable formatting compatible with reversible formatting (nyfmt PoC).
Formatting
- Indent with 2 spaces (no tabs).
- Braces: K&R style (opening brace on the same line).
- Max line length: 100 characters (soft limit).
- One statement per line. Use semicolons only when placing multiple statements on one physical line.
- Blank lines: separate top‑level
boxdeclarations with one blank line; no trailing blank lines at file end.
Statements and ASI
- Newline is the primary separator. See
reference/language/statements.md. - Do not insert semicolons before
else. - When breaking expressions across lines, break after an operator or keep the expression grouped.
using / include
- Place all
usinglines at the top of the file, before code. - One
usingper line; no trailing semicolons. - Sort
usingtargets alphabetically; group namespaces before file paths. - Prefer
asaliases for readability. Aliases should bePascalCase. - Keep
includeadjacent tousinggroup, sorted and one per line.
String concatenation policy
- Avoid using
"" + id(implicit to-string) when building map/register keys or control values. - Use explicit conversion helpers instead, e.g.
StringHelpers.int_to_str(id). - Plain string building for messages or JSON emit is allowed to use
+for clarity (no key/control impact).
Naming (conventions for Nyash code)
- Boxes (types):
PascalCase(e.g.,ConsoleBox,PathBox). - Methods/functions:
lowerCamelCase(e.g.,length,substring,lastIndexOf). - Local variables: concise
lowerCamelCase(e.g.,i,sum,filePath). - Constants (if any):
UPPER_SNAKE_CASE.
Structure
- Top‑to‑bottom:
using/include→ static/box declarations → helpers →main. - Keep methods short and focused; prefer extracting helpers to maintain clarity.
- Prefer pure helpers where possible; isolate I/O in specific methods.
Box layout
- 統一メンバ採用時(
NYASH_ENABLE_UNIFIED_MEMBERS=1)の推奨順序:- stored(格納プロパティ:
name: Type [= expr]) - computed / once / birth_once(読み専:
name: Type {}/once name: Type {}/birth_once name: Type {}) - methods(
birthを含む)
- stored(格納プロパティ:
- 既存表記でも同様に「フィールド(格納)を先頭にまとめる」。
- 先頭群の後ろはメソッドのみを記述する。
- メンバ間の空行・コメントは許可。アノテーション(将来)もメンバ直前/行末で許可。
- NG: 最初のメソッド以降に stored を追加すること(リンタ警告/厳格モードでエラー)。
良い例
box Employee {
// データ構造(フィールド)
name: StringBox
age: IntegerBox
department: StringBox
// ここからメソッド
birth(n, a, d) { me.name = n; me.age = a; me.department = d }
promote() { }
}
悪い例(NG)
box Bad {
id: IntegerBox
method1() { }
name: StringBox // ❌ フィールドはメソッドの後に置けない
}
ツール
- 警告: 既定は警告(
NYASH_CLI_VERBOSE=1で詳細を表示)。 - 厳格化:
NYASH_FIELDS_TOP_STRICT=1でエラーに昇格(Runnerでチェック)。
Examples
using core.std as Std
using "apps/examples/string_p0.hako" as Strings
static box Main {
escJson(s) { // lowerCamelCase for methods
local out = ""
local i = 0
local n = s.length()
loop(i < n) {
local ch = s.substring(i, i+1)
if ch == "\\" { out = out + "\\\\" }
else if ch == "\"" { out = out + "\\\"" }
else { out = out + ch }
i = i + 1
}
return out
}
main(args) {
local console = new ConsoleBox()
console.println("ok")
return 0
}
}
CI/Tooling
- Optional formatter PoC: see
docs/tools/nyfmt/NYFMT_POC_ROADMAP.md. - Keep smoke scripts small and fast; place them under
tools/.