-
Notifications
You must be signed in to change notification settings - Fork 6
/
block.c
89 lines (70 loc) · 2.79 KB
/
block.c
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
/* C Code Generator
*
* Copyright (C) 2016, Antoine Balestrat <[email protected]>
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom
* the Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*/
#include "ccg.h"
/* `nesting' is the nesting level of the block. func(){0 {1} {1 {2}}} */
Block *makeBlock(Context *context, unsigned nesting)
{
size_t i, numlocalvars, numstatements;
Block *ret = xmalloc(sizeof(*ret));
Context *bcontext = xmalloc(sizeof(*bcontext));
bcontext->currfunc = context->currfunc;
bcontext->nvars = context->nvars;
bcontext->nintegers = context->nintegers;
bcontext->scope = NULL;
copyVariableList(context->scope, &bcontext->scope);
ret->localvars = NULL, ret->statementlist = NULL;
numlocalvars = rand() % cmdline.max_localvars + !nesting;
for(i = 0; i < numlocalvars; ++i)
{
Variable *tmp = makeVariable(bcontext, _randomvartype);
bcontext->nvars++;
if(tmp->type == _integer)
bcontext->nintegers++;
addVariableToList(tmp, &(ret->localvars));
addVariableToList(tmp, &bcontext->scope);
}
if(nesting < cmdline.max_block_nesting)
{
numstatements = cmdline.min_statements_per_block +
(rand() % (cmdline.max_statements_per_block - cmdline.min_statements_per_block));
for(i = 0; i < numstatements; ++i)
{
Statement *tmp = makeStatement(bcontext, nesting, !(numstatements - 1 - i));
addStatementToList(tmp, &ret->statementlist);
}
}
freeVariableList(bcontext->scope);
free(bcontext);
return ret;
}
void printBlock(Block *block)
{
VariableList *v;
StatementList *s;
puts("{");
foreach(v, block->localvars)
printVariableDecl(v->variable);
foreach(s, block->statementlist)
printStatement(s->statement);
puts("}");
}