Skip to content

Commit

Permalink
Merge branch 'mtn-translate-c-enum-vals'
Browse files Browse the repository at this point in the history
This reintroduces b8ce8f2.
(reverting dd4b13a)

Now with correct author information. Apologies to kristopher tate
and Michael Noronha.
  • Loading branch information
andrewrk committed Aug 21, 2018
2 parents dd4b13a + b023db2 commit 937b822
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 2 deletions.
10 changes: 8 additions & 2 deletions src/translate_c.cpp
Expand Up @@ -458,9 +458,15 @@ static const char *decl_name(const Decl *decl) {
static AstNode *trans_create_node_apint(Context *c, const llvm::APSInt &aps_int) {
AstNode *node = trans_create_node(c, NodeTypeIntLiteral);
node->data.int_literal.bigint = allocate<BigInt>(1);
bigint_init_data(node->data.int_literal.bigint, aps_int.getRawData(), aps_int.getNumWords(), aps_int.isNegative());
bool is_negative = aps_int.isNegative();
// ACHTUNG: llvm::APSInt stores an int's sign inside of its getRawData;
// Internally to Zig we store an integer's sign outside of getRawData!
// ++(~aps_int) calls .flip() internally on the raw data to match Zig.
bigint_init_data( node->data.int_literal.bigint
, (is_negative ? (++(~aps_int)) : aps_int).getRawData()
, aps_int.getNumWords()
, is_negative );
return node;

}

static const Type *qual_type_canon(QualType qt) {
Expand Down
54 changes: 54 additions & 0 deletions test/translate_c.zig
Expand Up @@ -1358,4 +1358,58 @@ pub fn addCases(cases: *tests.TranslateCContext) void {
\\ }
\\}
);

cases.add("correctly translate enum init values",
\\enum EnumWithInits {
\\ VAL01 = 0,
\\ VAL02 = 1,
\\ VAL03 = 2,
\\ VAL04 = 3,
\\ VAL05 = -1,
\\ VAL06 = -2,
\\ VAL07 = -3,
\\ VAL08 = -4,
\\ VAL09 = VAL02 + VAL08,
\\ VAL10 = -1000012000,
\\ VAL11 = -1000161000,
\\ VAL12 = -1000174001,
\\ VAL13 = VAL09,
\\ VAL14 = VAL10,
\\ VAL15 = VAL11,
\\ VAL16 = VAL13,
\\ VAL17 = (VAL16 - VAL10 + 1),
\\ VAL18 = 0x1000000000000000L,
\\ VAL19 = VAL18 + VAL18 + VAL18 - 1,
\\ VAL20 = VAL19 + VAL19,
\\ VAL21 = VAL20 + 0xFFFFFFFFFFFFFFFF,
\\ VAL22 = 0xFFFFFFFFFFFFFFFF + 1,
\\ VAL23 = 0xFFFFFFFFFFFFFFFF,
\\};
,
\\pub const enum_EnumWithInits = extern enum(c_longlong) {
\\ VAL01 = 0,
\\ VAL02 = 1,
\\ VAL03 = 2,
\\ VAL04 = 3,
\\ VAL05 = -1,
\\ VAL06 = -2,
\\ VAL07 = -3,
\\ VAL08 = -4,
\\ VAL09 = -3,
\\ VAL10 = -1000012000,
\\ VAL11 = -1000161000,
\\ VAL12 = -1000174001,
\\ VAL13 = -3,
\\ VAL14 = -1000012000,
\\ VAL15 = -1000161000,
\\ VAL16 = -3,
\\ VAL17 = 1000011998,
\\ VAL18 = 1152921504606846976,
\\ VAL19 = 3458764513820540927,
\\ VAL20 = 6917529027641081854,
\\ VAL21 = 6917529027641081853,
\\ VAL22 = 0,
\\ VAL23 = -1,
\\};
);
}

0 comments on commit 937b822

Please sign in to comment.