Exclude classes with a writeReplace method from serializability checks

This commit is contained in:
Chris Smowton
2025-01-06 14:42:44 +00:00
parent b60c86077d
commit 5c2df36786
4 changed files with 36 additions and 0 deletions

View File

@@ -24,6 +24,16 @@ where
c.hasNoParameters() and
not c.isPrivate()
) and
// Assume if an object replaces itself prior to serialization,
// then it is unlikely to be directly deserialized.
// That means it won't need to comply with default serialization rules,
// such as non-serializable super-classes having a no-argument constructor.
not exists(Method m |
m = serial.getAMethod() and
m.hasName("writeReplace") and
m.getReturnType() instanceof TypeObject and
m.hasNoParameters()
) and
serial.fromSource()
select serial,
"This class is serializable, but its non-serializable " +