Commit c6f300e
authored
Suppress empty builder for all-required dictionaries (#17)
When every property is required, the generated <Foo>Builder carries
only build() with nothing to chain - dead weight. ts-gen now emits
just new(reqs) directly on the dictionary type with construction
inlined, skipping the wrapper struct.
Before:
impl EmailSendResult {
pub fn new(message_id: &str) -> EmailSendResult {
Self::builder(message_id).build()
}
pub fn builder(message_id: &str) -> EmailSendResultBuilder {
let inner: Self = JsCast::unchecked_into(js_sys::Object::new());
inner.set_message_id(message_id);
EmailSendResultBuilder { inner }
}
}
pub struct EmailSendResultBuilder { inner: EmailSendResult }
impl EmailSendResultBuilder {
pub fn build(self) -> EmailSendResult { self.inner }
}
After:
impl EmailSendResult {
pub fn new(message_id: &str) -> EmailSendResult {
let inner: Self = JsCast::unchecked_into(js_sys::Object::new());
inner.set_message_id(message_id);
inner
}
}
Dictionaries with at least one optional field still get the full
new(reqs) + builder(reqs) + chainable wrapper treatment.1 parent a38a67c commit c6f300e
7 files changed
Lines changed: 2189 additions & 13475 deletions
File tree
- src/codegen
- tests
- fixtures
- snapshots
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
262 | 262 | | |
263 | 263 | | |
264 | 264 | | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
265 | 269 | | |
266 | 270 | | |
267 | 271 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
298 | 298 | | |
299 | 299 | | |
300 | 300 | | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
301 | 308 | | |
302 | 309 | | |
303 | 310 | | |
| |||
607 | 614 | | |
608 | 615 | | |
609 | 616 | | |
610 | | - | |
611 | 617 | | |
612 | 618 | | |
613 | 619 | | |
| |||
640 | 646 | | |
641 | 647 | | |
642 | 648 | | |
643 | | - | |
644 | | - | |
645 | | - | |
646 | | - | |
647 | | - | |
648 | | - | |
649 | | - | |
650 | | - | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
651 | 662 | | |
652 | | - | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
653 | 683 | | |
654 | | - | |
655 | | - | |
656 | | - | |
657 | | - | |
658 | | - | |
659 | | - | |
660 | | - | |
661 | | - | |
662 | | - | |
663 | | - | |
664 | | - | |
665 | | - | |
666 | | - | |
667 | | - | |
668 | | - | |
669 | | - | |
670 | | - | |
671 | | - | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
672 | 705 | | |
673 | 706 | | |
674 | 707 | | |
675 | 708 | | |
| 709 | + | |
676 | 710 | | |
677 | 711 | | |
678 | 712 | | |
| |||
700 | 734 | | |
701 | 735 | | |
702 | 736 | | |
703 | | - | |
704 | | - | |
705 | | - | |
706 | | - | |
707 | | - | |
| 737 | + | |
| 738 | + | |
| 739 | + | |
| 740 | + | |
| 741 | + | |
| 742 | + | |
708 | 743 | | |
709 | | - | |
710 | | - | |
711 | | - | |
| 744 | + | |
| 745 | + | |
| 746 | + | |
712 | 747 | | |
713 | | - | |
714 | | - | |
| 748 | + | |
| 749 | + | |
715 | 750 | | |
716 | | - | |
717 | | - | |
| 751 | + | |
| 752 | + | |
| 753 | + | |
| 754 | + | |
| 755 | + | |
| 756 | + | |
| 757 | + | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
718 | 762 | | |
719 | 763 | | |
720 | 764 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
27 | | - | |
28 | | - | |
29 | | - | |
30 | 27 | | |
31 | 28 | | |
32 | | - | |
33 | | - | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
38 | | - | |
39 | | - | |
40 | | - | |
| 29 | + | |
41 | 30 | | |
42 | 31 | | |
43 | 32 | | |
| |||
52 | 41 | | |
53 | 42 | | |
54 | 43 | | |
55 | | - | |
56 | | - | |
57 | | - | |
58 | 44 | | |
59 | 45 | | |
60 | | - | |
61 | | - | |
62 | | - | |
63 | | - | |
64 | | - | |
65 | | - | |
66 | | - | |
67 | | - | |
68 | | - | |
| 46 | + | |
69 | 47 | | |
70 | 48 | | |
71 | 49 | | |
| |||
80 | 58 | | |
81 | 59 | | |
82 | 60 | | |
83 | | - | |
84 | | - | |
85 | | - | |
86 | 61 | | |
87 | 62 | | |
88 | | - | |
89 | | - | |
90 | | - | |
91 | | - | |
92 | | - | |
93 | | - | |
94 | | - | |
95 | | - | |
96 | | - | |
| 63 | + | |
97 | 64 | | |
98 | 65 | | |
99 | 66 | | |
| |||
108 | 75 | | |
109 | 76 | | |
110 | 77 | | |
111 | | - | |
112 | | - | |
113 | | - | |
114 | 78 | | |
115 | 79 | | |
116 | | - | |
117 | | - | |
118 | | - | |
119 | | - | |
120 | | - | |
121 | | - | |
122 | | - | |
123 | | - | |
124 | | - | |
| 80 | + | |
125 | 81 | | |
126 | 82 | | |
127 | 83 | | |
| |||
261 | 217 | | |
262 | 218 | | |
263 | 219 | | |
264 | | - | |
265 | | - | |
266 | | - | |
267 | 220 | | |
268 | 221 | | |
269 | 222 | | |
270 | | - | |
271 | | - | |
272 | | - | |
273 | | - | |
274 | | - | |
275 | | - | |
276 | | - | |
277 | | - | |
278 | | - | |
| 223 | + | |
279 | 224 | | |
280 | 225 | | |
281 | 226 | | |
| |||
333 | 278 | | |
334 | 279 | | |
335 | 280 | | |
336 | | - | |
337 | | - | |
338 | | - | |
339 | 281 | | |
340 | 282 | | |
341 | | - | |
342 | | - | |
343 | | - | |
344 | | - | |
345 | | - | |
346 | | - | |
347 | | - | |
348 | | - | |
349 | | - | |
| 283 | + | |
350 | 284 | | |
351 | 285 | | |
352 | 286 | | |
| |||
0 commit comments