99 lines
3.2 KiB
Markdown
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)
|