Ignore:
Timestamp:
06/28/13 11:56:03 (11 years ago)
Author:
psniegowski
Message:

HIGHLIGHTS:

  • FramsClass? and contained Param are now immutable classes (like String),

which allows to refer to them concurrently without synchronization
(which for example in turn simplifies GUI management)

  • also make Path immutable (which was earlier only assumed)
  • add global cache for FramsClasses? created solely and automatically

on base of Java classes.

representations basing on given FramsClass?

  • above changes greatly improved GUI responsivness during browsing
  • furtherly improve Param class hierarchy
  • allow to inject actions on state changes into MultiParamLoader?
  • add more tests

CHANGELOG:

Add StatusListener? to MultiParamLoader?.

Minor refactorization in MultiParamLoader?.

First step with auto append.

Add SchemaTest?.

Improve Registry.

Clean up in Registry.

Work out Registry.

Use annotations for Param.

Fix ListChange?.

Improve fluent interface of the FramsClassBuilder?.

Done caching of ReflectionAccess?.Backend

Fix hashCode of Pair.

A step on a way to cache ReflectionAccess?.Backend

Make SimpleAbstractAccess?.framsClass a final field.

Add static cache for FramsClasses? based on java.

Only classes created strictly and automatically
based on java classes are using this cache.

Make all Params immutable.

Many improvement to make Param immutable.

Make PrimitiveParam? generic type.

Several changes to make Param immutable.

Make FramsClass? immutable.

Another improvement to Path immutability.

Several improvements to Path.

Improve PathTest?.

Configurarable MutabilityDetector?.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • java/main/src/main/java/com/framsticks/parsers/Loaders.java

    r86 r87  
    1212
    1313        public static FramsClass loadFramsClass(SourceInterface source) throws ConstructionException {
    14                 MultiParamLoader loader = new MultiParamLoader();
     14                final MultiParamLoader loader = new MultiParamLoader();
    1515                loader.setNewSource(source);
    1616
    17                 FramsClass result = new FramsClass();
     17                final FramsClassBuilder builder = FramsClass.build();
    1818
    19                 AccessInterface framsClassAccess = new ReflectionAccess(FramsClass.class, FramsClassBuilder.buildForClass(FramsClass.class));
    20                 AccessInterface paramBuilderAccess = new ReflectionAccess(ParamBuilder.class, FramsClassBuilder.buildForClass(ParamBuilder.class));
    21                 framsClassAccess.select(result);
     19                final AccessInterface framsClassAccess = new ReflectionAccess(FramsClassBuilder.class, FramsClass.build().forClass(FramsClassBuilder.class));
     20                AccessInterface paramBuilderAccess = new ReflectionAccess(ParamBuilder.class, FramsClass.build().forClass(ParamBuilder.class));
     21                framsClassAccess.select(builder);
    2222                loader.addAccessInterface(framsClassAccess);
    2323                loader.addAccessInterface(paramBuilderAccess);
    2424
    25                 loader.addBreakCondition(MultiParamLoader.Status.AfterObject);
     25                loader.addListener(MultiParamLoader.Status.AfterObject, new MultiParamLoader.StatusListener() {
     26                        @Override
     27                        public void onStatusChange() {
     28                                Object object = loader.returnObject();
     29                                if (object instanceof FramsClassBuilder) {
     30                                        return;
     31                                }
     32                                if (framsClassAccess.select(builder).tryAutoAppend(object)) {
     33                                        return;
     34                                }
     35                                throw new ConstructionException().msg("failed to interpretate object").arg("object", object);
     36
     37                        }
     38                });
    2639
    2740                try {
    28                         MultiParamLoader.Status condition;
    29                         while ((condition = loader.go()) != MultiParamLoader.Status.Finished) {
    30                                 if (condition == MultiParamLoader.Status.AfterObject) {
    31 
    32                                         Object object = loader.returnObject();
    33                                         if (object instanceof FramsClass) {
    34                                                 continue;
    35                                         }
    36                                         if (object instanceof ParamBuilder) {
    37                                                 result.append(((ParamBuilder) object).finish());
    38                                         }
    39                                 }
    40                         }
    41                         return result;
     41                        loader.go();
     42                        return builder.finish();
    4243                } catch (Exception e) {
    4344                        throw new ConstructionException().msg("an error occurred while loading class description").arg("before", loader.getCurrentLine()).cause(e);
Note: See TracChangeset for help on using the changeset viewer.