Skip to content
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

Refactor Root #229

Closed
rpx99 opened this issue Jun 26, 2024 · 2 comments
Closed

Refactor Root #229

rpx99 opened this issue Jun 26, 2024 · 2 comments

Comments

@rpx99
Copy link

rpx99 commented Jun 26, 2024

It seems once there is Data in a store I cannot rename the Root Class.

E.g. I changed

@Storage
public class KundeStorage

to

@Storage
public class DataRoot

org.eclipse.serializer.persistence.exceptions.PersistenceException: Missing runtime type for required type handler for type: de.metaprog.demo.logic.home.KundeStorage
     at deployment.demo.war//org.eclipse.serializer.persistence.types.PersistenceTypeHandlerManager$Default.validateExistingType(PersistenceTypeHandlerManager.java:390)
     at deployment.demo.war//org.eclipse.serializer.persistence.types.PersistenceTypeHandlerManager$Default.ensureTypeHandler(PersistenceTypeHandlerManager.java:439)
     at deployment.demo.war//org.eclipse.serializer.persistence.types.PersistenceTypeHandlerManager$Default.lambda$ensureTypeHandlers$2(PersistenceTypeHandlerManager.java:486)
     at deployment.demo.war//org.eclipse.serializer.collections.ChainStorageStrong.iterate(ChainStorageStrong.java:1316)
     at deployment.demo.war//org.eclipse.serializer.collections.HashEnum.iterate(HashEnum.java:693)
     at deployment.demo.war//org.eclipse.serializer.persistence.types.PersistenceTypeHandlerManager$Default.ensureTypeHandlers(PersistenceTypeHandlerManager.java:485)
     at deployment.demo.war//org.eclipse.serializer.persistence.types.PersistenceTypeHandlerManager$Default.ensureTypeHandlersByTypeIds(PersistenceTypeHandlerManager.java:477)
     at deployment.demo.war//org.eclipse.store.storage.embedded.types.EmbeddedStorageManager$Default.ensureRequiredTypeHandlers(EmbeddedStorageManager.java:344)
     at deployment.demo.war//org.eclipse.store.storage.embedded.types.EmbeddedStorageManager$Default.start(EmbeddedStorageManager.java:251)
     at deployment.demo.war//org.eclipse.store.storage.embedded.types.EmbeddedStorageManager$Default.start(EmbeddedStorageManager.java:95)
     at deployment.demo.war//org.eclipse.store.integrations.cdi.types.config.StorageManagerProducer.storageManagerFromProperties(StorageManagerProducer.java:97)
     at deployment.demo.war//org.eclipse.store.integrations.cdi.types.config.StorageManagerProducer.getStorageManager(StorageManagerProducer.java:63)
     at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103)
     at java.base/java.lang.reflect.Method.invoke(Method.java:580)

Is it possible to use some kind of indirection for this ?
How to fix it, if I ever wanted to do this?

Thanks!

@Bios-Marcel
Copy link

Hey

You have to register a RefactoringMappingProvider, for example:

.createEmbeddedStorageFoundation()
.setRefactoringMappingProvider(
        PersistenceRefactoringMappingProvider.New(
                List.of(KeyValue.New("link.biosmarcel.baka.data.Data", "link.biosmarcel.baka.data.DataNew"))
        )
)

There are multiple ways to do this, but the default seems to be a CSV file, as documented here:

https://docs.eclipsestore.io/manual/storage/legacy-type-mapping/index.html#_explicit_mapping_syntax

@rpx99
Copy link
Author

rpx99 commented Jul 8, 2024

@Bios-Marcel Thanks a lot for commenting. In the meantime I was enlighted

@rpx99 rpx99 closed this as completed Jul 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants