133 lines
4.1 KiB
Markdown
133 lines
4.1 KiB
Markdown
# Syntax Quickstart
|
|
|
|
文档类型:语法主线
|
|
是否可直接用于生成代码:是
|
|
是否含已验证可执行示例:是
|
|
是否含已验证反例:是
|
|
遇到不确定时跳转到:[03_core_model.md](03_core_model.md)、[06_functions_and_calls.md](06_functions_and_calls.md)、[10_units_and_scope.md](10_units_and_scope.md)
|
|
|
|
手册位置:第 2 篇,共 32 篇。上一篇:[01_introduction.md](01_introduction.md)。下一篇:[03_core_model.md](03_core_model.md)。
|
|
|
|
这一篇集中回答两个紧邻问题:现在要写 TSL 时,应该从哪一种最短骨架起手;以及落代码前必须先核对哪些语言硬规则。
|
|
|
|
## 这一篇解决什么问题
|
|
|
|
快速回答“当前任务应该从松散语句、函数、类还是 unit 开始”,并提供一份单点的语言核心事实速查。
|
|
|
|
## 语言核心事实速查
|
|
|
|
这一节是当前语法手册默认的语言硬规则收口点。涉及赋值、顶层外形、命名参数、类写法、`unit` 骨架和下标规则时,统一先看这里。
|
|
|
|
- 普通赋值用 `:=`,不要把 `=` 当成普通赋值。
|
|
- 顶层主体先按四类理解:松散语句、`function / procedure`、`type Name = class`、`unit`。
|
|
- 如果当前文件采用顶层 `function / procedure` 模型,就不要再混入松散语句。
|
|
- 无返回值时用 `procedure Name(...); begin ... end;`,不要勉强用 `function`。
|
|
- 顶层类定义统一写成 `type Name = class ... end;`,不要写裸 `class Name`。
|
|
- 多文件组织默认先按 `unit Name; interface ... implementation ... end.` 理解。
|
|
- 命名参数写法是 `Func(a:1, b:2)`。
|
|
- `array(...)` 既可以写顺序数组,也可以写字符串键表;数组下标从 `0` 开始,字符串下标从 `1` 开始。
|
|
|
|
## 术语对照
|
|
|
|
- 文档里出现的“顶层 `function / procedure`”“顶层函数骨架”“顶层函数定义体”,指的是同一类顶层模型:文件以顶层 `function` / `procedure` 为主体。
|
|
- 文档里出现的 ``class function`` 和“类方法”,指的是同一件事:前者是代码关键字写法,后者是中文描述。
|
|
|
|
## 先选哪一种骨架
|
|
|
|
| 当前任务 | 起手骨架 |
|
|
| --- | --- |
|
|
| 只写一段一次性脚本逻辑 | 顶层松散语句 |
|
|
| 先沉淀一个可复用逻辑块 | 顶层 `function` |
|
|
| 需要对象状态、字段、方法 | `type Name = class` |
|
|
| 需要把接口和实现组织进一个模块 | `unit` |
|
|
|
|
默认建议:
|
|
|
|
- 如果你只是要让新 session 先写出一段最稳、最容易续写的基础语法,优先从顶层 `function` 开始。
|
|
- `uses` 往往天然进入多文件查找路径问题,所以不放进这篇的最小起手骨架里。
|
|
|
|
## 已验证最小骨架
|
|
|
|
顶层松散语句骨架:
|
|
|
|
代码块身份:已验证可执行示例
|
|
|
|
```tsl
|
|
a := 1;
|
|
```
|
|
|
|
顶层函数骨架:
|
|
|
|
代码块身份:已验证可执行示例
|
|
|
|
```tsl
|
|
function Demo();
|
|
begin
|
|
return 1;
|
|
end;
|
|
```
|
|
|
|
顶层类骨架:
|
|
|
|
代码块身份:已验证可执行示例
|
|
|
|
```tsl
|
|
type DemoType = class
|
|
end;
|
|
```
|
|
|
|
顶层 `unit` 骨架:
|
|
|
|
代码块身份:已验证可执行示例
|
|
|
|
```tsl
|
|
unit DemoUnit;
|
|
interface
|
|
function Ping();
|
|
|
|
implementation
|
|
function Ping();
|
|
begin
|
|
return 1;
|
|
end;
|
|
end.
|
|
```
|
|
|
|
## 最常用起手版本
|
|
|
|
如果你现在没有明确的多文件或对象建模需求,直接从函数版本开始:
|
|
|
|
代码块身份:已验证可执行示例
|
|
|
|
```tsl
|
|
function Hello();
|
|
begin
|
|
return 1;
|
|
end;
|
|
```
|
|
|
|
## 最容易写错的一件事
|
|
|
|
- 不要把“顶层函数定义”和“顶层松散语句”混写在同一个最小文件里。
|
|
|
|
代码块身份:反例 / 不可照写
|
|
|
|
```text
|
|
function Add(a, b);
|
|
begin
|
|
return a + b;
|
|
end;
|
|
|
|
value := Add(1, 2);
|
|
```
|
|
|
|
上面这种“先定义顶层函数,再接松散语句”的混合写法会编译失败。
|
|
|
|
## 跳转指引
|
|
|
|
- 先建立整体读法:见 [01_introduction.md](01_introduction.md)
|
|
- 继续判断顶层模型:见 [03_core_model.md](03_core_model.md)
|
|
- 继续写函数:见 [06_functions_and_calls.md](06_functions_and_calls.md)
|
|
- 继续写 `unit` / `uses`:见 [10_units_and_scope.md](10_units_and_scope.md)
|
|
- 继续写类:见 [09_objects_and_classes.md](09_objects_and_classes.md)
|