-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathПредметТексту.ц
559 lines (508 loc) · 48.3 KB
/
ПредметТексту.ц
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
взяти визначення МаМа;
секція МаМа {
дія нативна_дія_тексту_чародія_отримати_елемент(предмет_нативної_дії: адреса<ПредметНативноїДії>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
якщо предмет_я == пусто {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_отримати_елемент\" не можна виконувати від від пусто") як адреса<Предмет>;
}
якщо предмет_я.тип != М.предмет_структури_текст {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_отримати_елемент\" можна виконувати лише від тексту") як адреса<Предмет>;
}
ціль предмет_тексту = предмет_я як адреса<ПредметТексту>;
змінна ціль знайдено_предмет_аргумента_ключа = ні;
змінна ціль предмет_аргумента_ключа: адреса<Предмет> = пусто;
якщо іменовані_аргументи != пусто {
ціль елемент_ключа = отримати_з_реєстру<адреса<Назва>, адреса<Предмет>>(М, іменовані_аргументи, М.БН.С.ключ);
якщо елемент_ключа != пусто {
знайдено_предмет_аргумента_ключа = так;
предмет_аргумента_ключа = елемент_ключа.значення;
}
}
якщо знайдено_предмет_аргумента_ключа == ні {
якщо аргументи != пусто {
якщо аргументи.розмір > 0 {
знайдено_предмет_аргумента_ключа = так;
предмет_аргумента_ключа = аргументи.дані[0];
}
}
}
якщо знайдено_предмет_аргумента_ключа == ні {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Пропущено аргумент \"ключ\"") як адреса<Предмет>;
}
вернути предмет_тексту_отримати_елемент(предмет_тексту, М, предмет_аргумента_ключа);
}
дія нативна_дія_тексту_чародія_перебір(предмет_нативної_дії: адреса<ПредметНативноїДії>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
ціль предмет_тексту = предмет_я як адреса<ПредметТексту>;
вернути предмет_тексту_отримати_перебір(предмет_тексту, М);
}
дія нативна_дія_тексту_чародія_додати(предмет_нативної_дії: адреса<ПредметНативноїДії>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
якщо предмет_я == пусто {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_додати\" не можна виконувати від від пусто") як адреса<Предмет>;
}
якщо предмет_я.тип != М.предмет_структури_текст {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_додати\" можна виконувати лише від тексту") як адреса<Предмет>;
}
ціль предмет_тексту = предмет_я як адреса<ПредметТексту>;
змінна ціль знайдено_предмет_аргумента = ні;
змінна ціль предмет_аргумента: адреса<Предмет> = пусто;
якщо іменовані_аргументи != пусто {
ціль елемент_значення = отримати_з_реєстру<адреса<Назва>, адреса<Предмет>>(М, іменовані_аргументи, М.БН.С.значення);
якщо елемент_значення != пусто {
знайдено_предмет_аргумента = так;
предмет_аргумента = елемент_значення.значення;
}
}
якщо знайдено_предмет_аргумента == ні {
якщо аргументи != пусто {
якщо аргументи.розмір > 0 {
знайдено_предмет_аргумента = так;
предмет_аргумента = аргументи.дані[0];
}
}
}
якщо знайдено_предмет_аргумента == ні {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Пропущено аргумент \"значення\"") як адреса<Предмет>;
}
вернути предмет_тексту_додати(предмет_тексту, М, предмет_аргумента);
}
дія нативна_дія_тексту_чародія_містить(предмет_нативної_дії: адреса<ПредметНативноїДії>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
якщо предмет_я == пусто {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_містить\" не можна виконувати від від пусто") як адреса<Предмет>;
}
якщо предмет_я.тип != М.предмет_структури_текст {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Чародію тексту \"чародія_містить\" можна виконувати лише від тексту") як адреса<Предмет>;
}
ціль предмет_тексту = предмет_я як адреса<ПредметТексту>;
змінна ціль знайдено_предмет_аргумента = ні;
змінна ціль предмет_аргумента: адреса<Предмет> = пусто;
якщо іменовані_аргументи != пусто {
ціль елемент_значення = отримати_з_реєстру<адреса<Назва>, адреса<Предмет>>(М, іменовані_аргументи, М.БН.С.значення);
якщо елемент_значення != пусто {
знайдено_предмет_аргумента = так;
предмет_аргумента = елемент_значення.значення;
}
}
якщо знайдено_предмет_аргумента == ні {
якщо аргументи != пусто {
якщо аргументи.розмір > 0 {
знайдено_предмет_аргумента = так;
предмет_аргумента = аргументи.дані[0];
}
}
}
якщо знайдено_предмет_аргумента == ні {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Пропущено аргумент \"значення\"") як адреса<Предмет>;
}
вернути предмет_тексту_містить(предмет_тексту, М, предмет_аргумента);
}
місцева дія створити_структуру_тексту(М: адреса<Машина>): адреса<ПредметСтруктури> {
ціль предмет_структури = виділити_предмет_структури(М, М.БН.С.текст, М.предмет_структури_предмет);
ціль предмет_нативної_дії_тексту_чародія_отримати_елемент = виділити_предмет_нативної_дії(М, М.БН.С.чародія_отримати_елемент, нативна_дія_тексту_чародія_отримати_елемент, пусто, пусто);
змінити_в_реєстрі<адреса<Назва>, адреса<Предмет>>(М, предмет_структури.методи::адреса, М.БН.С.чародія_отримати_елемент, предмет_нативної_дії_тексту_чародія_отримати_елемент як адреса<Предмет>);
ціль предмет_нативної_дії_тексту_чародія_перебір = виділити_предмет_нативної_дії(М, М.БН.С.чародія_перебір, нативна_дія_тексту_чародія_перебір, пусто, пусто);
змінити_в_реєстрі<адреса<Назва>, адреса<Предмет>>(М, предмет_структури.методи::адреса, М.БН.С.чародія_перебір, предмет_нативної_дії_тексту_чародія_перебір як адреса<Предмет>);
ціль предмет_нативної_дії_тексту_чародія_додати = виділити_предмет_нативної_дії(М, М.БН.С.чародія_додати, нативна_дія_тексту_чародія_додати, пусто, пусто);
змінити_в_реєстрі<адреса<Назва>, адреса<Предмет>>(М, предмет_структури.методи::адреса, М.БН.С.чародія_додати, предмет_нативної_дії_тексту_чародія_додати як адреса<Предмет>);
ціль предмет_нативної_дії_тексту_чародія_містить = виділити_предмет_нативної_дії(М, М.БН.С.чародія_містить, нативна_дія_тексту_чародія_містить, пусто, пусто);
змінити_в_реєстрі<адреса<Назва>, адреса<Предмет>>(М, предмет_структури.методи::адреса, М.БН.С.чародія_містить, предмет_нативної_дії_тексту_чародія_містить як адреса<Предмет>);
вернути предмет_структури;
}
місцева дія виділити_предмет_тексту(М: адреса<Машина>, значення: текст): адреса<ПредметТексту> {
ціль предмет_тексту = виділити_предмет<ПредметТексту>(М, М.предмет_структури_текст);
предмет_тексту.значення = текст { пусто, 0 };
якщо виділити_копію_тексту_цілі(М, значення, предмет_тексту.значення::адреса) == ні {
ПОМЕРТИ(М, ю8"Не вдалося виділити копію КД");
}
вернути предмет_тексту;
}
місцева дія виділити_предмет_тексту_з_ю8(М: адреса<Машина>, значення: ю8): адреса<ПредметТексту> {
ціль предмет_тексту = виділити_предмет<ПредметТексту>(М, М.предмет_структури_текст);
якщо значення.розмір == 0 {
предмет_тексту.значення = текст { пусто, 0 };
} інакше {
змінна ціль вихід_КД = виділити<п8>(М, значення.розмір);
ціль розмір_перекодованого_виходу_КД = КД::перекодувати_з_Ю8(
значення.дані,
значення.розмір,
вихід_КД
);
якщо розмір_перекодованого_виходу_КД == 0 {
ПОМЕРТИ(М, ю8"Не вдалось перекодувати в КД");
}
предмет_тексту.значення = текст { вихід_КД, розмір_перекодованого_виходу_КД };
}
вернути предмет_тексту;
}
місцева дія звільнити_предмет_тексту(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>) {
звільнити(М, предмет_тексту.значення.дані як адреса);
звільнити(М, предмет_тексту);
}
місцева дія предмет_тексту_виконати(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати текст") як адреса<Предмет>;
}
місцева дія предмет_тексту_отримати_властивість(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, назва: адреса<Назва>): предмет_або_стан_падіння {
якщо назва == М.БН.С.довжина {
вернути виділити_предмет_числа(М, д64(предмет_тексту.значення.розмір)) як адреса<Предмет>;
}
змінна ціль тип = предмет_тексту.тип;
поки тип != пусто {
ціль елемент_реєстру_методів = отримати_з_реєстру<адреса<Назва>, адреса<Предмет>>(М, тип.методи::адреса, назва);
якщо елемент_реєстру_методів != пусто {
вернути елемент_реєстру_методів.значення;
}
тип = тип.предок;
}
вернути пусто;
}
місцева дія предмет_тексту_змінити_властивість(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, назва: адреса<Назва>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
вернути пусто;
}
місцева дія предмет_тексту_видалити_властивість(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, назва: адреса<Назва>): предмет_або_стан_падіння {
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_виконати_властивість(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, назва_властивості: адреса<Назва>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
ціль предмет_властивості = предмет_тексту_отримати_властивість(предмет_тексту, М, назва_властивості);
якщо М.стан_падіння == позитивне(так) {
вернути предмет_властивості;
}
вернути предмет_виконати(предмет_властивості, М, предмет_тексту як адреса<Предмет>, аргументи, іменовані_аргументи);
}
місцева дія предмет_тексту_отримати_елемент(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, ключ: адреса<Предмет>): предмет_або_стан_падіння {
якщо ключ == пусто {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Ключ отримання елемента з тексту має бути числом") як адреса<Предмет>;
}
якщо ключ.тип != М.предмет_структури_число {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Ключ отримання елемента з тексту має бути числом") як адреса<Предмет>;
}
ціль предмет_числа = ключ як адреса<ПредметЧисла>;
ціль позиція = позитивне(предмет_числа.значення);
якщо предмет_тексту.значення.розмір > позиція {
вернути виділити_предмет_числа(М, д64(предмет_тексту.значення.дані[позиція])) як адреса<Предмет>;
}
вернути пусто;
}
місцева дія предмет_тексту_змінити_елемент(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, ключ: адреса<Предмет>, значення: адреса<Предмет>): предмет_або_стан_падіння {
вернути пусто;
}
місцева дія предмет_тексту_видалити_елемент(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, ключ: адреса<Предмет>): предмет_або_стан_падіння {
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
дія нативна_дія_перебору_тексту_далі(предмет_нативної_дії: адреса<ПредметНативноїДії>, М: адреса<Машина>, предмет_я: адреса<Предмет>, аргументи: адреса<Накопичувач<адреса<Предмет>>>, іменовані_аргументи: адреса<Реєстр<адреса<Назва>, адреса<Предмет>>>): предмет_або_стан_падіння {
ціль предмет_тексту = предмет_отримати_властивість(предмет_я, М, М.БН.С.сп);
зберегти_предмет(М, предмет_тексту);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
вернути предмет_тексту;
}
ціль довжина_тексту = предмет_отримати_властивість(предмет_тексту, М, М.БН.С.довжина);
зберегти_предмет(М, довжина_тексту);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути довжина_тексту;
}
змінна ціль предмет_позиції = предмет_отримати_властивість(предмет_я, М, М.БН.С.позиція);
зберегти_предмет(М, предмет_позиції);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути предмет_позиції;
}
ціль чи_позиція_менше = предмет_менше(предмет_позиції, М, довжина_тексту);
зберегти_предмет(М, чи_позиція_менше);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути чи_позиція_менше;
}
якщо чи_позиція_менше == М.предмет_логічного_так як адреса<Предмет> {
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути предмет_позиції;
}
ціль елемент_тексту = предмет_отримати_елемент(предмет_тексту, М, предмет_позиції);
зберегти_предмет(М, чи_позиція_менше);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути елемент_тексту;
}
предмет_позиції = предмет_додати(предмет_позиції, М, виділити_предмет_числа(М, 1) як адреса<Предмет>);
зберегти_предмет(М, предмет_позиції);
ціль результат_зміни_властивості_позиції = предмет_змінити_властивість(предмет_я, М, М.БН.С.позиція, предмет_позиції);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути результат_зміни_властивості_позиції;
}
ціль результат_зміни_властивості_значення = предмет_змінити_властивість(предмет_я, М, М.БН.С.значення, елемент_тексту);
якщо М.стан_падіння == позитивне(так) {
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути результат_зміни_властивості_значення;
}
вернути М.предмет_логічного_так як адреса<Предмет>;
}
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
видалити_збережений_предмет(М);
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_отримати_перебір(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
ціль предмет_перебору = виділити_складений_предмет(М, М.предмет_структури_предмет);
ціль результат_зміни_властивості = складений_предмет_змінити_властивість(предмет_перебору, М, М.БН.С.сп, предмет_тексту як адреса<Предмет>);
якщо М.стан_падіння == позитивне(так) {
вернути результат_зміни_властивості;
}
ціль предмет_позиції = виділити_предмет_числа(М, 0);
ціль результат_зміни_властивості_позиції = складений_предмет_змінити_властивість(предмет_перебору, М, М.БН.С.позиція, предмет_позиції як адреса<Предмет>);
якщо М.стан_падіння == позитивне(так) {
вернути результат_зміни_властивості_позиції;
}
ціль предмет_нативної_дії_тексту_перебору_далі = виділити_предмет_нативної_дії(М, М.БН.С.далі, нативна_дія_перебору_тексту_далі, пусто, пусто);
ціль результат_зміни_властивості_перебору_далі = складений_предмет_змінити_властивість(предмет_перебору, М, М.БН.С.далі, предмет_нативної_дії_тексту_перебору_далі як адреса<Предмет>);
якщо М.стан_падіння == позитивне(так) {
вернути результат_зміни_властивості_перебору_далі;
}
вернути предмет_перебору як адреса<Предмет>;
}
місцева дія предмет_тексту_додати(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
якщо аргумент == пусто {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо додати пусто до тексту") як адреса<Предмет>;
}
якщо аргумент.тип != М.предмет_структури_текст {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"До тексту можна додати лише текст") як адреса<Предмет>;
}
ціль предмет_тексту_аргумента = аргумент як адреса<ПредметТексту>;
ціль розмір_значення_1 = предмет_тексту.значення.розмір;
ціль розмір_значення_2 = предмет_тексту_аргумента.значення.розмір;
ціль новий_розмір = розмір_значення_1 + розмір_значення_2;
ціль нове_значення = виділити<п8>(М, новий_розмір + 1);
змінна ціль позиція: позитивне = 0;
поки позиція < розмір_значення_1 {
нове_значення[позиція] = предмет_тексту.значення.дані[позиція];
позиція += 1;
}
позиція = 0;
поки позиція < розмір_значення_2 {
нове_значення[розмір_значення_1 + позиція] = предмет_тексту_аргумента.значення.дані[позиція];
позиція += 1;
}
нове_значення[новий_розмір] = 0;
ціль новий_предмет_тексту = виділити_предмет_тексту(М, текст { нове_значення, новий_розмір });
звільнити(М, нове_значення як адреса);
вернути новий_предмет_тексту як адреса<Предмет>;
}
місцева дія предмет_тексту_відняти(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати віднімання для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_помножити(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати множення для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_поділити(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати ділення для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_отримати_остачу_ділення(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати отримання остачі ділення для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_отримати_частку_ділення(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати отримання частки ділення для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_піднести_до_степеня(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати піднесення до степеня для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_зсунути_вліво(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати зсув вліво для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_зсунути_вправо(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати зсув вправо для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_зсунути_вправо_зі_заповненням(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати зсув вправо зі заповненням для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_двійкове_і(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати двійкове І для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_двійкове_або(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати двійкове АБО для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_двійкове_виключне_або(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати двійкове ВИКЛЮЧНЕ АБО для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_двійкове_не(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати двійкове НЕ для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_більше(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати перевірку на більшість для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_менше(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати перевірку на меншість для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_рівно(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
якщо перевірити_чи_предмет_тексту_рівно(предмет_тексту, М, аргумент) {
вернути М.предмет_логічного_так як адреса<Предмет>;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_містить(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
якщо аргумент == пусто {
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
якщо аргумент.тип == М.предмет_структури_число {
ціль предмет_числа_аргумента = аргумент як адреса<ПредметЧисла>;
ціль символ = п8(предмет_числа_аргумента.значення);
змінна ціль позиція: позитивне = 0;
поки позиція < предмет_тексту.значення.розмір {
якщо предмет_тексту.значення.дані[позиція] == символ {
вернути М.предмет_логічного_так як адреса<Предмет>;
}
позиція += 1;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
якщо аргумент.тип == М.предмет_структури_текст {
змінна ціль предмет_тексту_аргумента = аргумент як адреса<ПредметТексту>;
якщо предмет_тексту.значення.розмір == 0 {
якщо предмет_тексту_аргумента.значення.розмір == 0 {
вернути М.предмет_логічного_так як адреса<Предмет>;
}
}
змінна ціль позиція: позитивне = 0;
поки позиція < предмет_тексту.значення.розмір {
змінна ціль позиція_аргумента: позитивне = 0;
поки позиція_аргумента < предмет_тексту_аргумента.значення.розмір {
якщо предмет_тексту.значення.дані[позиція + позиція_аргумента] != предмет_тексту_аргумента.значення.дані[позиція_аргумента] {
стрибнути далі;
}
позиція_аргумента += 1;
}
вернути М.предмет_логічного_так як адреса<Предмет>;
далі:
позиція += 1;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_є(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): предмет_або_стан_падіння {
якщо аргумент == пусто {
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
якщо аргумент.тип != М.предмет_структури_Структура {
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
якщо перевірити_чи_предмет_тексту_є(предмет_тексту, М, аргумент як адреса<ПредметСтруктури>) {
вернути М.предмет_логічного_так як адреса<Предмет>;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_відʼємне(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати відʼємне для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_числове(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати числове для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_заперечити(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
якщо предмет_тексту.значення.розмір == 0 {
вернути М.предмет_логічного_так як адреса<Предмет>;
}
вернути М.предмет_логічного_ні як адреса<Предмет>;
}
місцева дія предмет_тексту_збільшити(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати збільшення для тексту") як адреса<Предмет>;
}
місцева дія предмет_тексту_зменшити(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>): предмет_або_стан_падіння {
увімкнути_стан_падіння(М, пусто);
вернути виділити_предмет_тексту_з_ю8(М, ю8"Неможливо виконати зменшення для тексту") як адреса<Предмет>;
}
місцева дія перевірити_чи_предмет_тексту_рівно(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, аргумент: адреса<Предмет>): логічне {
ціль предмет = предмет_тексту як адреса<Предмет>;
якщо предмет == аргумент {
вернути так;
}
якщо аргумент == пусто {
вернути ні;
}
якщо аргумент.тип != М.предмет_структури_текст {
вернути ні;
}
ціль предмет_тексту_аргумента = аргумент як адреса<ПредметТексту>;
якщо перевірити_чи_тексти_рівні(предмет_тексту.значення, предмет_тексту_аргумента.значення) {
вернути так;
}
вернути ні;
}
місцева дія перевірити_чи_предмет_тексту_є(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, предмет_структури: адреса<ПредметСтруктури>): логічне {
якщо предмет_структури == М.предмет_структури_текст {
вернути так;
}
вернути ні;
}
місцева дія надрукувати_предмет_тексту_в_накопичувач_ю8(предмет_тексту: адреса<ПредметТексту>, М: адреса<Машина>, накопичувач_ю8: адреса<НакопичувачЮ8>, глибина: позитивне) {
якщо глибина > 0 {
покласти_ю8_в_накопичувач_ю8(М, накопичувач_ю8, ю8"\"");
}
ціль розмір_значення_КД = предмет_тексту.значення.розмір;
ціль значення_ю8 = виділити<п8>(М, розмір_значення_КД * 3 + 1);
ціль розмір_перекодованого_в_Ю8 = КД::перекодувати_в_Ю8(предмет_тексту.значення.дані, позитивне(розмір_значення_КД), значення_ю8);
значення_ю8[розмір_перекодованого_в_Ю8] = 0;
якщо розмір_перекодованого_в_Ю8 == 0 {
надрукувати_Ю8(М, ю8"!!! Щось пішло не так під час отримання Ю8 з тексту!");
} інакше {
покласти_ю8_в_накопичувач_ю8(М, накопичувач_ю8, ю8 { значення_ю8, МаМа::порахувати_розмір_Ю8(значення_ю8) });
}
звільнити(М, значення_ю8 як адреса);
якщо глибина > 0 {
покласти_ю8_в_накопичувач_ю8(М, накопичувач_ю8, ю8"\"");
}
}
}