private void parseCacheAttribute(
     XMLExtendedStreamReader reader, int index, Attribute attribute, String value, ModelNode cache)
     throws XMLStreamException {
   switch (attribute) {
     case NAME:
       {
         CacheResource.NAME.parseAndSetParameter(value, cache, reader);
         break;
       }
     case START:
       {
         CacheResource.START.parseAndSetParameter(value, cache, reader);
         break;
       }
     case JNDI_NAME:
       {
         CacheResource.JNDI_NAME.parseAndSetParameter(value, cache, reader);
         break;
       }
     case BATCHING:
       {
         CacheResource.BATCHING.parseAndSetParameter(value, cache, reader);
         break;
       }
     case MODULE:
       {
         CacheResource.CACHE_MODULE.parseAndSetParameter(value, cache, reader);
         break;
       }
     default:
       {
         throw ParseUtils.unexpectedAttribute(reader, index);
       }
   }
 }
    static {
      // shared cache attributes
      sharedAttributeResolver.put(CacheResource.BATCHING.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.CACHE_MODULE.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.INDEXING.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.INDEXING_PROPERTIES.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.JNDI_NAME.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.NAME.getName(), "cache");
      sharedAttributeResolver.put(CacheResource.START.getName(), "cache");

      sharedAttributeResolver.put(
          ClusteredCacheResource.ASYNC_MARSHALLING.getName(), "clustered-cache");
      sharedAttributeResolver.put(ClusteredCacheResource.MODE.getName(), "clustered-cache");
      sharedAttributeResolver.put(
          ClusteredCacheResource.QUEUE_FLUSH_INTERVAL.getName(), "clustered-cache");
      sharedAttributeResolver.put(ClusteredCacheResource.QUEUE_SIZE.getName(), "clustered-cache");
      sharedAttributeResolver.put(
          ClusteredCacheResource.REMOTE_TIMEOUT.getName(), "clustered-cache");

      sharedAttributeResolver.put(BaseStoreResource.FETCH_STATE.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.PASSIVATION.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.PRELOAD.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.PURGE.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.SHARED.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.SINGLETON.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.PROPERTY.getName(), "store");
      sharedAttributeResolver.put(BaseStoreResource.PROPERTIES.getName(), "store");

      sharedAttributeResolver.put(BaseJDBCStoreResource.DATA_SOURCE.getName(), "jdbc-store");
      sharedAttributeResolver.put(BaseJDBCStoreResource.BATCH_SIZE.getName(), "jdbc-store");
      sharedAttributeResolver.put(BaseJDBCStoreResource.FETCH_SIZE.getName(), "jdbc-store");
      sharedAttributeResolver.put(BaseJDBCStoreResource.PREFIX.getName(), "jdbc-store");
      sharedAttributeResolver.put(
          BaseJDBCStoreResource.ID_COLUMN.getName() + ".column", "jdbc-store");
      sharedAttributeResolver.put(
          BaseJDBCStoreResource.DATA_COLUMN.getName() + ".column", "jdbc-store");
      sharedAttributeResolver.put(
          BaseJDBCStoreResource.TIMESTAMP_COLUMN.getName() + ".column", "jdbc-store");
      sharedAttributeResolver.put(
          BaseJDBCStoreResource.ENTRY_TABLE.getName() + "table", "jdbc-store");
      sharedAttributeResolver.put(
          BaseJDBCStoreResource.BUCKET_TABLE.getName() + "table", "jdbc-store");

      // shared children - this avoids having to describe the children for each parent resource
      sharedAttributeResolver.put(ModelKeys.TRANSPORT, null);
      sharedAttributeResolver.put(ModelKeys.LOCKING, null);
      sharedAttributeResolver.put(ModelKeys.TRANSACTION, null);
      sharedAttributeResolver.put(ModelKeys.EVICTION, null);
      sharedAttributeResolver.put(ModelKeys.EXPIRATION, null);
      sharedAttributeResolver.put(ModelKeys.STATE_TRANSFER, null);
      sharedAttributeResolver.put(ModelKeys.STORE, null);
      sharedAttributeResolver.put(ModelKeys.FILE_STORE, null);
      sharedAttributeResolver.put(ModelKeys.REMOTE_STORE, null);
      sharedAttributeResolver.put(ModelKeys.STRING_KEYED_JDBC_STORE, null);
      sharedAttributeResolver.put(ModelKeys.BINARY_KEYED_JDBC_STORE, null);
      sharedAttributeResolver.put(ModelKeys.MIXED_KEYED_JDBC_STORE, null);
      sharedAttributeResolver.put(ModelKeys.WRITE_BEHIND, null);
      sharedAttributeResolver.put(ModelKeys.PROPERTY, null);
    }