-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PojoBuilder should support adding a single element to a Collections #80
Comments
What if I have already something like
@mkarneim could you assist me and indicate the code parts which needs modification, I try to make another contribution to this project. |
Hi Vad1mo Putting addItem(Item additionalItem) in original POJO looks not a best solution. new TradeBuilder().withName(bla).withItemsAdd(
ItemBuilder().sithFoo("foo").withBar("bar"));
//or if you want to add two elements
new TradeBuilder().withName(bla)
.withItemsAdd(
ItemBuilder().sithFoo("foo").withBar("bar"));
.withItemsAdd(
ItemBuilder().sithFoo("foo2").withBar("bar2"));
This one will be better.
if in pojo,there is List<Item> items, pojobuilder just generate with*Add method.
we can also check items is initialized or not... |
Have you seen this one? |
thanks I didn't see #40 I don't find reasons why addItem is not feasible. About the unknown Collection Type which was mentioned before, and why it is not a problem.
|
@doggie1989 sorry I am not understanding your response. Can you elaborate more on that? |
@Vad1mo I think we should not add addItems method in original object.The original object only contains getters and setters. if pojobuilder detects List in object,in _Builder, it will have a method called with_Add class Trade
{
List<Item> items;
//no addItems method
}
//or if you want to add two elements
new TradeBuilder().withName(bla)
.withItemsAdd(
ItemBuilder().sithFoo("foo").withBar("bar"));
.withItemsAdd(
ItemBuilder().sithFoo("foo2").withBar("bar2"));
|
Vadim, it's not about feasibility. I just wanted to point out that you already can add single elements to a list-type property by using a simple method call that converts an enumeration of elements to a list. And I wouldn't call it a work-around since this is no bug you need to work around :-) Since your suggestion has been suggested a few times before, I knwo that I have to listen to you carefully, since I don't want to stop a really important feature just because of some ignorance by myself. But first, my I ask you to have a look at the following wiki article I just created, and at the code samples I commited (and refrenced there)? https://github.com/mkarneim/pojobuilder/wiki/Domain-specific-language Among other things, you should see, how you can work with list-type properties using a bunch of static helper method that provide a proverful DSL for cerating pojos. In my opinion, this DSL is really fluent, and it does not really suffer from not-having 'addItem' methods. Comments? |
@mkarneim thank you for the tutorial, I will try it out and report how it feels. |
Vadim, |
I tried it out now, but honestly I have some difficulties to grasp this DSL concept based on the testcase. IMHO I am a bit worried, if this all is understandable and easy to grasp for an average developer who never heard of Fluent Builder. I have a model with 100 classes I will try to build upon it and try out some more maybe I get it.. |
No, DslBase is handwritten, but it is so generic that (most of it) can be reused in other projects. The idea, to write and publish some demo project, is very good. I think I will do that during the next week or so. I also had a look at your repo 'konik'. There is also a sample unit test: https://github.com/mkarneim/konik/blob/master/src/test/java/io/konik/examples/SomeSampleTest.java. I tried to test the feature, that an invoice can be stored to a file and loaded from it (it does not work at the end, but that's because of the lazy field initialization of list properties). I hope you get the idea with that. |
A few years have passed and Java now supports |
Notes on a complex usecase: @GeneratePojoBuilder
public class Thing {
@CollectWith(ArrayListCollector.class)
public List<String> names;
} I think PB should support public static class ArrayListCollector<T> implements Supplier<Collector<T, List<T>, List<T>>> {
@SuppressWarnings("unchecked")
@Override
public Collector<T, List<T>, List<T>> get() {
return (Collector<T, List<T>, List<T>>) Collectors.<T>toList();
}
} This generates the following builder public class ThingBuilder {
// Note STATIC. This is not actually a requirement of Collector<T,A,R> but seems the standard
// FIXME Determining "String" is v difficult ...
// ...T doesn't have to be related to R : Collector<Map.Entry<K,V>, Map<K,V>, Map<K,V>>
// ... A != R for custom collectors which don't use the terminal type during accumulation
protected static final Collector<String, List<String>, List<String>> collector$names$java$util$List = new ArrayListCollector<>();
protected ThingBuilder self;
protected List<String> value$names$java$util$List;
protected boolean isSet$names$java$util$List;
public ThingBuilder withNames(List<String> value) {
this.value$names$java$util$List = value;
this.isSet$names$java$util$List = true;
return self;
}
// Overload withNames even for singular as code doesn't understand pluralisation
public ThingBuilder withNames(String name) {
if (value$names$java$util$List == null) {
value$names$java$util$List = collector$names$java$util$List.supplier().get(); // new ArrayList()
}
collector$names$java$util$List.accumulator().accept(value$names$java$util$List, name); // list.add(name)
return self;
}
public Thing build() {
try {
Thing result = new Thing();
// isSet now means "explicitly set"
if (isSet$names$java$util$List) {
result.names = value$names$java$util$List;
} else if(value$names$java$util$List != null) {
result.names = collector$names$java$util$List.finisher().apply(value$names$java$util$List);
}
return result;
} catch (RuntimeException ex) {
throw ex;
} catch (Exception ex) {
throw new RuntimeException(ex);
}
}
} |
Note Java 10 has built-in immutable Collectors which is really useful for Value Object builders. |
Imagine a POJO like this:
When PojoBuilder would support adding a single element to a Collections one could write something like this:
This feature would be great. I could help but need help where and how best to start.
The text was updated successfully, but these errors were encountered: