Commit Graph

316 Commits

Author SHA1 Message Date
Dmitri Hrybenko
b10105dd75 Make test DebugInfo/Errors.swift word-size independent
Swift SVN r28252
2015-05-07 04:02:30 +00:00
Dmitri Hrybenko
58601fafc8 Remove Array.count, it is redundant with protocol extensions
Swift SVN r28247
2015-05-07 00:30:41 +00:00
Dmitri Hrybenko
c109ec9125 stdlib: protocol extensions: de-underscore count()
Swift SVN r28246
2015-05-07 00:30:38 +00:00
Adrian Prantl
f18d802c19 Debug Info: Emit the error result argument.
If a function has an error result slot, emit debug info for an artificial
function argument "$error" with indirect storage that holds a pointer
to the error object address.

<rdar://problem/20736999> lldb needs to be able to locate the error return location when stepping out of a function

Swift SVN r28229
2015-05-07 00:29:40 +00:00
Adrian Prantl
301aae1492 Promote the "true"-Scope of a condition to an actual lexical scope.
<rdar://problem/20394204> Scoping of if/let declarations too broad

Swift SVN r28203
2015-05-06 16:40:11 +00:00
Manman Ren
e94aae06da [Function Attribute] add target-cpu and target-features sets if they're non-null.
All llvm::Functions created during IRGen will have target-cpu and target-features
attributes if they are non-null.

Update testing cases to expect the attribute in function definition.
Add testing case function-target-features.swift to verify target-cpu and
target-features.

rdar://20772331


Swift SVN r28186
2015-05-05 23:19:48 +00:00
Adrian Prantl
2aff7e78d7 Debug Info: Mangle the AST type instead of the SIL type for local variables
and function arguments.

<rdar://problem/20565180> Debug info should not expose ImplFunctionType

Swift SVN r28148
2015-05-05 03:50:28 +00:00
Joe Groff
2d3eba9e0d IRGen: Reuse value witness table projections.
Don't project every value witness from the metadata every time we need one; this wastes code size in a way LLVM can't really optimize since it doesn't know the metadata is immutable. The code size wins on the standard library are disappointingly small (stdlib only shrinks by 4KB), but this makes generic IR a lot more compact and easier to read.

Swift SVN r28095
2015-05-03 05:00:40 +00:00
David Farler
91c64fdbb1 Stop re-exporting the Objective-C library
and link it properly. This is needed to embed LLVM bitcode sections
in the standard library and overlays. The linker doesn't support
embedded bitcode and reexport flags (among others).

rdar://problem/20750099

Swift SVN r28052
2015-05-01 22:24:14 +00:00
Dmitri Hrybenko
8beb642dc9 Remove uses of println() from test/DebugInfo/closure-multivalue.swift
Swift SVN r28037
2015-05-01 09:34:32 +00:00
Dmitri Hrybenko
155fa0a425 Speculatively revert my change to test/DebugInfo/closure-multivalue.swift
Apparently it broke the test when the standard library is built with
debug info.

Swift SVN r28036
2015-05-01 08:47:02 +00:00
Dmitri Hrybenko
82364d6a44 tests: remove uses of println() that are not relevant to the tests
Swift SVN r28018
2015-05-01 03:56:26 +00:00
Dmitri Hrybenko
0fce5c7b4e tests: remove uses of println() that are not relevant to the tests
Swift SVN r28016
2015-05-01 03:35:50 +00:00
Adrian Prantl
fa402df22d Debug Info: Anonymous functions should only have a linkage name.
<rdar://problem/20008393> MDSubprogram has name

Swift SVN r27981
2015-04-30 16:30:15 +00:00
Doug Gregor
a815ab7386 Don't eagerly check protocol conformances for Clang-imported AST nodes.
The Clang importer introduces a number of synthesized conformances for
imported enums (normal, NS_ENUMS, or NS_OPTIONS-based all have the
same issue) that aren't used in most translation units. Rather than go
through the effort of fully checking these conformances and generating
SIL for them always, rely on semantic analysis to force them to be
fully checked when the conformance is required. This cuts down on the
amount of work we need to do for imported enumeration types
considerably. For a simple program consisting of only:

    import Foundation
    var str = NSString()

My not-entirely-scientific measurements show that:
  * Time to parse + type-check is reduced by 34%
  * Time to generate SIL is reduced by 50%
  * Time to generate IR is reduced by 47%
  * SIL output size is reduced by 66%

Fixes rdar://problem/20047340.

Swift SVN r27946
2015-04-29 23:20:54 +00:00
Duncan Exon Smith
c6d42db070 Adapt to MD* => DI* renaming of debug info types
Applied the upgrade script from r236120 (LLVM) and r236121 (CFE).  This is the
final step of rdar://problem/20434113.



Swift SVN r27925
2015-04-29 21:40:21 +00:00
Adrian Prantl
07f00c5b93 Debug info: Fix the mangling for builtin name alias types.
rdar://problem/20597521

Swift SVN r27857
2015-04-28 04:14:52 +00:00
Doug Gregor
793b3326af Implement the new rules for argument label defaults.
The rule changes are as follows:
  * All functions (introduced with the 'func' keyword) have argument
  labels for arguments beyond the first, by default. Methods are no
  longer special in this regard.
  * The presence of a default argument no longer implies an argument
  label.

The actual changes to the parser and printer are fairly simple; the
rest of the noise is updating the standard library, overlays, tests,
etc.

With the standard library, this change is intended to be API neutral:
I've added/removed #'s and _'s as appropriate to keep the user
interface the same. If we want to separately consider using argument
labels for more free functions now that the defaults in the language
have shifted, we can tackle that separately.

Fixes rdar://problem/17218256.

Swift SVN r27704
2015-04-24 19:03:30 +00:00
Adrian Prantl
56e8ae7d82 Add missing testcase for r27562.
Swift SVN r27579
2015-04-22 15:57:37 +00:00
Devin Coughlin
d08b98b1ca Sema: Turn on availability checking by default
Enable checking for uses of potentially unavailable APIs. There is
a frontend option to disable it: -disable-availability-checking.

This commit updates the SDK overlays with @availability() annotations for the
declarations where the overlay refers to potentially unavailable APIs. It also changes
several tests that refer to potentially unavailable APIs to use either #available()
or @availability annotations.

Swift SVN r27272
2015-04-14 06:44:01 +00:00
Joe Groff
c0a2994564 AST: Start printing function types with @convention instead of old attributes.
And update tests to match.

Swift SVN r27262
2015-04-13 22:51:34 +00:00
Michael Gottesman
75ea31dba9 Turn on +0 self by default.
The only caveat is that:

1. We do not properly recognize when we have a let binding and we
perform a guaranteed dynamic call. In such a case, we add an extra
retain, release pair around the call. In order to get that case I will
need to refactor some code in Callee. I want to make this change, but
not at the expense of getting the rest of this work in.

2. Some of the protocol witness thunks generated have unnecessary
retains or releases in a similar manner.

But this is a good first step.

I am going to send a large follow up email with all of the relevant results, so
I can let the bots chew on this a little bit.

rdar://19933044

Swift SVN r27241
2015-04-12 22:23:37 +00:00
Dmitri Hrybenko
32dbd0cfef tests: add a %target-ld substitution that is configured with stdlib paths
rdar://20474868

Swift SVN r27183
2015-04-09 22:17:24 +00:00
Dmitri Hrybenko
f87788f218 tests: remove ld-add_ast_path feature
We don't support building Swift with linkers that don't support this feature.

Swift SVN r27180
2015-04-09 21:47:55 +00:00
Dmitri Hrybenko
189eb3251e Revert "tests: use a %target-* substitution instead of calling 'ld' directly"
This reverts commit r27176.  Jordan pointed out an issue with this
approach, I'll make a different fix.

Swift SVN r27179
2015-04-09 21:11:28 +00:00
Dmitri Hrybenko
c6504366ad tests: use a %target-* substitution instead of calling 'ld' directly
rdar://20474868

Swift SVN r27176
2015-04-09 20:47:24 +00:00
Adrian Prantl
4a56a6b763 Generalize testcase to work on 32-bit targets.
<rdar://problem/20325040> [build-bot failure] Swift :: DebugInfo/return.swift

Swift SVN r26627
2015-03-27 15:51:29 +00:00
Mark Lacey
3ab2e208af Devirtualize during mandatory inlining.
With this change we will devirtualize in trivial cases where mandatory
inlining has exposed opportunities due to substituting types, for
example substituting a struct type into a witness_method where we can
now easily determine exactly what method will be called.

This makes it possible to use @transparent on struct methods that are
dispatched via generic functions, resulting in the opportunity to emit
diagnostics for these methods as well as eliminate the overhead of the
indirect call.

I saw a handful of 10+% perf improvements at -Onone on our benchmarks.

In theory this should allow us to remove the overloads for ++/-- in
FixedPoint.swift.gyb without a performance penalty (and with the proper
overflow diagnostics), but unfortunately if we were to do so, we would
currently dispatch to functions that lack runtime overflow
checks (rdar://problem/20226526).

Swift SVN r26397
2015-03-21 23:05:24 +00:00
Adrian Prantl
a9c3b7a6f4 Revert "XFAIL Failing Debug Info tests to unblock builders. rdar://20245578."
This reverts commit 26366.

Swift SVN r26380
2015-03-20 23:54:34 +00:00
Michael Gottesman
3b5634c30f XFAIL Failing Debug Info tests to unblock builders. rdar://20245578.
Swift SVN r26366
2015-03-20 22:36:12 +00:00
Chris Lattner
ce9b0131a1 Change the testsuite to not use typed patterns in nested contexts, which
requires pushing the types out.  The only interesting one is this diff:

-  var (e,f,g:(),h) = MRV()
+  var (e,f,g,h) : (Int, Float, (), Double) = MRV()

... where the type annotation is required to silence the warning about "void type
may be unexpected".  This seems perfectly reasonable to me.



Swift SVN r26161
2015-03-15 19:11:18 +00:00
Adrian Prantl
3c6af3610a Debug Info: type-unique enum types by virtue of their mangled name.
rdar://problem/20015686

Swift SVN r26104
2015-03-13 18:13:59 +00:00
Adrian Prantl
a100a3e6e9 Debug Info: Don't absolutize file paths.
Fixes <rdar://problem/19985842> REPL should set the default file to "repl.swift"

Swift SVN r26022
2015-03-12 02:56:49 +00:00
Dmitri Hrybenko
99d215cb34 tests: port DebugInfo/variables.swift to Linux
Swift SVN r25861
2015-03-08 11:31:29 +00:00
Dmitri Hrybenko
9ed3a4a196 tests: fix a test for 32-bit platforms
Swift SVN r25745
2015-03-04 05:19:21 +00:00
Adrian Prantl
2a4c39ddd9 Also accept "Apple Swift" as a valid producer.
Swift SVN r25728
2015-03-04 00:15:13 +00:00
Adrian Prantl
f5432e4a3b remove stale comment
Swift SVN r25727
2015-03-04 00:05:26 +00:00
Adrian Prantl
8ce7d8667e Fixup testcases after the debug representation update.
Swift SVN r25726
2015-03-03 23:58:07 +00:00
Duncan Exon Smith
093eb3c365 DebugInfo: Hand-update testcases after LLVM r231082
Update debug info testcases after moving the new hierarchy into place in
upstream LLVM r231082.

rdar://problem/19720042



Swift SVN r25715
2015-03-03 19:15:31 +00:00
Dmitri Hrybenko
ab5dfa0cd0 Adjust tests for the upstream changes in the LLVM IR syntax
Swift SVN r25655
2015-03-01 09:28:51 +00:00
Dmitri Hrybenko
3890d64e49 Fix a crash in the type checker when trying to find an ObjC bridge
intrinsic when ObjC interop is absent

Investigated and fixed together with Graham.

Swift SVN r25621
2015-02-27 22:09:15 +00:00
Adrian Prantl
d70e28c917 Update this tescase for r25502.
Thanks Jordan for noticing.

Swift SVN r25518
2015-02-24 22:57:52 +00:00
Adrian Prantl
45544727ac Mark reabstraction thunk helpers as auto-generated.
Fixes <rdar://problem/18670152> Stack trace is a lie.

Swift SVN r25362
2015-02-18 00:46:25 +00:00
Adrian Prantl
9deae1b6b7 Add a testcase I forgot add before committing r25287.
Swift SVN r25361
2015-02-18 00:46:15 +00:00
Adrian Prantl
bb63b1eb2d Make this testcase more resilient.
Swift SVN r25337
2015-02-17 01:18:14 +00:00
Jordan Rose
6e96e26a81 Add CompilerInvocation::loadFromSerializedAST.
This is mainly for the debugger's use, to set up CompilerInvocations that
match how a particular app was compiled in certain important ways. Today
that's the target (which is also in the binary), the SDK path (which in
the long run should probably be an SDK name), and any random -Xcc options
we need to pass (which we should probably attempt to minimize).

Because there's only one target and SDK per context, and because -Xcc
options can easily conflict, this is only intended to be used once per
CompilerInvocation.

Note that search paths are not covered by this; they are already being
added at the time the module is loaded. See r24545.

Completes rdar://problem/17670778.

Swift SVN r25227
2015-02-12 05:32:37 +00:00
Jordan Rose
de8a05b293 [Serialization] Serialize the SDK path and -Xcc arguments for an app.
...so that the debugger has the best possible chance of being able to load
the app properly.

We don't do this for frameworks today because we don't want to leak this
information into the public module; once we have a distinction between
"the module that ships with the framework" and "the module that goes into
the debug info" we can do this for frameworks as well.

Part of rdar://problem/17670778

Swift SVN r25204
2015-02-11 23:07:48 +00:00
Adrian Prantl
3428430a7c Fix an embarrassing typo in this testcase.
Swift SVN r25154
2015-02-11 01:06:17 +00:00
Adrian Prantl
52fbf06f55 Rewrite this testcase to be more robust.
Swift SVN r25148
2015-02-11 00:25:47 +00:00
Dmitri Hrybenko
6058d291ca CMake: allow the SDK overlay to be built separately from the compiler
and the stdandard library

rdar://19703353

Swift SVN r25139
2015-02-10 21:57:03 +00:00