Coverage Report

Created: 2025-11-06 06:34

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/elfutils/libdw/dwarf_srclang.c
Line
Count
Source
1
/* Return source language attribute of DIE.
2
   Copyright (C) 2003-2010 Red Hat, Inc.
3
   Copyright (C) 2025 Mark J. Wielaard <mark@klomp.org>
4
   This file is part of elfutils.
5
   Written by Ulrich Drepper <drepper@redhat.com>, 2003.
6
7
   This file is free software; you can redistribute it and/or modify
8
   it under the terms of either
9
10
     * the GNU Lesser General Public License as published by the Free
11
       Software Foundation; either version 3 of the License, or (at
12
       your option) any later version
13
14
   or
15
16
     * the GNU General Public License as published by the Free
17
       Software Foundation; either version 2 of the License, or (at
18
       your option) any later version
19
20
   or both in parallel, as here.
21
22
   elfutils is distributed in the hope that it will be useful, but
23
   WITHOUT ANY WARRANTY; without even the implied warranty of
24
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25
   General Public License for more details.
26
27
   You should have received copies of the GNU General Public License and
28
   the GNU Lesser General Public License along with this program.  If
29
   not, see <http://www.gnu.org/licenses/>.  */
30
31
#ifdef HAVE_CONFIG_H
32
# include <config.h>
33
#endif
34
35
#include <dwarf.h>
36
#include "libdwP.h"
37
38
39
static int srclang_to_language (Dwarf_Word srclang,
40
        Dwarf_Word *lname,
41
        Dwarf_Word *lversion)
42
0
{
43
0
  switch (srclang)
44
0
    {
45
0
    case DW_LANG_C89:
46
0
      *lname = DW_LNAME_C;
47
0
      *lversion = 198912;
48
0
      return 0;
49
0
    case DW_LANG_C:
50
0
      *lname = DW_LNAME_C;
51
0
      *lversion = 0;
52
0
      return 0;
53
0
    case DW_LANG_Ada83:
54
0
      *lname = DW_LNAME_Ada;
55
0
      *lversion = 1983;
56
0
      return 0;
57
0
    case DW_LANG_C_plus_plus:
58
0
      *lname = DW_LNAME_C_plus_plus;
59
0
      *lversion = 199711;
60
0
      return 0;
61
0
    case DW_LANG_Cobol74:
62
0
      *lname = DW_LNAME_Cobol;
63
0
      *lversion = 1974;
64
0
      return 0;
65
0
    case DW_LANG_Cobol85:
66
0
      *lname = DW_LNAME_Cobol;
67
0
      *lversion = 1985;
68
0
      return 0;
69
0
    case DW_LANG_Fortran77:
70
0
      *lname = DW_LNAME_Fortran;
71
0
      *lversion = 1977;
72
0
      return 0;
73
0
    case DW_LANG_Fortran90:
74
0
      *lname = DW_LNAME_Fortran;
75
0
      *lversion = 1990;
76
0
      return 0;
77
0
    case DW_LANG_Pascal83:
78
0
      *lname = DW_LNAME_Pascal;
79
0
      *lversion = 1983;
80
0
      return 0;
81
0
    case DW_LANG_Modula2:
82
0
      *lname = DW_LNAME_Modula2;
83
0
      *lversion = 0;
84
0
      return 0;
85
0
    case DW_LANG_Java:
86
0
      *lname = DW_LNAME_Java;
87
0
      *lversion = 0;
88
0
      return 0;
89
0
    case DW_LANG_C99:
90
0
      *lname = DW_LNAME_C;
91
0
      *lversion = 199901;
92
0
      return 0;
93
0
    case DW_LANG_Ada95:
94
0
      *lname = DW_LNAME_Ada;
95
0
      *lversion = 1995;
96
0
      return 0;
97
0
    case DW_LANG_Fortran95:
98
0
      *lname = DW_LNAME_Fortran;
99
0
      *lversion = 1995;
100
0
      return 0;
101
0
    case DW_LANG_PLI:
102
0
      *lname = DW_LNAME_PLI;
103
0
      *lversion = 0;
104
0
      return 0;
105
0
    case DW_LANG_ObjC:
106
0
      *lname = DW_LNAME_ObjC;
107
0
      *lversion = 0;
108
0
      return 0;
109
0
    case DW_LANG_ObjC_plus_plus:
110
0
      *lname = DW_LNAME_ObjC_plus_plus;
111
0
      *lversion = 0;
112
0
      return 0;
113
0
    case DW_LANG_UPC:
114
0
      *lname = DW_LNAME_UPC;
115
0
      *lversion = 0;
116
0
      return 0;
117
0
    case DW_LANG_D:
118
0
      *lname = DW_LNAME_D;
119
0
      *lversion = 0;
120
0
      return 0;
121
0
    case DW_LANG_Dylan:
122
0
      *lname = DW_LNAME_Dylan;
123
0
      *lversion = 0;
124
0
      return 0;
125
0
    case DW_LANG_Python:
126
0
      *lname = DW_LNAME_Python;
127
0
      *lversion = 0;
128
0
      return 0;
129
0
    case DW_LANG_OpenCL:
130
0
      *lname = DW_LNAME_OpenCL_C;
131
0
      *lversion = 0;
132
0
      return 0;
133
0
    case DW_LANG_Go:
134
0
      *lname = DW_LNAME_Go;
135
0
      *lversion = 0;
136
0
      return 0;
137
0
    case DW_LANG_Modula3:
138
0
      *lname = DW_LNAME_Modula3;
139
0
      *lversion = 0;
140
0
      return 0;
141
0
    case DW_LANG_Haskell:
142
0
      *lname = DW_LNAME_Haskell;
143
0
      *lversion = 0;
144
0
      return 0;
145
0
    case DW_LANG_C_plus_plus_03:
146
0
      *lname = DW_LNAME_C_plus_plus;
147
0
      *lversion = 199711; /* This is really just c++98. */
148
0
      return 0;
149
0
    case DW_LANG_C_plus_plus_11:
150
0
      *lname = DW_LNAME_C_plus_plus;
151
0
      *lversion = 201103;
152
0
      return 0;
153
0
    case DW_LANG_OCaml:
154
0
      *lname = DW_LNAME_OCaml;
155
0
      *lversion = 0;
156
0
      return 0;
157
0
    case DW_LANG_Rust:
158
0
      *lname = DW_LNAME_Rust;
159
0
      *lversion = 0;
160
0
      return 0;
161
0
    case DW_LANG_C11:
162
0
      *lname = DW_LNAME_C;
163
0
      *lversion = 201112;
164
0
      return 0;
165
0
    case DW_LANG_Swift:
166
0
      *lname = DW_LNAME_Swift;
167
0
      *lversion = 0;
168
0
      return 0;
169
0
    case DW_LANG_Julia:
170
0
      *lname = DW_LNAME_Julia;
171
0
      *lversion = 0;
172
0
      return 0;
173
0
    case DW_LANG_C_plus_plus_14:
174
0
      *lname = DW_LNAME_C_plus_plus;
175
0
      *lversion = 201402;
176
0
      return 0;
177
0
    case DW_LANG_Fortran03:
178
0
      *lname = DW_LNAME_Fortran;
179
0
      *lversion = 2003;
180
0
      return 0;
181
0
    case DW_LANG_Fortran08:
182
0
      *lname = DW_LNAME_Fortran;
183
0
      *lversion = 2008;
184
0
      return 0;
185
0
    case DW_LANG_RenderScript:
186
0
      *lname = DW_LNAME_RenderScript;
187
0
      *lversion = 0;
188
0
      return 0;
189
0
    case DW_LANG_BLISS:
190
0
      *lname = DW_LNAME_BLISS;
191
0
      *lversion = 0;
192
0
      return 0;
193
0
    case DW_LANG_Kotlin:
194
0
      *lname = DW_LNAME_Kotlin;
195
0
      *lversion = 0;
196
0
      return 0;
197
0
    case DW_LANG_Zig:
198
0
      *lname = DW_LNAME_Zig;
199
0
      *lversion = 0;
200
0
      return 0;
201
0
    case DW_LANG_Crystal:
202
0
      *lname = DW_LNAME_Crystal;
203
0
      *lversion = 0;
204
0
      return 0;
205
0
    case DW_LANG_C_plus_plus_17:
206
0
      *lname = DW_LANG_C_plus_plus;
207
0
      *lversion = 201703;
208
0
      return 0;
209
0
    case DW_LANG_C_plus_plus_20:
210
0
      *lname = DW_LANG_C_plus_plus;
211
0
      *lversion = 202002;
212
0
      return 0;
213
0
    case DW_LANG_C17:
214
0
      *lname = DW_LNAME_C;
215
0
      *lversion = 201710;
216
0
      return 0;
217
0
    case DW_LANG_Fortran18:
218
0
      *lname = DW_LNAME_Fortran;
219
0
      *lversion = 2018;
220
0
      return 0;
221
0
    case DW_LANG_Ada2005:
222
0
      *lname = DW_LNAME_Ada;
223
0
      *lversion = 2005;
224
0
      return 0;
225
0
    case DW_LANG_Ada2012:
226
0
      *lname = DW_LNAME_Ada;
227
0
      *lversion = 2012;
228
0
      return 0;
229
0
    case DW_LANG_HIP:
230
0
      *lname = DW_LNAME_HIP;
231
0
      *lversion = 0;
232
0
      return 0;
233
0
    case DW_LANG_Assembly:
234
0
    case DW_LANG_Mips_Assembler:
235
0
      *lname = DW_LNAME_Assembly;
236
0
      *lversion = 0;
237
0
      return 0;
238
0
    case DW_LANG_C_sharp:
239
0
      *lname = DW_LNAME_C_sharp;
240
0
      *lversion = 0;
241
0
      return 0;
242
0
    case DW_LANG_Mojo:
243
0
      *lname = DW_LNAME_Mojo;
244
0
      *lversion = 0;
245
0
      return 0;
246
0
    case DW_LANG_GLSL:
247
0
      *lname = DW_LNAME_GLSL;
248
0
      *lversion = 0;
249
0
      return 0;
250
0
    case DW_LANG_GLSL_ES:
251
0
      *lname = DW_LNAME_GLSL_ES;
252
0
      *lversion = 0;
253
0
      return 0;
254
0
    case DW_LANG_HLSL:
255
0
      *lname = DW_LNAME_HLSL;
256
0
      *lversion = 0;
257
0
      return 0;
258
0
    case DW_LANG_OpenCL_CPP:
259
0
      *lname = DW_LNAME_OpenCL_CPP;
260
0
      *lversion = 0;
261
0
      return 0;
262
0
    case DW_LANG_CPP_for_OpenCL:
263
0
      *lname = DW_LNAME_CPP_for_OpenCL;
264
0
      *lversion = 0;
265
0
      return 0;
266
0
    case DW_LANG_SYCL:
267
0
      *lname = DW_LNAME_SYCL;
268
0
      *lversion = 0;
269
0
      return 0;
270
0
    case DW_LANG_C_plus_plus_23:
271
0
      *lname = DW_LNAME_C_plus_plus;
272
0
      *lversion = 202302;
273
0
      return 0;
274
0
    case DW_LANG_Odin:
275
0
      *lname = DW_LNAME_Odin;
276
0
      *lversion = 0;
277
0
      return 0;
278
0
    case DW_LANG_P4:
279
0
      *lname = DW_LNAME_P4;
280
0
      *lversion = 0;
281
0
      return 0;
282
0
    case DW_LANG_Metal:
283
0
      *lname = DW_LNAME_Metal;
284
0
      *lversion = 0;
285
0
      return 0;
286
0
    case DW_LANG_C23:
287
0
      *lname = DW_LNAME_C;
288
0
      *lversion = 202311;
289
0
      return 0;
290
0
    case DW_LANG_Fortran23:
291
0
      *lname = DW_LNAME_Fortran;
292
0
      *lversion = 2023;
293
0
      return 0;
294
0
    case DW_LANG_Ruby:
295
0
      *lname = DW_LNAME_Ruby;
296
0
      *lversion = 0;
297
0
      return 0;
298
0
    case DW_LANG_Move:
299
0
      *lname = DW_LNAME_Move;
300
0
      *lversion = 0;
301
0
      return 0;
302
0
    case DW_LANG_Hylo:
303
0
      *lname = DW_LNAME_Hylo;
304
0
      *lversion = 0;
305
0
      return 0;
306
0
    case DW_LANG_V:
307
0
      *lname = DW_LNAME_V;
308
0
      *lversion = 0;
309
0
      return 0;
310
0
    case DW_LANG_Algol68:
311
0
      *lname = DW_LNAME_Algol68;
312
0
      *lversion = 0;
313
0
      return 0;
314
0
    case DW_LANG_Nim:
315
0
      *lname = DW_LNAME_Nim;
316
0
      *lversion = 0;
317
0
      return 0;
318
0
    default:
319
0
      __libdw_seterrno (DWARF_E_UNKNOWN_LANGUAGE);
320
0
      return -1;
321
0
    }
322
0
}
323
324
static int
325
language_to_srclang (Dwarf_Word lname, Dwarf_Word lversion, Dwarf_Word *value)
326
0
{
327
0
  switch (lname)
328
0
    {
329
0
    case DW_LNAME_Ada:
330
0
      if (lversion <= 1983)
331
0
  *value = DW_LANG_Ada83;
332
0
      else if (lversion <= 1995)
333
0
  *value = DW_LANG_Ada95;
334
0
      else if (lversion <= 2005)
335
0
  *value = DW_LANG_Ada2005;
336
0
      else
337
0
  *value = DW_LANG_Ada2012;
338
0
      return 0;
339
0
    case DW_LNAME_BLISS:
340
0
      *value = DW_LANG_BLISS;
341
0
      return 0;
342
0
    case DW_LNAME_C:
343
0
      if (lversion == 0)
344
0
  *value = DW_LANG_C;
345
0
      else if (lversion <= 198912)
346
0
  *value = DW_LANG_C89;
347
0
      else if (lversion <= 199901)
348
0
  *value = DW_LANG_C99;
349
0
      else if (lversion <= 201112)
350
0
  *value = DW_LANG_C11;
351
0
      else if (lversion <= 201710)
352
0
  *value = DW_LANG_C17;
353
0
      else
354
0
  *value = DW_LANG_C23;
355
0
      return 0;
356
0
    case DW_LNAME_C_plus_plus:
357
0
      if (lversion <= 199711)
358
0
  *value = DW_LANG_C_plus_plus;
359
0
      else if (lversion <= 201103)
360
0
  *value = DW_LANG_C_plus_plus_11;
361
0
      else if (lversion <= 201402)
362
0
  *value = DW_LANG_C_plus_plus_14;
363
0
      else if (lversion <= 201703)
364
0
  *value = DW_LANG_C_plus_plus_17;
365
0
      else if (lversion <= 202002)
366
0
  *value = DW_LANG_C_plus_plus_20;
367
0
      else
368
0
  *value = DW_LANG_C_plus_plus_23;
369
0
      return 0;
370
0
    case DW_LNAME_Cobol:
371
0
      if (lversion <= 1974)
372
0
  *value = DW_LANG_Cobol74;
373
0
      else
374
0
  *value = DW_LANG_Cobol85;
375
0
      return 0;
376
0
    case DW_LNAME_Crystal:
377
0
      *value = DW_LANG_Crystal;
378
0
      return 0;
379
0
    case DW_LNAME_D:
380
0
      *value = DW_LANG_D;
381
0
      return 0;
382
0
    case DW_LNAME_Dylan:
383
0
      *value = DW_LANG_Dylan;
384
0
      return 0;
385
0
    case DW_LNAME_Fortran:
386
0
      if (lversion <= 1977)
387
0
  *value = DW_LANG_Fortran77;
388
0
      else if (lversion <= 1990)
389
0
  *value = DW_LANG_Fortran90;
390
0
      else if (lversion <= 1995)
391
0
  *value = DW_LANG_Fortran95;
392
0
      else if (lversion <= 2003)
393
0
  *value = DW_LANG_Fortran03;
394
0
      else if (lversion <= 2008)
395
0
  *value = DW_LANG_Fortran08;
396
0
      else if (lversion <= 2018)
397
0
  *value = DW_LANG_Fortran18;
398
0
      else
399
0
  *value = DW_LANG_Fortran23;
400
0
      return 0;
401
0
    case DW_LNAME_Go:
402
0
      *value = DW_LANG_Go;
403
0
      return 0;
404
0
    case DW_LNAME_Haskell:
405
0
      *value = DW_LANG_Haskell;
406
0
      return 0;
407
0
    case DW_LNAME_Java:
408
0
      *value = DW_LANG_Java;
409
0
      return 0;
410
0
    case DW_LNAME_Julia:
411
0
      *value = DW_LANG_Julia;
412
0
      return 0;
413
0
    case DW_LNAME_Kotlin:
414
0
      *value = DW_LANG_Kotlin;
415
0
      return 0;
416
0
    case DW_LNAME_Modula2:
417
0
      *value = DW_LANG_Modula2;
418
0
      return 0;
419
0
    case DW_LNAME_Modula3:
420
0
      *value = DW_LANG_Modula3;
421
0
      return 0;
422
0
    case DW_LNAME_ObjC:
423
0
      *value = DW_LANG_ObjC;
424
0
      return 0;
425
0
    case DW_LNAME_ObjC_plus_plus:
426
0
      *value = DW_LANG_ObjC_plus_plus;
427
0
      return 0;
428
0
    case DW_LNAME_OCaml:
429
0
      *value = DW_LANG_OCaml;
430
0
      return 0;
431
0
    case DW_LNAME_OpenCL_C:
432
0
      *value = DW_LANG_OpenCL;
433
0
      return 0;
434
0
    case DW_LNAME_Pascal:
435
0
      *value = DW_LANG_Pascal83;
436
0
      return 0;
437
0
    case DW_LNAME_PLI:
438
0
      *value = DW_LANG_PLI;
439
0
      return 0;
440
0
    case DW_LNAME_Python:
441
0
      *value = DW_LANG_Python;
442
0
      return 0;
443
0
    case DW_LNAME_RenderScript:
444
0
      *value = DW_LANG_RenderScript;
445
0
      return 0;
446
0
    case DW_LNAME_Rust:
447
0
      *value = DW_LANG_Rust;
448
0
      return 0;
449
0
    case DW_LNAME_Swift:
450
0
      *value = DW_LANG_Swift;
451
0
      return 0;
452
0
    case DW_LNAME_UPC:
453
0
      *value = DW_LANG_UPC;
454
0
      return 0;
455
0
    case DW_LNAME_Zig:
456
0
      *value = DW_LANG_Zig;
457
0
      return 0;
458
0
    case DW_LNAME_Assembly:
459
      /* DW_LANG_Assembler is not as good for compatibility.  */
460
0
      *value = DW_LANG_Mips_Assembler;
461
0
      return 0;
462
0
    case DW_LNAME_C_sharp:
463
0
      *value = DW_LANG_C_sharp;
464
0
      return 0;
465
0
    case DW_LNAME_Mojo:
466
0
      *value = DW_LANG_Mojo;
467
0
      return 0;
468
0
    case DW_LNAME_GLSL:
469
0
      *value = DW_LANG_GLSL;
470
0
      return 0;
471
0
    case DW_LNAME_GLSL_ES:
472
0
      *value = DW_LANG_GLSL_ES;
473
0
      return 0;
474
0
    case DW_LNAME_HLSL:
475
0
      *value = DW_LANG_HLSL;
476
0
      return 0;
477
0
    case DW_LNAME_OpenCL_CPP:
478
0
      *value = DW_LANG_OpenCL_CPP;
479
0
      return 0;
480
0
    case DW_LNAME_CPP_for_OpenCL:
481
0
      *value = DW_LANG_CPP_for_OpenCL;
482
0
      return 0;
483
0
    case DW_LNAME_SYCL:
484
0
      *value = DW_LANG_SYCL;
485
0
      return 0;
486
0
    case DW_LNAME_Ruby:
487
0
      *value = DW_LANG_Ruby;
488
0
      return 0;
489
0
    case DW_LNAME_Move:
490
0
      *value = DW_LANG_Move;
491
0
      return 0;
492
0
    case DW_LNAME_Hylo:
493
0
      *value = DW_LANG_Hylo;
494
0
      return 0;
495
0
    case DW_LNAME_HIP:
496
0
      *value = DW_LANG_HIP;
497
0
      return 0;
498
0
    case DW_LNAME_Odin:
499
0
      *value = DW_LANG_Odin;
500
0
      return 0;
501
0
    case DW_LNAME_P4:
502
0
      *value = DW_LANG_P4;
503
0
      return 0;
504
0
    case DW_LNAME_Metal:
505
0
      *value = DW_LANG_Metal;
506
0
      return 0;
507
0
    case DW_LNAME_V:
508
0
      *value = DW_LANG_V;
509
0
      return 0;
510
0
    case DW_LNAME_Algol68:
511
0
      *value = DW_LANG_Algol68;
512
0
      return 0;
513
0
    case DW_LNAME_Nim:
514
0
      *value = DW_LANG_Nim;
515
0
      return 0;
516
0
    default:
517
0
      __libdw_seterrno (DWARF_E_UNKNOWN_LANGUAGE);
518
0
      return -1;
519
0
    }
520
0
}
521
522
NEW_VERSION (dwarf_srclang, ELFUTILS_0.143)
523
int
524
dwarf_srclang (Dwarf_Die *die)
525
0
{
526
0
  Dwarf_Attribute attr_mem;
527
0
  Dwarf_Word value;
528
529
0
  int res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
530
0
             (die, DW_AT_language, &attr_mem),
531
0
             &value) == 0 ? (int) value : -1;
532
0
  if (res == -1)
533
0
    {
534
0
      res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
535
0
             (die, DW_AT_language_name, &attr_mem),
536
0
             &value);
537
0
      if (res == 0)
538
0
  {
539
0
    Dwarf_Word lname = value;
540
0
    Dwarf_Word lversion;
541
0
    res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
542
0
           (die, DW_AT_language_version,
543
0
            &attr_mem), &value);
544
0
    lversion = (res == 0) ? value : 0;
545
0
    res = language_to_srclang (lname, lversion, &value);
546
0
    if (res == 0)
547
0
      res = (int) value;
548
0
  }
549
0
    }
550
551
0
  return res;
552
0
}
553
NEW_INTDEF (dwarf_srclang)
554
OLD_VERSION (dwarf_srclang, ELFUTILS_0.122)
555
556
int
557
dwarf_language (Dwarf_Die *cudie, Dwarf_Word *lname, Dwarf_Word *lversion)
558
0
{
559
0
  Dwarf_Attribute attr;
560
0
  Dwarf_Word val;
561
562
0
  int res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
563
0
             (cudie, DW_AT_language_name, &attr),
564
0
             &val);
565
0
  if (res == 0)
566
0
    {
567
0
      *lname = val;
568
0
      if (lversion != NULL)
569
0
  {
570
    /* We like to get the version, but given we already have the
571
       lang, we will ignore errors here and just return zero as
572
       version.  */
573
0
    res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
574
0
           (cudie, DW_AT_language_version,
575
0
            &attr), &val);
576
0
    *lversion = (res == 0) ? val : 0;
577
0
  }
578
0
    }
579
0
  else
580
0
    {
581
      /* Try the get the old style pre DWARF6 DW_AT_LANG and translate
582
   that to the new language name/version style.  */
583
0
      res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
584
0
             (cudie, DW_AT_language, &attr), &val);
585
0
      if (res == 0)
586
0
  {
587
0
    Dwarf_Word version;
588
0
    res = srclang_to_language (val, lname, (lversion == NULL
589
0
              ? &version : lversion));
590
0
  }
591
0
    }
592
593
0
  return res;
594
0
}
595
INTDEF (dwarf_language)
596
597
#ifdef MAIN_CHECK
598
#include "known-dwarf.h"
599
#include <inttypes.h>
600
#include <stdio.h>
601
602
void
603
test_lang (const char *name, Dwarf_Word lang)
604
{
605
  printf ("Testing %s: 0x%" PRIx64 "\n", name, lang);
606
607
  Dwarf_Word lname;
608
  Dwarf_Word lversion;
609
  int res = srclang_to_language (lang, &lname, &lversion);
610
  if (res != 0)
611
    {
612
      printf ("srclang_to_language failed (%d) for %s\n", res, name);
613
      exit (-1);
614
    }
615
616
  Dwarf_Word rlang;
617
  res = language_to_srclang (lname, lversion, &rlang);
618
  if (res != 0)
619
    {
620
      printf ("language_to_srclang (%" PRId64 ", %" PRId64 ") failed (%d)\n",
621
        lname, lversion, res);
622
      exit (-1);
623
    }
624
625
  /* Most langs should roundtrip, but there are some exceptions.  */
626
  switch (lang)
627
    {
628
    case DW_LANG_Assembly:
629
      if (rlang != DW_LANG_Mips_Assembler)
630
  {
631
    printf ("For compatibility Assembly should go to Mips_Assembler\n");
632
    exit (-1);
633
  }
634
      break;
635
    case DW_LANG_C_plus_plus_03:
636
      if (rlang != DW_LANG_C_plus_plus)
637
  {
638
    printf ("For c++03 doesn't exist it is just c++\n");
639
    exit (-1);
640
  }
641
      break;
642
    default:
643
      if (lang != rlang)
644
  {
645
    printf ("going from srclang to lang and back gives different name "
646
      "for %s (%" PRId64 " != %" PRId64 ")\n", name, lang, rlang);
647
    exit (-1);
648
  }
649
    }
650
}
651
652
int
653
main (void)
654
{
655
  /* Test all known language codes.  */
656
#define DWARF_ONE_KNOWN_DW_LANG(NAME, CODE) test_lang (#NAME, CODE);
657
  DWARF_ALL_KNOWN_DW_LANG
658
#undef DWARF_ONE_KNOWN_DW_LANG
659
  return 0;
660
}
661
#endif