Skip to content

Commit 85c0855

Browse files
authored
Merge pull request #51 from noti0na1/dotty-explicit-nulls-notNull
Fix typos and merge upstream
2 parents 1c15bef + c41b926 commit 85c0855

File tree

155 files changed

+9641
-204
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

155 files changed

+9641
-204
lines changed

.gitignore

Lines changed: 0 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -83,37 +83,3 @@ community-build/sbt-dotty-sbt
8383

8484
# Vulpix output files
8585
*.check.out
86-
87-
tastydoc/report/report\.aux
88-
89-
tastydoc/report/report\.fdb_latexmk
90-
91-
tastydoc/report/report\.fls
92-
93-
tastydoc/report/report\.synctex\.gz
94-
95-
tastydoc/report/report\.toc
96-
97-
tastydoc/report/report\.out
98-
99-
tastydoc/report/presentation/presentation\.aux
100-
101-
tastydoc/report/presentation/presentation\.fdb_latexmk
102-
103-
tastydoc/report/presentation/presentation\.fls
104-
105-
tastydoc/report/presentation/presentation\.nav
106-
107-
tastydoc/report/presentation/presentation\.out
108-
109-
tastydoc/report/presentation/presentation\.snm
110-
111-
tastydoc/report/presentation/presentation\.synctex\.gz
112-
113-
tastydoc/report/presentation/presentation\.toc
114-
115-
tastydoc/dotty-0\.15\.0-RC1/
116-
117-
tastydoc/report/presentation/presentation\.vrb
118-
119-
tastydoc/dotty-0\.16\.0-RC3/

NOTICE.md

Lines changed: 209 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,209 @@
1+
# License notice for the ScalaPB protobuf library
2+
3+
The Dotty codebase contains parts which are derived from
4+
[the ScalaPB protobuf library](https://github.com/scalapb/scalapb).
5+
We include the text of the original license below:
6+
7+
```
8+
Apache License
9+
Version 2.0, January 2004
10+
http://www.apache.org/licenses/
11+
12+
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
13+
14+
1. Definitions.
15+
16+
"License" shall mean the terms and conditions for use, reproduction,
17+
and distribution as defined by Sections 1 through 9 of this document.
18+
19+
"Licensor" shall mean the copyright owner or entity authorized by
20+
the copyright owner that is granting the License.
21+
22+
"Legal Entity" shall mean the union of the acting entity and all
23+
other entities that control, are controlled by, or are under common
24+
control with that entity. For the purposes of this definition,
25+
"control" means (i) the power, direct or indirect, to cause the
26+
direction or management of such entity, whether by contract or
27+
otherwise, or (ii) ownership of fifty percent (50%) or more of the
28+
outstanding shares, or (iii) beneficial ownership of such entity.
29+
30+
"You" (or "Your") shall mean an individual or Legal Entity
31+
exercising permissions granted by this License.
32+
33+
"Source" form shall mean the preferred form for making modifications,
34+
including but not limited to software source code, documentation
35+
source, and configuration files.
36+
37+
"Object" form shall mean any form resulting from mechanical
38+
transformation or translation of a Source form, including but
39+
not limited to compiled object code, generated documentation,
40+
and conversions to other media types.
41+
42+
"Work" shall mean the work of authorship, whether in Source or
43+
Object form, made available under the License, as indicated by a
44+
copyright notice that is included in or attached to the work
45+
(an example is provided in the Appendix below).
46+
47+
"Derivative Works" shall mean any work, whether in Source or Object
48+
form, that is based on (or derived from) the Work and for which the
49+
editorial revisions, annotations, elaborations, or other modifications
50+
represent, as a whole, an original work of authorship. For the purposes
51+
of this License, Derivative Works shall not include works that remain
52+
separable from, or merely link (or bind by name) to the interfaces of,
53+
the Work and Derivative Works thereof.
54+
55+
"Contribution" shall mean any work of authorship, including
56+
the original version of the Work and any modifications or additions
57+
to that Work or Derivative Works thereof, that is intentionally
58+
submitted to Licensor for inclusion in the Work by the copyright owner
59+
or by an individual or Legal Entity authorized to submit on behalf of
60+
the copyright owner. For the purposes of this definition, "submitted"
61+
means any form of electronic, verbal, or written communication sent
62+
to the Licensor or its representatives, including but not limited to
63+
communication on electronic mailing lists, source code control systems,
64+
and issue tracking systems that are managed by, or on behalf of, the
65+
Licensor for the purpose of discussing and improving the Work, but
66+
excluding communication that is conspicuously marked or otherwise
67+
designated in writing by the copyright owner as "Not a Contribution."
68+
69+
"Contributor" shall mean Licensor and any individual or Legal Entity
70+
on behalf of whom a Contribution has been received by Licensor and
71+
subsequently incorporated within the Work.
72+
73+
2. Grant of Copyright License. Subject to the terms and conditions of
74+
this License, each Contributor hereby grants to You a perpetual,
75+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76+
copyright license to reproduce, prepare Derivative Works of,
77+
publicly display, publicly perform, sublicense, and distribute the
78+
Work and such Derivative Works in Source or Object form.
79+
80+
3. Grant of Patent License. Subject to the terms and conditions of
81+
this License, each Contributor hereby grants to You a perpetual,
82+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
83+
(except as stated in this section) patent license to make, have made,
84+
use, offer to sell, sell, import, and otherwise transfer the Work,
85+
where such license applies only to those patent claims licensable
86+
by such Contributor that are necessarily infringed by their
87+
Contribution(s) alone or by combination of their Contribution(s)
88+
with the Work to which such Contribution(s) was submitted. If You
89+
institute patent litigation against any entity (including a
90+
cross-claim or counterclaim in a lawsuit) alleging that the Work
91+
or a Contribution incorporated within the Work constitutes direct
92+
or contributory patent infringement, then any patent licenses
93+
granted to You under this License for that Work shall terminate
94+
as of the date such litigation is filed.
95+
96+
4. Redistribution. You may reproduce and distribute copies of the
97+
Work or Derivative Works thereof in any medium, with or without
98+
modifications, and in Source or Object form, provided that You
99+
meet the following conditions:
100+
101+
(a) You must give any other recipients of the Work or
102+
Derivative Works a copy of this License; and
103+
104+
(b) You must cause any modified files to carry prominent notices
105+
stating that You changed the files; and
106+
107+
(c) You must retain, in the Source form of any Derivative Works
108+
that You distribute, all copyright, patent, trademark, and
109+
attribution notices from the Source form of the Work,
110+
excluding those notices that do not pertain to any part of
111+
the Derivative Works; and
112+
113+
(d) If the Work includes a "NOTICE" text file as part of its
114+
distribution, then any Derivative Works that You distribute must
115+
include a readable copy of the attribution notices contained
116+
within such NOTICE file, excluding those notices that do not
117+
pertain to any part of the Derivative Works, in at least one
118+
of the following places: within a NOTICE text file distributed
119+
as part of the Derivative Works; within the Source form or
120+
documentation, if provided along with the Derivative Works; or,
121+
within a display generated by the Derivative Works, if and
122+
wherever such third-party notices normally appear. The contents
123+
of the NOTICE file are for informational purposes only and
124+
do not modify the License. You may add Your own attribution
125+
notices within Derivative Works that You distribute, alongside
126+
or as an addendum to the NOTICE text from the Work, provided
127+
that such additional attribution notices cannot be construed
128+
as modifying the License.
129+
130+
You may add Your own copyright statement to Your modifications and
131+
may provide additional or different license terms and conditions
132+
for use, reproduction, or distribution of Your modifications, or
133+
for any such Derivative Works as a whole, provided Your use,
134+
reproduction, and distribution of the Work otherwise complies with
135+
the conditions stated in this License.
136+
137+
5. Submission of Contributions. Unless You explicitly state otherwise,
138+
any Contribution intentionally submitted for inclusion in the Work
139+
by You to the Licensor shall be under the terms and conditions of
140+
this License, without any additional terms or conditions.
141+
Notwithstanding the above, nothing herein shall supersede or modify
142+
the terms of any separate license agreement you may have executed
143+
with Licensor regarding such Contributions.
144+
145+
6. Trademarks. This License does not grant permission to use the trade
146+
names, trademarks, service marks, or product names of the Licensor,
147+
except as required for reasonable and customary use in describing the
148+
origin of the Work and reproducing the content of the NOTICE file.
149+
150+
7. Disclaimer of Warranty. Unless required by applicable law or
151+
agreed to in writing, Licensor provides the Work (and each
152+
Contributor provides its Contributions) on an "AS IS" BASIS,
153+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
154+
implied, including, without limitation, any warranties or conditions
155+
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
156+
PARTICULAR PURPOSE. You are solely responsible for determining the
157+
appropriateness of using or redistributing the Work and assume any
158+
risks associated with Your exercise of permissions under this License.
159+
160+
8. Limitation of Liability. In no event and under no legal theory,
161+
whether in tort (including negligence), contract, or otherwise,
162+
unless required by applicable law (such as deliberate and grossly
163+
negligent acts) or agreed to in writing, shall any Contributor be
164+
liable to You for damages, including any direct, indirect, special,
165+
incidental, or consequential damages of any character arising as a
166+
result of this License or out of the use or inability to use the
167+
Work (including but not limited to damages for loss of goodwill,
168+
work stoppage, computer failure or malfunction, or any and all
169+
other commercial damages or losses), even if such Contributor
170+
has been advised of the possibility of such damages.
171+
172+
9. Accepting Warranty or Additional Liability. While redistributing
173+
the Work or Derivative Works thereof, You may choose to offer,
174+
and charge a fee for, acceptance of support, warranty, indemnity,
175+
or other liability obligations and/or rights consistent with this
176+
License. However, in accepting such obligations, You may act only
177+
on Your own behalf and on Your sole responsibility, not on behalf
178+
of any other Contributor, and only if You agree to indemnify,
179+
defend, and hold each Contributor harmless for any liability
180+
incurred by, or claims asserted against, such Contributor by reason
181+
of your accepting any such warranty or additional liability.
182+
183+
END OF TERMS AND CONDITIONS
184+
185+
APPENDIX: How to apply the Apache License to your work.
186+
187+
To apply the Apache License to your work, attach the following
188+
boilerplate notice, with the fields enclosed by brackets "[]"
189+
replaced with your own identifying information. (Don't include
190+
the brackets!) The text should be enclosed in the appropriate
191+
comment syntax for the file format. We also recommend that a
192+
file or class name and description of purpose be included on the
193+
same "printed page" as the copyright notice for easier
194+
identification within third-party archives.
195+
196+
Copyright [yyyy] [name of copyright owner]
197+
198+
Licensed under the Apache License, Version 2.0 (the "License");
199+
you may not use this file except in compliance with the License.
200+
You may obtain a copy of the License at
201+
202+
http://www.apache.org/licenses/LICENSE-2.0
203+
204+
Unless required by applicable law or agreed to in writing, software
205+
distributed under the License is distributed on an "AS IS" BASIS,
206+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
207+
See the License for the specific language governing permissions and
208+
limitations under the License.
209+
```

compiler/src/dotty/tools/dotc/Compiler.scala

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,7 @@ class Compiler {
4040
List(new YCheckPositions) :: // YCheck positions
4141
List(new Staging) :: // Check PCP, heal quoted types and expand macros
4242
List(new sbt.ExtractDependencies) :: // Sends information on classes' dependencies to sbt via callbacks
43+
List(new semanticdb.ExtractSemanticDB) :: // Extract info into .semanticdb files
4344
List(new PostTyper) :: // Additional checks and cleanups after type checking
4445
List(new sbt.ExtractAPI) :: // Sends a representation of the API of classes to sbt via callbacks
4546
List(new SetRootTree) :: // Set the `rootTreeOrProvider` on class symbols

compiler/src/dotty/tools/dotc/ast/Trees.scala

Lines changed: 29 additions & 32 deletions
Original file line numberDiff line numberDiff line change
@@ -332,53 +332,44 @@ object Trees {
332332
def namedType: NamedType = tpe.asInstanceOf[NamedType]
333333
}
334334

335-
/** Tree defines a new symbol and carries modifiers.
336-
* The position of a MemberDef contains only the defined identifier or pattern.
337-
* The envelope of a MemberDef contains the whole definition and has its point
338-
* on the opening keyword (or the next token after that if keyword is missing).
339-
*/
340-
abstract class MemberDef[-T >: Untyped](implicit @constructorOnly src: SourceFile) extends NameTree[T] with DefTree[T] {
341-
type ThisTree[-T >: Untyped] <: MemberDef[T]
342-
343-
def rawComment: Option[Comment] = getAttachment(DocComment)
344-
345-
def setComment(comment: Option[Comment]): this.type = {
346-
comment.map(putAttachment(DocComment, _))
347-
this
348-
}
335+
abstract class NamedDefTree[-T >: Untyped](implicit @constructorOnly src: SourceFile) extends NameTree[T] with DefTree[T] {
336+
type ThisTree[-T >: Untyped] <: NamedDefTree[T]
349337

350338
/** The position of the name defined by this definition.
351339
* This is a point position if the definition is synthetic, or a range position
352340
* if the definition comes from source.
353341
* It might also be that the definition does not have a position (for instance when synthesized by
354342
* a calling chain from `viewExists`), in that case the return position is NoSpan.
343+
* Overridden in Bind
355344
*/
356345
def nameSpan: Span =
357346
if (span.exists) {
358347
val point = span.point
359348
if (rawMods.is(Synthetic) || name.toTermName == nme.ERROR) Span(point)
360349
else {
361350
val realName = name.stripModuleClassSuffix.lastPart.toString
362-
val nameStart =
363-
if (point != span.start) point
364-
else {
365-
// Point might be too far away from start to be recorded. In this case we fall back to scanning
366-
// forwards from the start offset for the name.
367-
// Note: This might be inaccurate since scanning might hit accidentally the same
368-
// name (e.g. in a comment) before finding the real definition.
369-
// To make this behavior more robust we'd have to change the trees for definitions to contain
370-
// a fully positioned Ident in place of a name.
371-
val contents = if source.exists then source.content() else Array.empty[Char]
372-
val idx = contents.indexOfSlice(realName, point)
373-
if (idx >= 0) idx
374-
else point // use `point` anyway. This is important if no source exists so scanning fails
375-
}
376351
Span(point, point + realName.length, point)
377352
}
378353
}
379354
else span
380355
}
381356

357+
/** Tree defines a new symbol and carries modifiers.
358+
* The position of a MemberDef contains only the defined identifier or pattern.
359+
* The envelope of a MemberDef contains the whole definition and has its point
360+
* on the opening keyword (or the next token after that if keyword is missing).
361+
*/
362+
abstract class MemberDef[-T >: Untyped](implicit @constructorOnly src: SourceFile) extends NamedDefTree[T] {
363+
type ThisTree[-T >: Untyped] <: MemberDef[T]
364+
365+
def rawComment: Option[Comment] = getAttachment(DocComment)
366+
367+
def setComment(comment: Option[Comment]): this.type = {
368+
comment.map(putAttachment(DocComment, _))
369+
this
370+
}
371+
}
372+
382373
/** A ValDef or DefDef tree */
383374
abstract class ValOrDefDef[-T >: Untyped](implicit @constructorOnly src: SourceFile) extends MemberDef[T] with WithLazyField[Tree[T]] {
384375
type ThisTree[-T >: Untyped] <: ValOrDefDef[T]
@@ -621,6 +612,8 @@ object Trees {
621612
case class Inlined[-T >: Untyped] private[ast] (call: tpd.Tree, bindings: List[MemberDef[T]], expansion: Tree[T])(implicit @constructorOnly src: SourceFile)
622613
extends Tree[T] {
623614
type ThisTree[-T >: Untyped] = Inlined[T]
615+
override def isTerm = expansion.isTerm
616+
override def isType = expansion.isType
624617
}
625618

626619
/** A type tree that represents an existing or inferred type */
@@ -705,10 +698,13 @@ object Trees {
705698

706699
/** name @ body */
707700
case class Bind[-T >: Untyped] private[ast] (name: Name, body: Tree[T])(implicit @constructorOnly src: SourceFile)
708-
extends NameTree[T] with DefTree[T] with PatternTree[T] {
701+
extends NamedDefTree[T] with PatternTree[T] {
709702
type ThisTree[-T >: Untyped] = Bind[T]
710703
override def isType: Boolean = name.isTypeName
711704
override def isTerm: Boolean = name.isTermName
705+
706+
override def nameSpan: Span =
707+
if span.exists then Span(span.start, span.start + name.toString.length) else span
712708
}
713709

714710
/** tree_1 | ... | tree_n */
@@ -938,6 +934,7 @@ object Trees {
938934
type NameTree = Trees.NameTree[T]
939935
type RefTree = Trees.RefTree[T]
940936
type DefTree = Trees.DefTree[T]
937+
type NamedDefTree = Trees.NamedDefTree[T]
941938
type MemberDef = Trees.MemberDef[T]
942939
type ValOrDefDef = Trees.ValOrDefDef[T]
943940
type LazyTree = Trees.LazyTree[T]
@@ -1439,13 +1436,13 @@ object Trees {
14391436
this(x, trees)
14401437
case UnApply(fun, implicits, patterns) =>
14411438
this(this(this(x, fun), implicits), patterns)
1442-
case tree @ ValDef(name, tpt, _) =>
1439+
case tree @ ValDef(_, tpt, _) =>
14431440
implicit val ctx = localCtx
14441441
this(this(x, tpt), tree.rhs)
1445-
case tree @ DefDef(name, tparams, vparamss, tpt, _) =>
1442+
case tree @ DefDef(_, tparams, vparamss, tpt, _) =>
14461443
implicit val ctx = localCtx
14471444
this(this(vparamss.foldLeft(this(x, tparams))(apply), tpt), tree.rhs)
1448-
case TypeDef(name, rhs) =>
1445+
case TypeDef(_, rhs) =>
14491446
implicit val ctx = localCtx
14501447
this(x, rhs)
14511448
case tree @ Template(constr, parents, self, _) if tree.derived.isEmpty =>

compiler/src/dotty/tools/dotc/ast/tpd.scala

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1070,7 +1070,7 @@ object tpd extends Trees.Instance[Type] with TypedTreeInfo {
10701070
transform(rhs)
10711071
case _ => tree
10721072
}
1073-
case Inlined(_, _, arg) => transform(arg)
1073+
case Inlined(_, Nil, arg) => transform(arg)
10741074
case Block(Nil, arg) => transform(arg)
10751075
case NamedArg(_, arg) => transform(arg)
10761076
case tree => super.transform(tree)

compiler/src/dotty/tools/dotc/ast/untpd.scala

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -111,6 +111,7 @@ object untpd extends Trees.Instance[Untyped] with UntypedTreeInfo {
111111
case class Export(expr: Tree, selectors: List[ImportSelector])(implicit @constructorOnly src: SourceFile) extends Tree
112112

113113
case class ImportSelector(imported: Ident, renamed: Tree = EmptyTree, bound: Tree = EmptyTree)(implicit @constructorOnly src: SourceFile) extends Tree {
114+
// TODO: Make bound a typed tree?
114115

115116
/** It's a `given` selector */
116117
val isGiven: Boolean = imported.name.isEmpty

0 commit comments

Comments
 (0)