playbook/docs/tsl/syntax/01_introduction.md

99 lines
3.2 KiB
Markdown

# Introduction
文档类型:语法主线
是否可直接用于生成代码:仅部分
是否含已验证可执行示例:是
是否含已验证反例:否
遇到不确定时跳转到:[02_quickstart.md](02_quickstart.md)、[03_core_model.md](03_core_model.md)、[12_pitfalls.md](12_pitfalls.md)
手册位置:第 1 篇,共 32 篇。上一篇:手册入口 [index.md](index.md)。下一篇:[02_quickstart.md](02_quickstart.md)。
这一篇只做一件事:让新 session 在看到 TSL 时,先用正确的读法建立心智模型。
## 这一篇解决什么问题
回答“第一次读 TSL 时,应该先把它当成什么来理解,以及最容易和别的语言混淆的差异是什么”。
涉及赋值、命名参数、类外形、`unit` 骨架、数组 / 字符串下标这类高频硬规则时,统一以 [02_quickstart.md](02_quickstart.md) 的“语言核心事实速查”为准;这一页只负责建立第一印象。
## 先用什么方式读 TSL
- 可以先按 Pascal 风格语言去读它:常见外形是 `function ... begin ... end;`、`unit ... interface ... implementation ... end.`、`type Name = class ... end;`;但这里只借外形,不默认继承 Pascal 的全部语义、库习惯和文件模型。
- 先看顶层主体,再看细节;不要先被文件扩展名带偏。
- 当前手册把顶层主体优先收敛成四类:松散语句、顶层 `function / procedure`、顶层 `type Name = class`、顶层 `unit`
- 顶层 `uses` 可以出现,但这里只把它当成辅助组织语句,不把它当成主体声明。
- 日常赋值先记 `:=`,不要把 `=` 当成普通赋值。
## 第一次写时最容易混淆的差异
- `array(...)` 既可以当顺序数组,也可以当字符串键表。
- 数组下标从 `0` 开始,字符串下标从 `1` 开始。
- 顶层类定义按 `type Name = class ... end;` 去写,不使用裸 `class Name`
- 调用函数时,命名参数写成 `name: value`,例如 `Demo(a: 1, b: 2)`
## 已验证的第一印象
最常见的 `function / procedure` 外形:
代码块身份:已验证可执行示例
```tsl
function Demo();
begin
return 1;
end;
procedure LogDemo(msg);
begin
WriteLn(msg);
end;
```
赋值、数组、字符串下标的第一印象:
代码块身份:已验证可执行示例
```tsl
items := array(10, 20, 30);
table_data := array("Code": "000001", "Name": "Demo");
first_item := items[0];
first_char := "ABC"[1];
```
类的第一印象:
代码块身份:已验证可执行示例
```tsl
type DemoType = class
end;
```
`unit` 的第一印象:
代码块身份:已验证可执行示例
```tsl
unit DemoUnit;
interface
function Demo();
implementation
function Demo();
begin
return 1;
end;
end.
```
## 下一步怎么读
- 需要立刻开始写代码:看 [02_quickstart.md](02_quickstart.md)
- 需要判断当前文件属于哪一种顶层模型:看 [03_core_model.md](03_core_model.md)
- 需要先写值、数组、字符串:看 [04_values_and_literals.md](04_values_and_literals.md)
- 需要先写变量、常量:看 [05_variables_and_constants.md](05_variables_and_constants.md)
- 需要先写函数和调用:看 [06_functions_and_calls.md](06_functions_and_calls.md)