Commit bf9e7e8
authored
Refactor pimpl pointers in XMLSchemaComplexTypeGenerator and XMLValidator to unique_ptr (#661)
## Summary
- Replace raw `class Impl*` pimpl members with `std::unique_ptr<class
Impl>` in `XMLSchemaComplexTypeGenerator` and `XMLValidator`
- Destructors changed from `{ delete pimpl_; }` to `= default`, letting
the compiler generate correct cleanup
- Added `#include <memory>` to both headers
## Motivation
Both classes already correctly suppressed copy/move with `= delete`, so
there was no double-free risk. This refactor makes ownership explicit in
the type system and eliminates manual `delete` calls, following the Rule
of Zero pattern for pimpl idiom.
## Testing
Full debug build succeeds. No behavior change — pure ownership semantics
refactor.1 parent b8e64ec commit bf9e7e8
4 files changed
Lines changed: 6 additions & 4 deletions
File tree
- source/src/utility/tag
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2051 | 2051 | | |
2052 | 2052 | | |
2053 | 2053 | | |
2054 | | - | |
| 2054 | + | |
2055 | 2055 | | |
2056 | 2056 | | |
2057 | 2057 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
117 | 117 | | |
118 | 118 | | |
119 | 119 | | |
| 120 | + | |
120 | 121 | | |
121 | 122 | | |
122 | 123 | | |
| |||
969 | 970 | | |
970 | 971 | | |
971 | 972 | | |
972 | | - | |
| 973 | + | |
973 | 974 | | |
974 | 975 | | |
975 | 976 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
425 | 425 | | |
426 | 426 | | |
427 | 427 | | |
428 | | - | |
| 428 | + | |
429 | 429 | | |
430 | 430 | | |
431 | 431 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| 31 | + | |
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
| |||
84 | 85 | | |
85 | 86 | | |
86 | 87 | | |
87 | | - | |
| 88 | + | |
88 | 89 | | |
89 | 90 | | |
90 | 91 | | |
| |||
0 commit comments