Bladeren bron

Class comment added to Set.

Herbert Vojčík 12 jaren geleden
bovenliggende
commit
1d5089dc94
2 gewijzigde bestanden met toevoegingen van 18 en 2 verwijderingen
  1. 1 1
      js/Kernel-Collections.js
  2. 17 1
      st/Kernel-Collections.st

+ 1 - 1
js/Kernel-Collections.js

@@ -5454,7 +5454,7 @@ smalltalk.String.klass);
 
 
 smalltalk.addClass('Set', smalltalk.Collection, ['defaultBucket', 'slowBucketStores', 'fastBuckets', 'size'], 'Kernel-Collections');
-smalltalk.Set.comment="I represent an unordered set of objects without duplicates.";
+smalltalk.Set.comment="I represent an unordered set of objects without duplicates.\x0a\x0a## Implementation notes\x0a\x0aI put an element to different stores based on its type.\x0aThe goal is to store some elements into native JS object property names to be fast.\x0a\x0aIf an unboxed element has typeof 'string', 'boolean' or 'number', or an element is nil, null or undefined,\x0aI store it as a property name in an empty (== Object.create(null)) JS object, different for each type\x0a(for simplicity, nil/null/undefined is treated as one and included with the two booleans).\x0a\x0aIf element happen to be an object, I try to store them in ArrayBucketStore. I have two of them by default,\x0aone hashed using Smalltalk class name, other using JS constructor name. It is possible to have more or less\x0aof ArrayBucketStores, see #initializeSlowBucketStores.\x0a\x0aAs a last resort, if none of the ArrayBucketStore can find suitable bucket, the defaultBucket is used,\x0awhich is an Array.\x0a";
 smalltalk.addMethod(
 smalltalk.method({
 selector: "=",

+ 17 - 1
st/Kernel-Collections.st

@@ -1822,7 +1822,23 @@ Collection subclass: #Set
 	instanceVariableNames: 'defaultBucket slowBucketStores fastBuckets size'
 	package: 'Kernel-Collections'!
 !Set commentStamp!
-I represent an unordered set of objects without duplicates.!
+I represent an unordered set of objects without duplicates.
+
+## Implementation notes
+
+I put an element to different stores based on its type.
+The goal is to store some elements into native JS object property names to be fast.
+
+If an unboxed element has typeof 'string', 'boolean' or 'number', or an element is nil, null or undefined,
+I store it as a property name in an empty (== Object.create(null)) JS object, different for each type
+(for simplicity, nil/null/undefined is treated as one and included with the two booleans).
+
+If element happen to be an object, I try to store them in ArrayBucketStore. I have two of them by default,
+one hashed using Smalltalk class name, other using JS constructor name. It is possible to have more or less
+of ArrayBucketStores, see #initializeSlowBucketStores.
+
+As a last resort, if none of the ArrayBucketStore can find suitable bucket, the defaultBucket is used,
+which is an Array.!
 
 !Set methodsFor: 'accessing'!