Coverage Report

Created: 2026-04-12 06:15

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 = 1978; /* Year of the Revised Report for revised language.  */
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
    case DW_LANG_Erlang:
319
0
      *lname = DW_LNAME_Erlang;
320
0
      *lversion = 0;
321
0
      return 0;
322
0
    case DW_LANG_Elixir:
323
0
      *lname = DW_LNAME_Elixir;
324
0
      *lversion = 0;
325
0
      return 0;
326
0
    case DW_LANG_Gleam:
327
0
      *lname = DW_LNAME_Gleam;
328
0
      *lversion = 0;
329
0
      return 0;
330
0
    default:
331
0
      __libdw_seterrno (DWARF_E_UNKNOWN_LANGUAGE);
332
0
      return -1;
333
0
    }
334
0
}
335
336
static int
337
language_to_srclang (Dwarf_Word lname, Dwarf_Word lversion, Dwarf_Word *value)
338
0
{
339
0
  switch (lname)
340
0
    {
341
0
    case DW_LNAME_Ada:
342
0
      if (lversion <= 1983)
343
0
  *value = DW_LANG_Ada83;
344
0
      else if (lversion <= 1995)
345
0
  *value = DW_LANG_Ada95;
346
0
      else if (lversion <= 2005)
347
0
  *value = DW_LANG_Ada2005;
348
0
      else
349
0
  *value = DW_LANG_Ada2012;
350
0
      return 0;
351
0
    case DW_LNAME_BLISS:
352
0
      *value = DW_LANG_BLISS;
353
0
      return 0;
354
0
    case DW_LNAME_C:
355
0
      if (lversion == 0)
356
0
  *value = DW_LANG_C;
357
0
      else if (lversion <= 198912)
358
0
  *value = DW_LANG_C89;
359
0
      else if (lversion <= 199901)
360
0
  *value = DW_LANG_C99;
361
0
      else if (lversion <= 201112)
362
0
  *value = DW_LANG_C11;
363
0
      else if (lversion <= 201710)
364
0
  *value = DW_LANG_C17;
365
0
      else
366
0
  *value = DW_LANG_C23;
367
0
      return 0;
368
0
    case DW_LNAME_C_plus_plus:
369
0
      if (lversion <= 199711)
370
0
  *value = DW_LANG_C_plus_plus;
371
0
      else if (lversion <= 201103)
372
0
  *value = DW_LANG_C_plus_plus_11;
373
0
      else if (lversion <= 201402)
374
0
  *value = DW_LANG_C_plus_plus_14;
375
0
      else if (lversion <= 201703)
376
0
  *value = DW_LANG_C_plus_plus_17;
377
0
      else if (lversion <= 202002)
378
0
  *value = DW_LANG_C_plus_plus_20;
379
0
      else
380
0
  *value = DW_LANG_C_plus_plus_23;
381
0
      return 0;
382
0
    case DW_LNAME_Cobol:
383
0
      if (lversion <= 1974)
384
0
  *value = DW_LANG_Cobol74;
385
0
      else
386
0
  *value = DW_LANG_Cobol85;
387
0
      return 0;
388
0
    case DW_LNAME_Crystal:
389
0
      *value = DW_LANG_Crystal;
390
0
      return 0;
391
0
    case DW_LNAME_D:
392
0
      *value = DW_LANG_D;
393
0
      return 0;
394
0
    case DW_LNAME_Dylan:
395
0
      *value = DW_LANG_Dylan;
396
0
      return 0;
397
0
    case DW_LNAME_Fortran:
398
0
      if (lversion <= 1977)
399
0
  *value = DW_LANG_Fortran77;
400
0
      else if (lversion <= 1990)
401
0
  *value = DW_LANG_Fortran90;
402
0
      else if (lversion <= 1995)
403
0
  *value = DW_LANG_Fortran95;
404
0
      else if (lversion <= 2003)
405
0
  *value = DW_LANG_Fortran03;
406
0
      else if (lversion <= 2008)
407
0
  *value = DW_LANG_Fortran08;
408
0
      else if (lversion <= 2018)
409
0
  *value = DW_LANG_Fortran18;
410
0
      else
411
0
  *value = DW_LANG_Fortran23;
412
0
      return 0;
413
0
    case DW_LNAME_Go:
414
0
      *value = DW_LANG_Go;
415
0
      return 0;
416
0
    case DW_LNAME_Haskell:
417
0
      *value = DW_LANG_Haskell;
418
0
      return 0;
419
0
    case DW_LNAME_Java:
420
0
      *value = DW_LANG_Java;
421
0
      return 0;
422
0
    case DW_LNAME_Julia:
423
0
      *value = DW_LANG_Julia;
424
0
      return 0;
425
0
    case DW_LNAME_Kotlin:
426
0
      *value = DW_LANG_Kotlin;
427
0
      return 0;
428
0
    case DW_LNAME_Modula2:
429
0
      *value = DW_LANG_Modula2;
430
0
      return 0;
431
0
    case DW_LNAME_Modula3:
432
0
      *value = DW_LANG_Modula3;
433
0
      return 0;
434
0
    case DW_LNAME_ObjC:
435
0
      *value = DW_LANG_ObjC;
436
0
      return 0;
437
0
    case DW_LNAME_ObjC_plus_plus:
438
0
      *value = DW_LANG_ObjC_plus_plus;
439
0
      return 0;
440
0
    case DW_LNAME_OCaml:
441
0
      *value = DW_LANG_OCaml;
442
0
      return 0;
443
0
    case DW_LNAME_OpenCL_C:
444
0
      *value = DW_LANG_OpenCL;
445
0
      return 0;
446
0
    case DW_LNAME_Pascal:
447
0
      *value = DW_LANG_Pascal83;
448
0
      return 0;
449
0
    case DW_LNAME_PLI:
450
0
      *value = DW_LANG_PLI;
451
0
      return 0;
452
0
    case DW_LNAME_Python:
453
0
      *value = DW_LANG_Python;
454
0
      return 0;
455
0
    case DW_LNAME_RenderScript:
456
0
      *value = DW_LANG_RenderScript;
457
0
      return 0;
458
0
    case DW_LNAME_Rust:
459
0
      *value = DW_LANG_Rust;
460
0
      return 0;
461
0
    case DW_LNAME_Swift:
462
0
      *value = DW_LANG_Swift;
463
0
      return 0;
464
0
    case DW_LNAME_UPC:
465
0
      *value = DW_LANG_UPC;
466
0
      return 0;
467
0
    case DW_LNAME_Zig:
468
0
      *value = DW_LANG_Zig;
469
0
      return 0;
470
0
    case DW_LNAME_Assembly:
471
      /* DW_LANG_Assembler is not as good for compatibility.  */
472
0
      *value = DW_LANG_Mips_Assembler;
473
0
      return 0;
474
0
    case DW_LNAME_C_sharp:
475
0
      *value = DW_LANG_C_sharp;
476
0
      return 0;
477
0
    case DW_LNAME_Mojo:
478
0
      *value = DW_LANG_Mojo;
479
0
      return 0;
480
0
    case DW_LNAME_GLSL:
481
0
      *value = DW_LANG_GLSL;
482
0
      return 0;
483
0
    case DW_LNAME_GLSL_ES:
484
0
      *value = DW_LANG_GLSL_ES;
485
0
      return 0;
486
0
    case DW_LNAME_HLSL:
487
0
      *value = DW_LANG_HLSL;
488
0
      return 0;
489
0
    case DW_LNAME_OpenCL_CPP:
490
0
      *value = DW_LANG_OpenCL_CPP;
491
0
      return 0;
492
0
    case DW_LNAME_CPP_for_OpenCL:
493
0
      *value = DW_LANG_CPP_for_OpenCL;
494
0
      return 0;
495
0
    case DW_LNAME_SYCL:
496
0
      *value = DW_LANG_SYCL;
497
0
      return 0;
498
0
    case DW_LNAME_Ruby:
499
0
      *value = DW_LANG_Ruby;
500
0
      return 0;
501
0
    case DW_LNAME_Move:
502
0
      *value = DW_LANG_Move;
503
0
      return 0;
504
0
    case DW_LNAME_Hylo:
505
0
      *value = DW_LANG_Hylo;
506
0
      return 0;
507
0
    case DW_LNAME_HIP:
508
0
      *value = DW_LANG_HIP;
509
0
      return 0;
510
0
    case DW_LNAME_Odin:
511
0
      *value = DW_LANG_Odin;
512
0
      return 0;
513
0
    case DW_LNAME_P4:
514
0
      *value = DW_LANG_P4;
515
0
      return 0;
516
0
    case DW_LNAME_Metal:
517
0
      *value = DW_LANG_Metal;
518
0
      return 0;
519
0
    case DW_LNAME_V:
520
0
      *value = DW_LANG_V;
521
0
      return 0;
522
0
    case DW_LNAME_Algol68:
523
0
      *value = DW_LANG_Algol68;
524
0
      return 0;
525
0
    case DW_LNAME_Nim:
526
0
      *value = DW_LANG_Nim;
527
0
      return 0;
528
0
    case DW_LNAME_Erlang:
529
0
      *value = DW_LANG_Erlang;
530
0
      return 0;
531
0
    case DW_LNAME_Elixir:
532
0
      *value = DW_LANG_Elixir;
533
0
      return 0;
534
0
    case DW_LNAME_Gleam:
535
0
      *value = DW_LANG_Gleam;
536
0
      return 0;
537
0
    default:
538
0
      __libdw_seterrno (DWARF_E_UNKNOWN_LANGUAGE);
539
0
      return -1;
540
0
    }
541
0
}
542
543
NEW_VERSION (dwarf_srclang, ELFUTILS_0.143)
544
int
545
dwarf_srclang (Dwarf_Die *die)
546
0
{
547
0
  Dwarf_Attribute attr_mem;
548
0
  Dwarf_Word value;
549
550
0
  int res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
551
0
             (die, DW_AT_language, &attr_mem),
552
0
             &value) == 0 ? (int) value : -1;
553
0
  if (res == -1)
554
0
    {
555
0
      res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
556
0
             (die, DW_AT_language_name, &attr_mem),
557
0
             &value);
558
0
      if (res == 0)
559
0
  {
560
0
    Dwarf_Word lname = value;
561
0
    Dwarf_Word lversion;
562
0
    res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
563
0
           (die, DW_AT_language_version,
564
0
            &attr_mem), &value);
565
0
    lversion = (res == 0) ? value : 0;
566
0
    res = language_to_srclang (lname, lversion, &value);
567
0
    if (res == 0)
568
0
      res = (int) value;
569
0
  }
570
0
    }
571
572
0
  return res;
573
0
}
574
NEW_INTDEF (dwarf_srclang)
575
OLD_VERSION (dwarf_srclang, ELFUTILS_0.122)
576
577
int
578
dwarf_language (Dwarf_Die *cudie, Dwarf_Word *lname, Dwarf_Word *lversion)
579
0
{
580
0
  Dwarf_Attribute attr;
581
0
  Dwarf_Word val;
582
583
0
  int res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
584
0
             (cudie, DW_AT_language_name, &attr),
585
0
             &val);
586
0
  if (res == 0)
587
0
    {
588
0
      *lname = val;
589
0
      if (lversion != NULL)
590
0
  {
591
    /* We like to get the version, but given we already have the
592
       lang, we will ignore errors here and just return zero as
593
       version.  */
594
0
    res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
595
0
           (cudie, DW_AT_language_version,
596
0
            &attr), &val);
597
0
    *lversion = (res == 0) ? val : 0;
598
0
  }
599
0
    }
600
0
  else
601
0
    {
602
      /* Try the get the old style pre DWARF6 DW_AT_LANG and translate
603
   that to the new language name/version style.  */
604
0
      res = INTUSE(dwarf_formudata) (INTUSE(dwarf_attr_integrate)
605
0
             (cudie, DW_AT_language, &attr), &val);
606
0
      if (res == 0)
607
0
  {
608
0
    Dwarf_Word version;
609
0
    res = srclang_to_language (val, lname, (lversion == NULL
610
0
              ? &version : lversion));
611
0
  }
612
0
    }
613
614
0
  return res;
615
0
}
616
INTDEF (dwarf_language)
617
618
#ifdef MAIN_CHECK
619
#include "known-dwarf.h"
620
#include <inttypes.h>
621
#include <stdio.h>
622
623
void
624
test_lang (const char *name, Dwarf_Word lang)
625
{
626
  printf ("Testing %s: 0x%" PRIx64 "\n", name, lang);
627
628
  Dwarf_Word lname;
629
  Dwarf_Word lversion;
630
  int res = srclang_to_language (lang, &lname, &lversion);
631
  if (res != 0)
632
    {
633
      printf ("srclang_to_language failed (%d) for %s\n", res, name);
634
      exit (-1);
635
    }
636
637
  Dwarf_Word rlang;
638
  res = language_to_srclang (lname, lversion, &rlang);
639
  if (res != 0)
640
    {
641
      printf ("language_to_srclang (%" PRId64 ", %" PRId64 ") failed (%d)\n",
642
        lname, lversion, res);
643
      exit (-1);
644
    }
645
646
  /* Most langs should roundtrip, but there are some exceptions.  */
647
  switch (lang)
648
    {
649
    case DW_LANG_Assembly:
650
      if (rlang != DW_LANG_Mips_Assembler)
651
  {
652
    printf ("For compatibility Assembly should go to Mips_Assembler\n");
653
    exit (-1);
654
  }
655
      break;
656
    case DW_LANG_C_plus_plus_03:
657
      if (rlang != DW_LANG_C_plus_plus)
658
  {
659
    printf ("For c++03 doesn't exist it is just c++\n");
660
    exit (-1);
661
  }
662
      break;
663
    default:
664
      if (lang != rlang)
665
  {
666
    printf ("going from srclang to lang and back gives different name "
667
      "for %s (%" PRId64 " != %" PRId64 ")\n", name, lang, rlang);
668
    exit (-1);
669
  }
670
    }
671
}
672
673
int
674
main (void)
675
{
676
  /* Test all known language codes.  */
677
#define DWARF_ONE_KNOWN_DW_LANG(NAME, CODE) test_lang (#NAME, CODE);
678
  DWARF_ALL_KNOWN_DW_LANG
679
#undef DWARF_ONE_KNOWN_DW_LANG
680
  return 0;
681
}
682
#endif