about summary refs log tree commit diff stats
path: root/subx
diff options
context:
space:
mode:
Diffstat (limited to 'subx')
-rw-r--r--subx/035labels.cc12
-rw-r--r--subx/036global_variables.cc14
2 files changed, 26 insertions, 0 deletions
diff --git a/subx/035labels.cc b/subx/035labels.cc
index acbb2206..5531910a 100644
--- a/subx/035labels.cc
+++ b/subx/035labels.cc
@@ -125,6 +125,10 @@ void compute_byte_indices_for_labels(const segment& code, map<string, int32_t>&
           raise << "'" << to_string(inst) << "': labels can only be the first word in a line.\n" << end();
         if (Map_file.is_open())
           Map_file << "0x" << HEXWORD << (code.start + current_byte) << ' ' << label << '\n';
+        if (contains_key(byte_index, label)) {
+          raise << "duplicate label '" << label << "'\n" << end();
+          return;
+        }
         put(byte_index, label, current_byte);
         trace(99, "transform") << "label '" << label << "' is at address " << (current_byte+code.start) << end();
         // no modifying current_byte; label definitions won't be in the final binary
@@ -237,6 +241,14 @@ loop:
 # second jump is to 0 (fall through)
 +transform: instruction after transform: 'eb 00'
 
+:(scenario duplicate_label)
+% Hide_errors = true;
+== 0x1
+loop:
+loop:
+    05  0x0d0c0b0a/imm32
++error: duplicate label 'loop'
+
 :(scenario label_too_short)
 % Hide_errors = true;
 == 0x1
diff --git a/subx/036global_variables.cc b/subx/036global_variables.cc
index afeb7427..5c707bd3 100644
--- a/subx/036global_variables.cc
+++ b/subx/036global_variables.cc
@@ -49,6 +49,10 @@ void compute_addresses_for_global_variables(const segment& s, map<string, uint32
           raise << "'" << to_string(inst) << "': global variable names can only be the first word in a line.\n" << end();
         if (Map_file.is_open())
           Map_file << "0x" << HEXWORD << current_address << ' ' << variable << '\n';
+        if (contains_key(address, variable)) {
+          raise << "duplicate global '" << variable << "'\n" << end();
+          return;
+        }
         put(address, variable, current_address);
         trace(99, "transform") << "global variable '" << variable << "' is at address 0x" << HEXWORD << current_address << end();
         // no modifying current_address; global variable definitions won't be in the final binary
@@ -188,6 +192,16 @@ y:
 +load: 0x0a000003 -> 0a
 $error: 0
 
+:(scenario duplicate_global_variable)
+% Hide_errors = true;
+== 0x1
+40/increment-EAX
+== 0x0a000000
+x:
+x:
+  00
++error: duplicate global 'x'
+
 :(scenario disp32_data_with_modrm)
 == code
 8b/copy 0/mod/indirect 5/rm32/.disp32 2/r32/EDX x/disp32
it.com> 2010-01-05 03:00:46 +0100 committer hut <hut@lavabit.com> 2010-01-05 03:00:46 +0100 help: implemented help framework, started writing' href='/akspecs/ranger/commit/TODO?h=v1.9.0b2&id=4b826595915c221f12a4ebe187e990cc7a08f7f2'>4b826595 ^
757e1f55 ^
277ecc9e ^
9983328c ^
33cb688a ^
a1274aba ^
b42eb058 ^
b13518af ^
316ff5a9 ^
fc486c60 ^
b4934e42 ^
2c1d2db0 ^
291ca616 ^
50845f37 ^
039c03ef ^
af6658b3 ^
efe2d7a3 ^
f0df3fa5 ^
a986e2bd ^

3fe38754 ^

6a8d5d23 ^
aad61455 ^
7a268c8b ^

efdc7b16 ^
636f69d3 ^
d3c262a9 ^
cf8b174e ^
e02d47ed ^
48a8eab5 ^
32f93303 ^
4be8b401 ^



d955e3f0 ^
75013dc7 ^
67bb838c ^
a808a661 ^
bba8d293 ^
2a64495f ^
5e449699 ^
8895b130 ^

7b04e507 ^
87db0130 ^
dd4a4145 ^
8f2f1767 ^
db1721dd ^
aea5cf92 ^
b624bd94 ^
6406bf0a ^
6099d9a3 ^
9207e83c ^
f7db061b ^
6099d9a3 ^
5a8b6059 ^
c1a9373c ^
6f43de0a ^




fca1fc4f ^
f70ee6b2 ^
0db4c9b2 ^
b2d63ef5 ^
6908d0cc ^
d994d0d6 ^
01c89bb5 ^
c776804d ^
dab4db44 ^
cc4210ff ^
34c131ef ^
32f93303 ^
c1a9373c ^
66c5bb93 ^
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