Comments (4)
I like the idea here. We can't totally eliminate VoidTypeName
because of TypeNames.forClass
, but we can make it non-public for that case.
As to the suggestions, I'm not sure which approach I'd prefer yet. Need to think about it a bit.
from javapoet.
I understand the principle here, but both of the standard APIs for working with types in Java represent void
as a type:
- https://docs.oracle.com/javase/7/docs/api/java/lang/Void.html#TYPE
- https://docs.oracle.com/javase/7/docs/api/javax/lang/model/type/NoType.html
IMO, the decision was made for us and IllegalArgumentException
just isn't that bad.
from javapoet.
Neither of those is part of an API for defining the type of something, though. You can never get void.class
as the result of Field.getType()
or Method.getParameterTypes()[0]
, and there's no way with reflection or annotation-processing to create a field, say, where you could accidentally specify a type of void.class
or NoType
.
I think having the Java type system help here would be beneficial to users, and I don't really see much of a downside. I do think that TypeNames.forClass
and TypeNames.forTypeMirror
should throw if given void.class
or NoType
respectively, and that there should be TypeNames.forClassReturnType
and TypeNames.forTypeMirrorReturnType
that do the right thing for those before forwarding to the existing methods.
from javapoet.
No action to take here with the current codebase.
from javapoet.
Related Issues (20)
- parameterVariableElement() in ParameterSpecTest failed HOT 1
- Can the javapoet generate constructor or getter or setter automatically? HOT 2
- how to build a jdk14 record type? HOT 1
- example error HOT 1
- addStatement produce wired results when format contains '\n' HOT 1
- Generics will not be auto-imported
- Emit `@Generated("...")` with a link back to the generator on all top-level classes HOT 1
- New release 1.14.0? HOT 2
- `ParameterizedTypeName#annotated` would add the annotations repeatedly.
- $L combined with ExecutableElement in ecj produces unexpected results HOT 2
- ClassName.bestGuess function : Case for classNameString "?" not handled HOT 6
- Need Help : Getting the ClassName from Array ! HOT 4
- When using JavaFile builder Import statement for Array of Class is Wrong HOT 4
- Dependency Dashboard HOT 1
- WildcardTypeName doesn't emit annotations HOT 1
- How to automatically add non-static imports
- Java 17: Cannot read value from annotation HOT 3
- Ability to modify JavaFile.TypeSpec HOT 1
- Construct transparent objects HOT 3
- com.squareup.javapoet.JavaFile to have support for Java constant pool size HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from javapoet.