Mercurial > projects > dwt2
view base/src/java/util/Hashtable.d @ 120:536e43f63c81
Comprehensive update for Win32/Linux32 dmd-2.053/dmd-1.068+Tango-r5661
===D2===
* added [Try]Immutable/Const/Shared templates to work with differenses in D1/D2 instead of version statements
used these templates to work with strict type storage rules of dmd-2.053
* com.ibm.icu now also compilable with D2, but not tested yet
* small fixes
Snippet288 - shared data is in TLS
===Phobos===
* fixed critical bugs in Phobos implemention
completely incorrect segfault prone fromStringz (Linux's port ruthless killer)
terrible, incorrect StringBuffer realization (StyledText killer)
* fixed small bugs as well
Snippet72 - misprint in the snippet
* implemented missed functionality for Phobos
ByteArrayOutputStream implemented (image loading available)
formatting correctly works for all DWT's cases
As a result, folowing snippets now works with Phobos (Snippet### - what is fixed):
Snippet24, 42, 111, 115, 130, 235, 276 - bad string formatting
Snippet48, 282 - crash on image loading
Snippet163, 189, 211, 213, 217, 218, 222 - crash on copy/cut in StyledText
Snippet244 - hang-up
===Tango===
* few changes for the latest Tango trunc-r5661
* few small performance improvments
===General===
* implMissing-s for only one version changed to implMissingInTango/InPhobos
* incorrect calls to Format in toString-s fixed
* fixed loading \uXXXX characters in ResourceBundle
* added good UTF-8 support for StyledText, TextLayout (Win32) and friends
UTF functions revised and tested. It is now in java.nonstandard.*Utf modules
StyledText and TextLayout (Win32) modules revised for UTF-8 support
* removed small diferences in most identical files in *.swt.* folders
*.swt.internal.image, *.swt.events and *.swt.custom are identical in Win32/Linux32
now 179 of 576 (~31%) files in *.swt.* folders are fully identical
* Win32: snippets now have right subsystem, pretty icons and native system style controls
* small fixes in snippets
Snippet44 - it's not Snippet44
Snippet212 - functions work with different images and offsets arrays
Win32: Snippet282 - crash on close if the button has an image
Snippet293 - setGrayed is commented
and others
Win32: As a result, folowing snippets now works
Snippet68 - color doesn't change
Snippet163, 189, 211, 213, 217, 218, 222 - UTF-8 issues (see above)
Snippet193 - no tabel headers
author | Denis Shelomovskij <verylonglogin.reg@gmail.com> |
---|---|
date | Sat, 09 Jul 2011 15:50:20 +0300 |
parents | 9f4c18c268b2 |
children |
line wrap: on
line source
module java.util.Hashtable; import java.lang.all; import java.util.Dictionary; import java.util.Map; import java.util.Enumeration; import java.util.Collection; import java.util.Set; // no nulls // synchronized class Hashtable : Dictionary, Map { public Object get(String key){ return super.get(key); } public Object put(String key, Object value){ return super.put(key, value); } public Object put(Object key, String value){ return super.put(key, value); } public Object put(String key, String value){ return super.put(key, value); } public Object remove(String key){ return super.remove(key); } Object[Object] map; // The HashMap class is roughly equivalent to Hashtable, except that it is unsynchronized and permits nulls. public this(){ } public this(int initialCapacity){ implMissing( __FILE__, __LINE__ ); } public this(int initialCapacity, float loadFactor){ implMissing( __FILE__, __LINE__ ); } public this(Map t){ implMissing( __FILE__, __LINE__ ); } class ObjectEnumeration : Enumeration { Object[] values; int index = 0; this( Object[] values ){ this.values = values; } public bool hasMoreElements(){ return index < values.length; } public Object nextElement(){ Object res = values[index]; index++; return res; } } Enumeration elements(){ return new ObjectEnumeration( map.values ); } Enumeration keys() { return new ObjectEnumeration( map.keys ); } public void clear(){ synchronized map = null; } public bool containsKey(Object key){ synchronized { if( auto v = key in map ){ return true; } return false; } } public bool containsKey(String key){ synchronized return containsKey(stringcast(key)); } public bool containsValue(Object value){ synchronized { foreach( k, v; map ){ if( v == value ){ return true; } } return false; } } public Set entrySet(){ implMissing( __FILE__, __LINE__ ); return null; } public equals_t opEquals(Object o){ implMissing( __FILE__, __LINE__ ); return 0; } public Object get(Object key){ synchronized { if( auto v = key in map ){ return *v; } return null; } } public hash_t toHash(){ implMissing( __FILE__, __LINE__ ); return 0; } public bool isEmpty(){ synchronized return map.length is 0; } public Set keySet(){ implMissing( __FILE__, __LINE__ ); return null; } public Object put(Object key, Object value){ synchronized { Object res = null; if( auto v = key in map ){ res = *v; } map[ key ] = value; return res; } } // public Object put(String key, Object value) // public Object put(Object key, String value) // public Object put(String key, String value) public void putAll(Map t){ synchronized implMissing( __FILE__, __LINE__ ); } public Object remove(Object key){ synchronized implMissing( __FILE__, __LINE__ ); return null; } // public Object remove(String key) public int size(){ synchronized return map.length; } public Collection values(){ implMissing( __FILE__, __LINE__ ); return null; } // only for D public int opApply (int delegate(ref Object value) dg){ implMissing( __FILE__, __LINE__ ); return 0; } public int opApply (int delegate(ref Object key, ref Object value) dg){ implMissing( __FILE__, __LINE__ ); return 0; } }