 
                            ...
Creating a mutable class without providing copy functionality can result in the data of its instance becoming corrupted when the instance is passed to untrusted code.
| Rule | Severity | Likelihood | Detectable | RepairableRemediation Cost | Priority | Level | 
|---|---|---|---|---|---|---|
| OBJ04-J | Low | Likely | No | NoMedium | P6P3 | L2L3 | 
Automated Detection
Sound automated detection is infeasible in the general case. Heuristic approaches could be useful.
| Tool | Version | Checker | Description | CodeSonar | 4.2 | FB.MALICIOUS_CODE.EI_EXPOSE_REP FB.MALICIOUS_CODE.EI_EXPOSE_REP2 | |||
|---|---|---|---|---|---|---|---|---|---|
| Coverity | 7.5 | FB.EI_EXPOSE_REP2 | Implemented | ||||||
| Klocwork | 
 | SV.EXPOSE.RET SV.EXPOSE.STORE | |||||||
| Parasoft Jtest | 
 | CERT.OBJ04.CLONE CERT.OBJ04.CPCL CERT.OBJ04.MPT CERT.OBJ04.SMO CERT.OBJ04.MUCOP | Make your 'clone()' method "final" for security Enforce returning a defensive copy in 'clone()' methods Do not pass user-given mutable objects directly to certain types Do not store user-given mutable objects directly into variables Provide mutable classes with copy functionality | 
...