summary refs log tree commit diff stats
path: root/compiler/nim.cfg
Commit message (Expand)AuthorAgeFilesLines
* IC: bugfixes (WIP) (#16836)Andreas Rumpf2021-02-021-3/+1
* remove nim.cfg file change lefover [backport:1.2] (#15469)Andreas Rumpf2020-10-021-6/+0
* closureiters: fixes #15243 (#15454) [backport:1.2]Andreas Rumpf2020-10-021-0/+7
* init checks and 'out' parameters (#14521)Andreas Rumpf2020-06-231-0/+4
* Only print the link command when listCmd is active; fix docs (#13603)Clyybber2020-03-071-1/+0
* make case-object transitions explicit, make unknownLineInfo a const, replace ...Jasper Jenkins2020-01-171-5/+0
* more arc features (#13098)Andreas Rumpf2020-01-101-0/+1
* ic: update to serialize paddingAtEndAraq2019-09-051-1/+1
* disable IC and the SQLite dependency for version 1Andreas Rumpf2019-09-031-0/+2
* makes devel green againAndreas Rumpf2019-07-141-1/+3
* makes --styleCheck:error the default for the Nim compiler itselfAraq2019-07-141-0/+2
* disable the new CaseTransition warning for the Nim compiler itselfAraq2019-06-031-0/+4
* fixes #1286; object case transitions are now soundAndreas Rumpf2019-05-271-0/+1
* compiler/nim.cfg: cleanup --pathAraq2018-09-211-2/+0
* disable -d:nimIncremental for develAraq2018-06-111-1/+1
* incremental compilation subsystem compiles againAndreas Rumpf2018-05-301-0/+1
* compiler API: final cleanups; improve security by diabling 'gorge' and friendsAndreas Rumpf2018-05-291-1/+1
* Remove docgen.nim's dependency on things being in pathSamadi van Koten2016-11-281-2/+0
* changed the compiler's path handling; fixes #546Andreas Rumpf2016-05-311-1/+1
* preparations for Nimble NimScript integrations; minor cleanupsAraq2015-08-181-1/+0
* Rename compiler configuration file to fix "nim check" within the repoZahary Karadjov2015-08-031-0/+21
3fb0136778b80f7f64e16ae37cf8d22907'>69f04c3f ^
8dacba82 ^
2199940a ^
db5c9550 ^
8dacba82 ^




























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

                                                    




                                     
                               



                                         
                   
                             
                   
                             
 

                                             

                                        






                                                                           
                            



                                                                                           
                                                                             




                                                                    
 
                                                                                   
                             




























                                          
//: Calls can also generate products, using 'reply'.

:(scenario "reply")
recipe main [
  3:integer, 4:integer <- f 2:literal
]
recipe f [
  12:integer <- next-ingredient
  13:integer <- add 1:literal, 12:integer
  reply 12:integer, 13:integer
]
+run: instruction main/0
+run: result 0 is 2
+mem: storing 2 in location 3
+run: result 1 is 3
+mem: storing 3 in location 4

:(before "End Primitive Recipe Declarations")
REPLY,
:(before "End Primitive Recipe Numbers")
Recipe_number["reply"] = REPLY;
:(before "End Primitive Recipe Implementations")
case REPLY: {
  vector<vector<int> > callee_results;
  for (size_t i = 0; i < instructions[pc].ingredients.size(); ++i) {
    callee_results.push_back(read_memory(instructions[pc].ingredients[i]));
  }
  rr.calls.pop();
  assert(!rr.calls.empty());
  size_t& caller_pc = rr.calls.top().pc;
  instruction& caller_instruction = Recipe[rr.calls.top().running_recipe].steps[caller_pc];
  assert(caller_instruction.products.size() <= callee_results.size());
  for (size_t i = 0; i < caller_instruction.products.size(); ++i) {
    trace("run") << "result " << i << " is " << to_string(callee_results[i]);
    write_memory(caller_instruction.products[i], callee_results[i]);
  }
  ++caller_pc;
  break;
}

//: Products can include containers and exclusive containers, addresses and arrays.
:(scenario "reply_container")
recipe main [
  3:point <- f 2:literal
]
recipe f [
  12:integer <- next-ingredient
  13:integer <- copy 35:literal
  reply 12:point
]
+run: instruction main/0
+run: result 0 is [2, 35]
+mem: storing 2 in location 3
+mem: storing 35 in location 4

:(code)
string to_string(const vector<int>& in) {
  if (in.empty()) return "[]";
  ostringstream out;
  if (in.size() == 1) {
    out << in[0];
    return out.str();
  }
  out << "[";
  for (size_t i = 0; i < in.size(); ++i) {
    if (i > 0) out << ", ";
    out << in[i];
  }
  out << "]";
  return out.str();
}