]> git.lizzy.rs Git - rust.git/commitdiff
Fix segfault when calling tuple struct constructor as extern fn
authorAndreas Martens <andreasm@fastmail.fm>
Sat, 17 Aug 2013 20:42:31 +0000 (22:42 +0200)
committerAndreas Martens <andreasm@fastmail.fm>
Sat, 17 Aug 2013 20:42:31 +0000 (22:42 +0200)
Fixes #5315

src/librustc/middle/trans/expr.rs
src/test/run-pass/tuple-struct-constructor-pointer.rs [new file with mode: 0644]

index 04fd477a317380d2eee4a560eeb9c482e0f24bca..1ec067d271f918a5e3ed322d3a5a3197a56a32ea 100644 (file)
@@ -795,14 +795,18 @@ fn trans_def_dps_unadjusted(bcx: @mut Block, ref_expr: &ast::expr,
                 return bcx;
             }
         }
-        ast::def_struct(*) => {
+        ast::def_struct(def_id) => {
             let ty = expr_ty(bcx, ref_expr);
             match ty::get(ty).sty {
                 ty::ty_struct(did, _) if ty::has_dtor(ccx.tcx, did) => {
                     let repr = adt::represent_type(ccx, ty);
                     adt::trans_start_init(bcx, repr, lldest, 0);
                 }
-                _ => {}
+                ty::ty_bare_fn(*) => {
+                    let fn_data = callee::trans_fn_ref(bcx, def_id, ref_expr.id);
+                    Store(bcx, fn_data.llfn, lldest);
+                }
+                _ => ()
             }
             return bcx;
         }
diff --git a/src/test/run-pass/tuple-struct-constructor-pointer.rs b/src/test/run-pass/tuple-struct-constructor-pointer.rs
new file mode 100644 (file)
index 0000000..ad2acc4
--- /dev/null
@@ -0,0 +1,19 @@
+// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+struct Foo(int);
+struct Bar(int, int);
+
+fn main() {
+    let f: extern fn(int) -> Foo = Foo;
+    let g: extern fn(int, int) -> Bar = Bar;
+    f(42);
+    g(4, 7);
+}