blob: 1bc31c5c433b232cd7a105e11cd39950aaf4e2f6 [file] [log] [blame]
Karl Paulsfae65682015-06-14 22:31:23 +00001Changes from 5.0.0 to 5.0.1
2---------------------------
3** Bug
4 * [FELIX-4867] - Stale bundle revisions don't get cleaned up when last using bundle is gone
5 * [FELIX-4905] - Framework does not export org.osgi.service.resolver
6 * [FELIX-4914] - Resolution problem with identity requirements on fragments
7 * [FELIX-4927] - Felix reports itself as an OSGi R4/R5 Framework
8
9** Improvement
10 * [FELIX-4866] - Improve service registry
11
Karl Pauls829fff12015-04-20 12:01:26 +000012Changes from 4.6.1 to 5.0.0
13---------------------------
14** Bug
15 * [FELIX-4838] - Deadlock in Service Registry
16 * [FELIX-4850] - org.osgi.framework.version should be 1.8
17 * [FELIX-4854] - Unable to create consistent wiring when same package is exported in same version by multiple bundles
18
19** Improvement
20 * [FELIX-4821] - Use a faster implementation for StringMap
21 * [FELIX-4845] - Clean up Logger implementation
22 * [FELIX-4525] - Refactor the Framework to use the Resolver module
23
Karl Pauls5063d832015-03-03 10:10:29 +000024Changes from 4.6.0 to 4.6.1
25---------------------------
26** Bug
27 * [FELIX-4806] - Ungetting service through ServiceObjects might throw IllegalArgumentException
28
29** Improvement
30 * [FELIX-4810] - Cache WeakZipFile#entries
31
Karl Paulsf1f665a2015-01-11 23:57:18 +000032Changes from 4.4.1 to 4.6.0
33---------------------------
34** Sub-task
35 * [FELIX-4503] - [Core R6] Support osgi.native capability
36 * [FELIX-4504] - [Core R6] Support Framework DTOs
37 * [FELIX-4505] - [Core R6] Support Prototype Service Factory
38 * [FELIX-4578] - [Core R6] Support new Framework.init(FrameworkListener ... listeners) override
39 * [FELIX-4579] - [Core R6] Support Framework Extension Bundle Activators
40 * [FELIX-4580] - [Core R6] Support service.bundleid Service Registration property
41 * [FELIX-4581] - [Core R6] Support FrameworkWiring.findProviders(Requirement)
42 * [FELIX-4582] - [Core R6] Support WovenClassListener
43 * [FELIX-4583] - [Core R6] Ensure that all OSGi Core R6 CT tests pass
44 * [FELIX-4590] - [Core R6] Update to R6 API
45 * [FELIX-4593] - Support the JavaSE/compact profiles for Java 8
46 * [FELIX-4726] - [Core R6] Update bundle and service hooks for the system bundle
47
48** Bug
49 * [FELIX-3883] - [Framework] Move OS and processor aliases to configuration properties
50 * [FELIX-4690] - Some bundles containing native code can fail to start on Windows 7+
51 * [FELIX-4701] - Properties with surprising spelling in AutoProcessor
52 * [FELIX-4729] - [Core R6] Support for osgi.native namespace with Loading native code libraries
53
54** Improvement
55 * [FELIX-4502] - [Core R6] Provide an OSGi R6 compliant framework implementation
56 * [FELIX-4658] - URL of the CodeSource of a ProtectionDomain should resolve to the right JAR
57 * [FELIX-4692] - Improve Service access time
58 * [FELIX-4757] - Native Capabilities should allow OS and Processor alias to load from default and config properties
59
Karl Pauls628dbbc2014-07-09 16:36:34 +000060Changes form 4.4.0 to 4.4.1
61---------------------------
62** Bug
63 * [FELIX-3239] - PackageAdmin#getExportedPackages does not work on packages exported by attached fragments
64 * [FELIX-3309] - Dashes in qualifier get replaced by periods causing framework not to start up
65 * [FELIX-3701] - Intermittent CNFE with embedded jars in Fragment Bundles
66 * [FELIX-4220] - BundleException type is always set to 0
67 * [FELIX-4281] - Security Warning: Felix with Java Web Start
68 * [FELIX-4515] - BundleRevision for system extension has no capabilities
69 * [FELIX-4523] - Deadlock in URLHandlers when Felix.init and Felix.stop are called concurrently
70 * [FELIX-4534] - Bundles containing native code fails to start on Windows 7
71
Karl Paulse1d8c702014-03-20 21:50:06 +000072Changes from 4.2.1 to 4.4.0
73---------------------------
74** Bug
75 * [FELIX-1131] - ServiceReference.isAssignableTo fails when using a factory that can not see the exported class and the bundle exporting the service does not have a direct wire to this class
76 * [FELIX-3992] - Classloader access outside of a privileged block
77 * [FELIX-4190] - The framework should not hold any lock while calling ServiceFactory#unget
78 * [FELIX-4283] - actually throw exception if method not found
79 * [FELIX-4331] - [Core R5] Support BundleContext and Framework adaptations
80 * [FELIX-4353] - [Core R5] BundleWiringTests OSGi CT test failures
81 * [FELIX-4354] - [Core R5] ResolverHookTests OSGi CT test failures
82 * [FELIX-4355] - [Core R5] org.osgi.test.cases.framework.launch OSGi CT test failure
83 * [FELIX-4365] - Input stream not properly closed on org.apache.felix.framework.Felix.getFrameworkVersion
84 * [FELIX-4388] - Initial start level not considered when bundle.start() is called
85 * [FELIX-4462] - Classloader deadlock in Java6 between two bundles
86
87** Improvement
88 * [FELIX-4128] - [Core R5] Provide an OSGi R5 compliant framework implementation
89 * [FELIX-4284] - remove dead allocation
90
91** Task
92 * [FELIX-4080] - [Core R5] Add support for org.osgi.framework.UnfilteredServiceListener
93 * [FELIX-4082] - [Core R5] Update org.osgi.framework.bsnversion framework property
94 * [FELIX-4083] - [Core R5] Support for valueOf when evaluating a Filter
95 * [FELIX-4084] - [Core R5] Enhance Bundle.adapt() to provider AccessControlContext.
96 * [FELIX-4085] - [Core R5] Implement updates to the Bundle Hook Specification
97 * [FELIX-4324] - [Core R5] Implement osgi.identity namespace for fragments
98
99** Wish
100 * [FELIX-3868] - Adding osgi.identity namespace to bundles (resources)
101
Karl Paulsa2364072013-03-08 20:56:35 +0000102Changes from 4.2.0 to 4.2.1
103---------------------------
104** Bug
105 * [FELIX-3411] - The implementation of org.osgi.service.startlevel.StartLevel#setStartLevel(int) does not follow the spec
106 * [FELIX-3893] - Bundle in cache doesn't pass security check anymore.
107 * [FELIX-3907] - NullPointerException in BundleWiringImpl when m_disposed is true.
108 * [FELIX-3939] - IllegalArgumentException from ClassLoader.definePackage
109 * [FELIX-3950] - Permission check being done even when security manager is absent
110 * [FELIX-3957] - Error events can be thrown when refreshing fragment bundles
111
112** Improvement
113 * [FELIX-3961] - Add a fallback to the default java security policy if no security provider is present
114
Karl Pauls97262fe2013-02-05 22:48:47 +0000115Changes from 4.0.3 to 4.2.0
116---------------------------
117** Bug
118 * [FELIX-2780] - Extension bundle implementation relies on urlhandlers service to start extension bundles
119 * [FELIX-3160] - NPE in BundleRevisionImpl.close() when uninstalling a bundle
120 * [FELIX-3242] - Concurrent modification problem in StatefulResolver$ResolverStateImpl.getCandidates
121 * [FELIX-3273] - Possible exception when accessing headers
122 * [FELIX-3306] - Lazy activation of bundles is not always working as expected
123 * [FELIX-3343] - Installing an fragment bundle without Bundle-ManifestVersion: 2 causes NPE in resolver
124 * [FELIX-3348] - StartLevel thread may terminate on uncaught exception
125 * [FELIX-3353] - The implementation of org.osgi.service.packageadmin.PackageAdmin#getExportedPackages(Bundle), does not follow the spec.
126 * [FELIX-3367] - getClassloader permission
127 * [FELIX-3397] - NPE when trying to resolve invalid fragments
128 * [FELIX-3411] - The implementation of org.osgi.service.startlevel.StartLevel#setStartLevel(int) does not follow the spec
129 * [FELIX-3413] - NPE and thread blocked in org.osgi.service.packageadmin.PackageAdmin#refreshPackages(Bundle[])
130 * [FELIX-3455] - Framework JARs for JDK 7
131 * [FELIX-3465] - Multi root resolve operations may cause duplicate blame chains to be created
132 * [FELIX-3618] - [Framework] Should not allow bundles to use generic cap/req headers for osgi.wiring.* namespaces
133 * [FELIX-3626] - Issue of felix on android 4.1
134 * [FELIX-3632] - [Framework] Parsing of delimited strings in manifest parser collapses all consecutive escapes
135 * [FELIX-3670] - PackageAdmin.isBundleType throws NPE for uninstalled bundle
136 * [FELIX-3713] - Bundle.start() returns without starting the bundle
137 * [FELIX-3743] - Potential endless loop setting the active framework startlevel
138 * [FELIX-3753] - Felix crashes when embedded within Felix
139 * [FELIX-3761] - When a bundle registers a service, the bundle lock is obtained without any real purpose
140 * [FELIX-3766] - Slightly invalid logic for pre-checking dynamic imports which cause the framework the grab the lock with no real need
141 * [FELIX-3803] - Bundle#getResource always try to resolve the bundle
142 * [FELIX-3824] - Possible InvalidStateException thrown while unregistering bundle services
143 * [FELIX-3840] - problem with URLHandlers when running 2 frameworks in one jvm in separate class loaders
144 * [FELIX-3844] - Native bundles cannot be installed on Windows 8 and Windows Server 2012
145 * [FELIX-3852] - InstallBundle throws ClassCastException: java.util.jar.Attributes$Name cannot be cast to java.lang.String
146 * [FELIX-3887] - ClassCastException during resolution of Require-Bundle: system.bundle
147
148** Improvement
149 * [FELIX-3344] - [Framework] Filter parsing treats ** as invalid syntax
150 * [FELIX-3372] - Add the ability to handle a blank on the property "org.osgi.framework.system.packages.extra"
151 * [FELIX-3394] - [Framework] Refactor internal resolver APIs to better align with upcoming OSGi resolver spec
152 * [FELIX-3447] - Optimize read only collections by using a specific class and not a wrapper which is slower
153 * [FELIX-3553] - Use of parallel class loading capability of JDK7
154 * [FELIX-3609] - Small optimizations
155 * [FELIX-3611] - Bundle certificates are not added to the CodeSource when building the BundleProtectionDomain
156 * [FELIX-3807] - Refreshing bundles should first grab all the bundle locks to avoid concurrent modifications of those bundles
157
158** New Feature
159 * [FELIX-3504] - [Framework] Move to OSGi R5 packages
160
161** Task
162 * [FELIX-3786] - Create system package definintions for Java 8
163
164
165Changes from 4.0.2 to 4.0.3
166---------------------------
167
168** Bug
169 * [FELIX-3003] - NPE in ResolverImpl.permutateIfNeeded
170 * [FELIX-3296] - URLHandlers caches null as values for common protocols
171 * [FELIX-3302] - Adapt the URLHandlers for the 4.0 refactoring
172 * [FELIX-3363] - Native bundles cannot be installed on Windows Server 2008 r2 with the tag win32
173 * [FELIX-3393] - Possible deadlock with reentrant calls
174 * [FELIX-3572] - [Framework] Resolver is not checking package space consistency for dynamic imports
175
176** Improvement
177 * [FELIX-3262] - Startup delay due to URLHandlersBundleStreamHandler
178
Karl Paulsf506dac2011-11-20 20:57:46 +0000179Changes from 4.0.1 to 4.0.2
180---------------------------
181
182** Bug
183 * [FELIX-3178] - NPE in ResolverImpl
184 * [FELIX-3194] - [Framework] Manifest parser is not correctly handling escapes
185 * [FELIX-3205] - Error resolving system.bundle dependencies
186 * [FELIX-3207] - Improper handling of nulls and substring matching at CapabilitySet/SimpleFilter
187 * [FELIX-3211] - org.apache.felix.framework.cache.BundleCache.deleteDirectoryTreeRecursive throws NPE
188 * [FELIX-3220] - Multiple ClassCastException(s) when invoking OSGi Service-Hooks (EventHook, FindHook)
189
190** Improvement
191 * [FELIX-3166] - Make Felix compile within Eclipse
192
193** New Feature
194 * [FELIX-3156] - Implement Bundle::getDataFile and Bundle::compareTo
195
Karl Pauls9e4fa062011-10-10 20:28:23 +0000196Changes from 4.0.0 to 4.0.1
197---------------------------
198
199** Bug
200 * [FELIX-3137] - [Framework] Capabilities from resolved singleton bundles are not indexed correctly
201 * [FELIX-3150] - Filter parameter is ignored at getServiceReferences
202 * [FELIX-3153] - [Framework] refreshPackages() should stop bundles in one pass and refresh them in a second pass
203
204** Improvement
205 * [FELIX-3138] - [Framework] Refactor some unnecessary code in the resolver
206 * [FELIX-3141] - [Framework] Framework should filter removal pending fragments not the resolver
207
Karl Pauls070bdc62011-09-22 14:49:45 +0000208Changes from 3.2.2 to 4.0.0
Karl Pauls73f01362011-09-22 13:29:22 +0000209---------------------------
210
211** Bug
212 * [FELIX-2762] - Substring parser incorrectly disallowing use of parentheses characters
213 * [FELIX-2990] - [Framework] Bug introduced into handling of native libraries during a fresh
214 * [FELIX-3015] - [Framework] Provide org.osgi.util.tracker version 1.5
215 * [FELIX-3033] - [Framework] Service registry hooks are not correctly filtering bundle contexts for event hook
216 * [FELIX-3038] - Framework does not offer J2SE-1.2 Execution Environment
217 * [FELIX-3043] - [Framework] Resolver is not correctly resolving fragments in all cases
218 * [FELIX-3059] - Reexported packages are not calculate correctly leading to resolver and class loading bugs
219 * [FELIX-3062] - [Framework] Resolver gets into infinite loop in the face of a require-bundle cycle
220 * [FELIX-3082] - [Framework] Bundles not allowed to add listeners while in STOPPING state
221 * [FELIX-3085] - Importing/exporting "." should not be allowed
222 * [FELIX-3096] - Could not add FrameworkListener from ServiceListener
223
224** Improvement
225 * [FELIX-2467] - The framework extensions should be returned when invoking the method PackageAdmin#getFragments with the system bundle
226 * [FELIX-2572] - JRE system packages should include "uses" constraints
227 * [FELIX-2950] - [Framework] Adopt OSGi R4.3 API as framework internal API
228 * [FELIX-2998] - [Framework] OSGi R4.3 changed filter handling of exceptions when calling equals()/compare() to return false
229 * [FELIX-3000] - Move sending service registered event out of bundle lock
Karl Pauls73f01362011-09-22 13:29:22 +0000230 * [FELIX-3071] - [Framework] It should be possible to limit number of open JAR files
231 * [FELIX-3125] - [Framework] Use single file per bundle in bundle cache by default
232
233** New Feature
234 * [FELIX-2959] - [Framework] Implement OSGi R4.3 class loader byte-code weaving hook
235 * [FELIX-2969] - [Framework] Implement OSGi R4.3 framework wiring object
236 * [FELIX-2973] - [Framework] Implement OSGi R4.3 generic capabilities and requirements
237 * [FELIX-2975] - [Framework] Implement OSGi R4.3 framework start level object
238 * [FELIX-2986] - [Framework] Implement OSGi R4.3 resolver hooks
239 * [FELIX-2999] - [Framework] OSGi R4.3 now specifies that number types should be trimmed when evaluating filters
240 * [FELIX-3032] - [Framework] Implement OSGi R4.3 bundle hooks
241 * [FELIX-3052] - [Framework] Implement OSGi R4.3 system bundle generic capabilities
242 * [FELIX-3056] - [Framework] Implement OSGi R4.3 event listener service registry hook
243 * [FELIX-3122] - [Framework] Implement OSGi R4.3 framework UUID
244 * [FELIX-3124] - [Framework] Implement OSGi R4.3 property to allow installing bundles with the same BSN and version
245
246** Task
247 * [FELIX-3110] - [Framework] Implement 4.3 security checks
248
249
Karl Paulsda9871c2011-05-11 19:16:20 +0000250Changes from 3.2.1 to 3.2.2
251---------------------------
252
253** Bug
254 * [FELIX-2935] - Bundle.getEntryPaths and findEntries are returning META-INF/ multiple times
255 * [FELIX-2941] - Felix Framework 3.2.0 and Framework Security 1.4.2 fails OSGI Conditional Permission Admin CT when running on IBM JVM 5 and 6.
256 * [FELIX-2942] - Bundles with higher start level get activated even before framework reaches that start level
257
258
Karl Pauls3f5c19b2011-04-18 21:33:22 +0000259Changes from 3.2.0 to 3.2.1
260---------------------------
261
262* Bug
263 * [FELIX-2901] - [Framework] NPE from a host bundle during framework shutdown
264 * [FELIX-2917] - Constructor of SecurityExceptino() which is incompatible to 1.4 is used
Karl Pauls5a179f22011-04-26 20:58:15 +0000265 * [FELIX-2924] - bundle stop hangs for http-2.2.0 in felix-3.2.0
Karl Pauls3f5c19b2011-04-18 21:33:22 +0000266
267** Improvement
268 * [FELIX-2909] - [Framework] Resolver could be more efficient if it detected if fragments were present
269
270
Karl Paulsda84e132011-03-28 20:00:25 +0000271Changes from 3.0.9 to 3.2.0
272---------------------------
273
274* Bug
275 * [FELIX-1816] - deadlock on SystemBundle.stop()
276 * [FELIX-2741] - NPE in ResolverImpl.calculatePackageSpaces
277 * [FELIX-2748] - Possible synchronization issue with BundleContext.getBundle()
278 * [FELIX-2877] - java6 update 24 breaks felix when used inside webstart
279
280
281** Improvement
282 * [FELIX-2858] - [Framework] Modify resolver to be self-contained with respect to fragment handling
283 * [FELIX-2859] - [Framework] Modify resolver to be self-contained with respect to singleton handling
284 * [FELIX-2864] - [Framework] Add package profile for JDK7 to default properties
285
Karl Paulsc52f6172011-02-21 21:48:19 +0000286Changes from 3.0.8 to 3.0.9
287---------------------------
288
289** Bug
290 * [FELIX-1581] - Bundle#update, Bundle#uninstall and Bundle#stop should wait for a (configurable) timeout before throwing an exception if the bundle is starting or stopping
291 * [FELIX-2784] - When the framework try to grab the bundle lock, it ignores thread interruption
292 * [FELIX-2822] - [Framework] System bundle module's state not reset when framework restarted leading to NPE
293 * [FELIX-2832] - [Framework] It should not be possible to open an URLConnection to "/" for a bundle URL
294 * [FELIX-2840] - [Framework] Uninstalling an uninstalled bundle throws NoSuchElementException
295 * [FELIX-2849] - PackageAdmin is inconsistent between getFragments and getHosts
296 * [FELIX-2850] - PackageAdmin return fragments / hosts even if the host isn't resolved
297 * [FELIX-2851] - Resolution problems after a fragment can't be resolved
298
299** Improvement
300 * [FELIX-2841] - [Framework] Improve resolve exception messages
301
Richard S. Hall8fe08db2011-02-21 14:38:03 +0000302Changes from 3.0.7 to 3.0.8
303---------------------------
304
305** Bug
306 * [FELIX-2749] - Boolean.parseBoolean() newly defined in Java5 should not be used.
307 * [FELIX-2789] - Native library matching is not correctly checking additional extensions
308 * [FELIX-2800] - Logging will throw an NPE if no bundle is specified
309 * [FELIX-2802] - A failed update doesn't rollback properly
310 * [FELIX-2805] - Cache PackageAdmin.getBundle() result for system bundle classes
311
Karl Pauls279d5412010-12-26 21:09:17 +0000312Changes from 3.0.6 to 3.0.7
313---------------------------
314
315** Bug
316 * [FELIX-2456] - Framework no longer fires UNRESOLVED event when a bundle is explicitly refreshed
317 * [FELIX-2693] - [Framework] Service registry should throw a ServiceException for factories resulting in a cycle
318 * [FELIX-2700] - Framework uses java.nio package which is not supported by CDC VM
319 * [FELIX-2710] - [Framework] For exploded bundles Bundle.getEntry("a/b.jar/")==Bundle.getEntry("a/b.jar")
320 * [FELIX-2717] - [Framework] Resolver treats multiple exports of same package as conflicting for fragment imports
321 * [FELIX-2725] - [Framework] Resolver is not correctly calculating exported packages for already resolved modules
322 * [FELIX-2728] - JarRevision does not close URLConnections which are instances of HttpURLConnection
323 * [FELIX-2736] - [Framework] Resolver is not correctly verifying package space consistency for dynamic imports
324 * [FELIX-2738] - [Framework] DirectoryContent does not handle security correctly
325
326** Improvement
327 * [FELIX-2703] - [Framework] Include OSGi/Minimum EEs in default properties
328 * [FELIX-2721] - [Framework] Implement custom manifest parser and avoid JarFile
329 * [FELIX-2737] - [Framework] Optimize resolver algorithm by not re-calculating uses constraints for resolved modules
330
Karl Paulsdb2cbc02010-11-03 21:03:40 +0000331Changes from 3.0.5 to 3.0.6
332---------------------------
333
334** Bug
335 * [FELIX-2670] - [Framework] Implicit boot delegation doesn't delegate for external code in all cases
336 * [FELIX-2683] - [Framework] Bundle last modified time is not persisted on deployment
337
338** Improvement
339 * [FELIX-2560] - Bundle URLs do not survive refreshes
340
341** New Feature
342 * [FELIX-2646] - [Framework] Locking could be used to prevent concurrent access to a single bundle cache
343
Karl Pauls5dfa2a02010-10-18 21:58:01 +0000344Changes from 3.0.4 to 3.0.5
345---------------------------
346
347** Bug
348 * [FELIX-2653] - LinkageError caused by duplicate class definition during implicit boot delegation
349
350** Improvement
351 * [FELIX-2645] - Add a (hidden) way to retrieve a local URL for a given bundle URL
352 * [FELIX-2654] - [Framework] Modify bundle cache to use a single file per bundle state
353
Karl Paulse74c2482010-10-04 20:35:42 +0000354Changes from 3.0.3 to 3.0.4
355---------------------------
356
357** Bug
358 * [FELIX-2584] - No FrameworkEvent.ERROR on unchecked exception in event listener
359 * [FELIX-2629] - [Framework] Module class loader should return an empty enumeration for getResources()
360
361** Improvement
362 * [FELIX-2619] - [Framework] Bundle cache is rechecking nonexistent files again and again
363 * [FELIX-2626] - [Framework] Bundle cache is rewriting some files when restarting bundles
364
Karl Pauls4ca14822010-09-22 20:37:21 +0000365Changes from 3.0.2 to 3.0.3
366---------------------------
367
368** Bug
369 * [FELIX-2548] - Resolver should use case sensitive indexing for capabilities
370 * [FELIX-2569] - Felix bundle classloader always delegates to parent loader in getResources()
371 * [FELIX-2589] - SecurityException "SecurityManager already installed" is thrown when calling Framework.init() multiple times with FRAMEWORK_SECURITY set
372 * [FELIX-2598] - Hang in Felix: thread owing a bundle lock waits for ever to lock it again
373 * [FELIX-2599] - When specifying the packages exported by the system bundle, attributes and directives on packages do not show up in the system bundle headers
374
375** Improvement
376 * [FELIX-1022] - Classloader Exceptions should be more informative
377 * [FELIX-2549] - Fix some synchronization issues in content handling
378 * [FELIX-2555] - Log messages should contain the bundle id, when available
379 * [FELIX-2597] - Deadlock during delivery of resolved event
380
Karl Pauls7fd85ce2010-08-18 20:41:35 +0000381Changes from 3.0.1 to 3.0.2
382---------------------------
383
384** Bug
385 * [FELIX-2421] - Implicit bootdelegation doesn't ignore classloaders if they are inner classes
386 * [FELIX-2437] - Deadlock on refrsh Import and refresh
387 * [FELIX-2451] - Felix uses System.out to print debug messages related to resolver...
388 * [FELIX-2459] - Wrong error message on a missing package
389 * [FELIX-2466] - Unknown attributes are not stripped from Fragment-Host header
390 * [FELIX-2473] - Subtring matching is incorreclty matching against an empty string
391 * [FELIX-2479] - Required bundles not correctly re-exporting their substitutable exports
392
393** Improvement
394 * [FELIX-2528] - Potential performance issue in resolver when uses constraint conflict is detected
395 * [FELIX-2529] - In some scenarios the resolver will not backtrack on imported package decisions
396
Karl Pauls5fb43302010-06-14 20:13:54 +0000397Changes from 3.0.0 to 3.0.1
398---------------------------
399
400** Bug
401 * [FELIX-2401] - NPE in org.apache.felix.framework.FilterImpl.DictionaryCapability.getAttribute(String)
402
Karl Paulsf4ea0312010-06-06 21:55:08 +0000403Changes from 2.0.5 to 3.0.0
404---------------------------
405** Sub-task
406 * [FELIX-2036] - Improve resolver's generic capability/requirement model
407 * [FELIX-2037] - Improve resolver performance by making solution space searching smarter
408
409** Bug
410 * [FELIX-995] - JRE packages are exported with wrong version
411 * [FELIX-1967] - Freeze finding consistent class space
412 * [FELIX-2080] - Updating bundles when debugging switched on might result in a deadlock with 100% CPU usage
413 * [FELIX-2150] - URLStreamHandlerProxy.setURL may not set query component correctly
414 * [FELIX-2172] - Extremely long resolve stage when running CXF-DOSGi system test
415 * [FELIX-2177] - Fragment bundles not loaded after second start when using autodeploy
416 * [FELIX-2271] - CLONE -NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
417 * [FELIX-2273] - getClassLoader-permission required accessing classes from dynamically loaded class
418 * [FELIX-2281] - Bundle id order affects fragment resolution success
419 * [FELIX-2317] - Possible NPE for jars with null Manifest
420 * [FELIX-2321] - BundleException type should be properly set when installing a duplicate bundle
421 * [FELIX-2332] - Lots of contention on ExtensionManager.openConnection(URL)
422 * [FELIX-2335] - Bundle.loadClass() for system bundle doesn't obey boot delegation
423 * [FELIX-2356] - extension bundle cannot load class from embed jar
424 * [FELIX-2383] - Bundles are restarted during start level change
425 * [FELIX-2392] - Felix framework uses a Java5 method
426
427** Improvement
428 * [FELIX-1210] - Allow jars with missing intermediate entries to be handled as if they were present in Bundle.getEntryPaths
429 * [FELIX-1797] - Customizable Framework startup message
430 * [FELIX-2035] - Reimplement framework resolver
431 * [FELIX-2039] - Reimplement standard OSGi LDAP filter to use new filter solution for resolver
432 * [FELIX-2040] - Modify framework service registry to use resolver's new capability/requirement model
433 * [FELIX-2041] - Look into using generics in framework code
434 * [FELIX-2042] - Use Gogo as the default shell for the framework distribution
435 * [FELIX-2324] - Support execution environment so that OBR works properly
436 * [FELIX-2336] - Variable substitution in configuration files should ignore mismatched delimiters
437
438Changes from 2.0.4 to 2.0.5
439---------------------------
440** Bug
441 * [FELIX-1753] - The start level should check that the bundle still exists before starting it to avoid an ugly exception
442 * [FELIX-2087] - NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
443 * [FELIX-2107] - Bundle.findEntries() matches '*<filePattern>' instead of '<filePattern>'
444 * [FELIX-2195] - Using URLDecoder.decode on locations is wrong
445 * [FELIX-2222] - Failure to reinstall a cached bundle will corrupt the bundle cache
446
Karl Paulsc6eda452010-02-14 22:52:56 +0000447Changes from 2.0.3 to 2.0.4
448---------------------------
449
450** Bug
451 * [FELIX-2056] - URLHandlersStreamHandler not getting handlers from frameworks that are inside a different classloader
452 * [FELIX-2067] - Fragment bundle ignored silently when the host Bundle-SymbolicName equals import package name
453 * [FELIX-2073] - The System Bundle is not providing WS Addressing
454
455** Improvement
456 * [FELIX-2071] - Missing checks inside ModuleImpl (in Framework) which causes exceptions
457
458Changes from 2.0.2 to 2.0.3
459---------------------------
460
461** Bug
462 * [FELIX-1838] - PackageAdmin.getExportedPackages() duplicates output for packages with different version
463 * [FELIX-1867] - ModuleImpl diagnoseClassLoadError throw NullPointerException for empty package name in debug mode
464 * [FELIX-1917] - A few minor bugs in the framework found while embedding Felix
465 * [FELIX-1919] - Fragment bundle cannot be linked to its host
466 * [FELIX-1920] - RequiredBundle.getRequiringBundles() incorrectly calculates result
467 * [FELIX-1929] - getStartLevel() always reports requested start level, not active start level
468 * [FELIX-1982] - Documented but uninterpreted felix.cache.* properties
469 * [FELIX-1998] - Use UTF-8 when decoding reference location URLs
470 * [FELIX-2002] - Uninstalled fragments are not properly detached
471
472** Improvement
473 * [FELIX-37] - Implement security for bundle resource URLs
474 * [FELIX-325] - Factor out security checks from the framework/system bundle code
475 * [FELIX-1973] - Implement all required security checks
476
477** New Feature
478 * [FELIX-30] - Implement extension bundles
479 * [FELIX-1991] - Allow boot delegation class loader to be configurable per bundle
480
481
482Changes from 2.0.1 to 2.0.2
483---------------------------
484
485** Bug
486 * [FELIX-1754] - Usage of BundleContext.getServiceReferences results in failure to activate components
487 * [FELIX-1782] - Errors during start-up on gnu/classpath based VMs (jamvm, kaffe, cacao) and mika
488 * [FELIX-1795] - Bundle version ignored in Fragment-Host header
489 * [FELIX-1834] - java.io.IOException: No framework context found when embedding felix frameworks as bundles
490
491** Improvement
492 * [FELIX-1534] - Improve fragment merging
493 * [FELIX-1781] - Try to reduce object allocations/usage in resolver algorithm
494 * [FELIX-1783] - Eliminate contention on ServiceRegistry.getServiceReferences(String, Filter)
495
496Changes from 2.0.0 to 2.0.1
497---------------------------
498
499** Bug
500 * [FELIX-1565] - Deadlock UrlHandlers
501 * [FELIX-1573] - Occasional NPE in URLHandlersBundleStreamHandler
502 * [FELIX-1580] - Regression with native library handling
503 * [FELIX-1586] - Framework reports org.osgi.framework.version as 1.3
504 * [FELIX-1600] - ServiceReference.isAssignableTo() always returns true if requesting bundle has no wire
505 * [FELIX-1631] - Implicit bootdelegation causes hang on android
506 * [FELIX-1710] - Resolver still does not discard all partial results when a cyclical dependency fails
507 * [FELIX-1721] - Framework boot delegation has a bug due to extraneous code
508 * [FELIX-1731] - Native library extraction could be improved to help cases where there are dependencies among libraries
509
510** Improvement
511 * [FELIX-1619] - Change the default auto-deploy actions to be install and start only
512 * [FELIX-1625] - Refactor bundle cache to simplify management
513 * [FELIX-1679] - VersionRange class should use finals to be thread safe.
514 * [FELIX-1724] - Various module metadata should be cached
515
516** Task
517 * [FELIX-1617] - Modify framework, main, shell, shell.tui, and obr to depend on official OSGi JAR files
518
519Changes from 1.8.1 to 2.0.0
520---------------------------
521
522** Bug
523 * [FELIX-893] - Felix fails to start using J9 JVM
524 * [FELIX-905] - Felix needs an RFC 126 FindHook
525 * [FELIX-906] - Felix needs an RFC 126 EventHook
526 * [FELIX-1122] - Extension bundles are not being removed from the bundle list when uninstalled
527 * [FELIX-1123] - System bundle does still not correctly handle (export) package attributes
528 * [FELIX-1124] - ResourceNotFoundException too verbose
529 * [FELIX-1130] - Bundle.getHeaders() returns a Dictionary<java.util.jar.Attribute.Name,String>
530 * [FELIX-1138] - URL Handlers performance regression due to service lookups
531 * [FELIX-1170] - MemoryLeak when stopping and restarting Felix
532 * [FELIX-1187] - BundleContext.ungetService() should return false only if the usage count is zero when the method is invoked
533 * [FELIX-1197] - Bundle Fragments not resolved correctly
534 * [FELIX-1198] - config.properties still refers to old org.osgi.framework.startlevel property
535 * [FELIX-1247] - BundleEvent.UNRESOLVED should be fired during update/uninstall not refresh
536 * [FELIX-1249] - Bundle.findEntries() should search fragments as well as the bundle itself
537 * [FELIX-1254] - Bundle#findEntries does not return resources from fragments
538 * [FELIX-1271] - Improve manifest localization to handle special cases
539 * [FELIX-1272] - Need to special case getResource()/getResources()/loadClass() for fragment bundles
540 * [FELIX-1273] - Bundle.getResources() should return null for a non-existent resource
541 * [FELIX-1277] - Fix Service Hooks Tests failures in RFC 126 TCK
542 * [FELIX-1279] - Framework.waitForStop() does not obey timeout
543 * [FELIX-1280] - Package Admin - getExportedPackages must return null instead of an empty array
544 * [FELIX-1285] - SecureAction captures the calling context incorrectly
545 * [FELIX-1286] - Module class loader should use secure action instead of a privileged block
546 * [FELIX-1287] - System bundle operations from RFC-132 (e.g., init(), start(), stop(), waitForStop()) are using wrong lock object
547 * [FELIX-1288] - System bundle context should be null after stopping the framework
548 * [FELIX-1292] - PackageAdmin.getBundle(Class) should return null if the bundle associated with the passed in class is from another framework
549 * [FELIX-1293] - StringMap used for case insensitive properties does not respect ordering if case sensitivity is changed
550 * [FELIX-1295] - ServiceRegistry increments/decrements service use count after/before getService/ungetService() is called on ServiceFactory
551 * [FELIX-1371] - Automatic parent class loader delegation does not correctly filter calls to Bundle.loadClass()
552 * [FELIX-1397] - Required execution environment verification should happen at resolve time, not install time
553 * [FELIX-1400] - bootdelegation and dynamic-import-packages are accepting invalid patterns
554 * [FELIX-1401] - Manifest localization with fragments not handled correctly
555 * [FELIX-1422] - Resolver does not always discard partial results when a cyclically dependency fails
556 * [FELIX-1435] - Resolver does not always resolve a dynamic import to a fragment export
557 * [FELIX-1527] - R4.2 spec errata now specifies uninstalling a bundle must transition through INSTALLED on its way to UNINSTALLED
558 * [FELIX-1551] - Start level service must synchronously persist bundle start level changes
559 * [FELIX-1556] - Bundle.getResource/s is not able to find resources if the package is not alraedy wired when I use DynamicImport-Package: *
560
561** Improvement
562 * [FELIX-712] - Ability to disable automatic parent classloader delegation
563 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
564 * [FELIX-1120] - Enable BundleCache customization
565 * [FELIX-1134] - Add support for native libraries in fragments
566 * [FELIX-1189] - Improve error message in main when there is an error processing auto-install/start bundles
567 * [FELIX-1246] - PackageAdmin.getBundle() is not implemented efficiently
568 * [FELIX-1260] - Make Bundle.findEntries() and Bundle.getEntryPaths() more thread safe
569 * [FELIX-1291] - Implement support for proper return type from Framework.waitForStop()
570 * [FELIX-1300] - Remove legacy bundle cache support when extracting embedded JAR files
571 * [FELIX-1360] - Improve native library matching algorithm (part 2)
572 * [FELIX-1404] - Use provided classes from OSGi R4.2 companion code
573 * [FELIX-1432] - Manifest parser doesn't return import package declarations in order of manifest
574 * [FELIX-1462] - Felix framework launcher should only use standard launching API
575
576** New Feature
577 * [FELIX-33] - Implement system bundle update
578 * [FELIX-749] - Add support for lazy activation of bundles
579 * [FELIX-1193] - Implement org.osgi.framework.bundle.parent from RFC 132
580 * [FELIX-1205] - Update to the latest OSGi R4.2 API
581 * [FELIX-1244] - Add support for ServiceEvent.MODIFIED_ENDMATCH
582 * [FELIX-1250] - Support service exceptions for service factories
583 * [FELIX-1289] - Support for FrameworkUtil.getBundle()
584 * [FELIX-1297] - Implement support for new org.osgi.framework.command.execpermission configuration property
585 * [FELIX-1298] - Implement support for new org.osgi.framework.library.extensions configuration property
586 * [FELIX-1446] - Framework launcher should automatically deploy bundles in bundle directory
587 * [FELIX-1478] - Add shutdown hook to launcher to cleanly shutdown the framework if the process is killed
588
589
590
591
592** Task
593 * [FELIX-1144] - The NOTICE file for Main subproject is not correctly copied into the source JAR
594
595
596** Test
597 * [FELIX-1208] - Need migrate the EventDispatcherTest to newer version of EasyMock
598
599Changes form 1.6.1 to 1.8.0
600---------------------------
601** Bug
602 * [FELIX-1034] - bootdelegation property seems to be matching more packages than desired
603 * [FELIX-1059] - DynamicImport-Package matches more packages than desired
604
605** Improvement
606 * [FELIX-1060] - URLHandlers doesn't support URLStreamHandler.openConnection(proxy,url) method
607
608** New Feature
609 * [FELIX-29] - Implement bundle fragments
610
611Changes from 1.6.0 to 1.6.1
612---------------------------
613** Bug
614 * [FELIX-1027] - deadlock with felix 1.6.0 ?
615 * [FELIX-1028] - NPE in configuration view when running webconsole with Equinox
616 * [FELIX-1033] - Exceptions when Felix is started with security manager
617 * [FELIX-1035] - deadlock observed while using fileinstall to monitor multiple directories
618 * [FELIX-1045] - Felix 1.6.0 fails with ClassCircularityError
619
620Changes from 1.4.1 to 1.6.0
621---------------------------
622
623** Bug
624 * [FELIX-737] - Resolver does not correctly discard export when module imports the same package (part 2)
625 * [FELIX-852] - Fragment support is currently limited to directly resolved hosts
626 * [FELIX-869] - SCR throws exception on invalidating a component with a reference to a service that was already unregistered
627 * [FELIX-891] - Bundle lock acquisition should not record lock until it verifies the bundle is lockable
628 * [FELIX-892] - ServiceReferenceImpl improper implementation of equals and hashcode
629 * [FELIX-893] - Felix fails to start using J9 JVM
630 * [FELIX-897] - Empty system package is exported when a semicolon is present in "extra" configuration
631 * [FELIX-902] - Empty bundle.state file produces NPE
632 * [FELIX-910] - Framework may ignore framework startlevel on startup
633 * [FELIX-911] - Potential deadlock between Bundle.stop() and BundleContext.registerService()
634 * [FELIX-915] - PackageAdmin returns null on getBundle(...) with system classes
635 * [FELIX-934] - Bootdelegation bug
636 * [FELIX-947] - Behaviour of startlevel comman doesn't adhere to spec
637 * [FELIX-948] - ServiceReferenceImpl.compareTo should handle other types than integer for service ranking
638 * [FELIX-951] - Deadlock in iPojo when stopping Felix
639 * [FELIX-952] - Exception thrown when unregistering services because the bundle is stopped
640 * [FELIX-953] - Bundle#loadClass sometimes return null instead of throwing a CNFE
641 * [FELIX-961] - 100% CPU looping inside uses calculation
642 * [FELIX-962] - Erroneous class loading delegation to the application launcher classloader in some cases
643 * [FELIX-969] - system bundle does not correctly handle (export) package attributes
644 * [FELIX-971] - Exception thrown in ServiceTracker at shutdown
645 * [FELIX-978] - Resolver does not clean up properly on a failed recursive attempt to resolve
646 * [FELIX-1004] - Extensionmanager openConnection(URL) method should be public
647 * [FELIX-1005] - Strange list of imported packages returned by the package admin
648
649** Improvement
650 * [FELIX-681] - Modify daemon threads to catch all exceptions and log them to avoid premature thread death
651 * [FELIX-851] - Refactor the module abstraction layer to align more closely to OSGi concepts
652 * [FELIX-872] - JarContent swallows exception when opening manifest, it should log it
653 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
654 * [FELIX-894] - Loosen locking when starting/stopping/uninstalling a bundle by firing event without holding a lock
655 * [FELIX-908] - Unsynchronize access to bundle state inside BundleInfo by making the variable volatile
656
657Changes from 1.4.0 to 1.4.1
658---------------------------
659
660* [2008-12-19] Refactor the URLHandlers implementation to fix a possible
661 Linkage-Error when running embedded inside tomcat. Furthermore, make it possible
662 to dynamically set a SecurityManager, change the url we add to the framework
663 classloader to fix issues with rmi and make sure we restore the previous URLStreamHandlerFactory
664 after stopping. (FELIX-842, FELIX-837, FELIX-844, FELIX-827)
665* [2008-12-19] Add missing javax.security.cert in JRE 1.4 and 1.5. (FELIX-854)
666* [2008-12-19] Improve framework internal locking protocol.
667* [2008-12-18] Fixed an issue where bundles with a non-existing native library
668 would not be removed correctly. (FELIX-835)
669* [2008-11-21] Throw an exception when there is an attempt to start or stop a
670 fragment, as per the spec. (FELIX-820)
671* [2008-11-20] Fixed a bug during shutdown where uninstalled fragments are not
672 properly closed. (FELIX-819)
673* [2008-11-14] Added partial support for new service registry hooks as proposed
674 for OSGi R4.2; currently, only listener hooks are supported. (FELIX-804)
675* [2008-11-08] Fixed Felix' delegation hack so that it correctly delegates to
676 the parent class loader for resources as appropriate; previously it was always
677 delegating for class loading, which was incorrect. (FELIX-808)
678
679Changes from 1.2.2 to 1.4.0
680---------------------------
681
682* [2008-11-05] URLStreamHandlerService and ContentHandlerService override
683 built-in handlers and make it possible to use URLHandlers when extending the
684 Felix class. (FELIX-756, FELIX-800)
685* [2008-11-04] Implement ServiceReference.compareTo() method. (FELIX-799)
686* [2008-10-31] Fix some visibility issues in the LDAP operators which could
687 result in incorrect toString values. (FELIX-765)
688* [2008-10-31] Fixed spec compliance issues around getting a service reference
689 from an invalid registration and throwing an exception when there are
690 duplicate property keys. (FELIX-798)
691* [2008-10-21] Fixed an issue with extension bundles which would be installed
692 as fragments and fail to install extension bundles if they have incomplete
693 metadata. (FELIX-770)
694* [2008-10-21] Fix a possible deadlock in URLHandlers. (FELIX-748)
695* [2008-10-16] Modified framework to have default values for the system
696 packages property, which also required modifying main to no longer expect to
697 set it. Now it is possible to start Felix with no configuration properties.
698 (FELIX-753)
699* [2008-10-16] Update felix to work with the 1.0.0-rc1 version of the android
700 sdk.
701* [2008-10-15] Implemented remaining PackageAdmin methods from R4. (FELIX-35)
702* [2008-10-15] Modified resolver to correctly mark fragment modules as resolved.
703 (FELIX-777)
704* [2008-10-15] Modified the resolver to longer consider uninstalled fragments
705 and hosts when resolving dependencies; this required a new "stale" flag on
706 modules that gets set when their associated bundle is uninstalled. (FELIX-776)
707* [2008-10-15] Modified the resolver to sort candidates when resolving
708 Require-Bundle dependencies. (FELIX-775)
709* [2008-10-14] Modified ExportedPackage.getImportingBundles() to include
710 bundles requiring the exporting bundle, in addition to those bundles
711 importing the package. Also tried to simplify dependency management code
712 by separating it out. (FELIX-764)
713* [2008-10-14] Fix a NullPointerException in SecureAction when a
714 SecurityManager is used by keeping pointers on the local stack. (FELIX-766)
715* [2008-10-13] Use System.gc to allow to update and uninstall bundles with
716 native libs on Windows. (FELIX-733)
717* [2008-10-10] Set the activator to null on Bundle.stop() to allow for earlier
718 garbage collection. (FELIX-762)
719* [2008-10-10] Implements support for flushing the cache on framework
720 initialization. (FELIX-755)
721* [2008-10-10] Improve exception messages. (FELIX-750)
722* [2008-10-09] Modified the bundle cache to no longer have profiles. (FELIX-754)
723* [2008-10-08] Modified the Felix API to aligned with the proposed standard
724 OSGi framework API. The framework instance can now be stopped and restarted.
725 (FELIX-753)
726* [2008-09-29] Support transiently starting/stopping bundles. (FELIX-713)
727* [2008-09-25] Correctly discard exported packages when a bundle is chosen to
728 import a package it exports. (FELIX-736)
729* [2008-09-24] Clearly distinguish between "resolved" and "unresolved"
730 capabilities, which is necessary since "resolved" capabilities have higher
731 priority than "unresolved" ones. (FELIX-730)
732* [2008-09-24] Do not bootdelegate in the case where Bundle.loadClass() has
733 been used. (FELIX-712)
734* [2008-09-23] Improve decoding of reference URLs. (FELIX-731)
735* [2008-09-23] For completeness, added symbolic names to framework and main.
736* [2008-09-17] Improve gc by fixing an issue with StartLevel and PackageAdmin.
737 (FELIX-728)
738* [2008-09-15] Fix an issue with Require-Bundle not aggregating packages
739 correctly. (FELIX-722)
740* [2008-09-15] Fixed a bug where class loader delegation for dynamic imports
741 was happening when it shouldn't. (FELIX-724)
742* [2008-09-12] Added a configuration property to determine whether installing a
743 fragment that uses unimplemented features throws an exception or logs a
744 warning. (FELIX-725)
745* [2008-09-12] Removed some experimental code for "implicit requirements",
746 since it was no longer needed.
747* [2008-09-12] Fix some visibility issues within the LDAP filter. (FELIX-721)
748
749Changes from 1.2.1 to 1.2.2
750---------------------------
751
752* [2008-10-14] Fixed a NullPointer exception that could happen when
753 running with a SecurityManager as a backport of FELIX-766.
754
755Changes from 1.2.0 to 1.2.1
756---------------------------
757
758* [2008-09-05] Fixed a performance regression that was caused by uncached
759 access to the bundle manifest headers. (FELIX-711)
760* [2008-09-03] Fixed a bug in calculating the system bundle's exported
761 packages which added a null export package.
762
763Changes from 1.0.4 to 1.2.0
764---------------------------
765
766* [2008-08-29] Support JAR-wide manifest package metadata. (FELIX-682)
767* [2008-08-29] Throw an exception when installing a fragment that uses
768 features that we do not support.
769* [2008-08-20] Improve error reporting when loading bundle classes using
770 Bundle.loadClass.
771* [2008-08-16] Fix attribute checking when resolving dynamic imports.
772 (FELIX-676)
773* [2008-08-08] Implement singleton bundle support. (FELIX-102)
774* [2008-08-06] Default to current security policy if no security extension is
775 installed in order to make Subject.doAs work. (FELIX-654)
776* [2008-08-04] Return Bundle.getLastModified() for bundle URLs
777 lastModified(). (FELIX-582)
778* [2008-08-04] Improve handling of improper resource URLs. (FELIX-577)
779* [2008-08-01] Add necessary stub methods to implement new R4.1 methods.
780 (FELIX-595)
781* [2008-08-01] Applied patch to properly return symbolic name when it has
782 parameters. (FELIX-650)
783* [2008-07-25] Fix some rollback issues after a bundle update throws an
784 exception. (FELIX-647)
785* [2008-07-23] Modified manifest parser to be more lenient. (FELIX-641)
786* [2008-07-07] Add support for the standard symbolic name for the system
787 bundle. (FELIX-602)
788* [2008-06-01] Add initial fragment support for extending the host bundle
789 class path. (FELIX-29, FELIX-656)
790
791Changes from 1.0.3 to 1.0.4
792___________________________
793
794* [2008-04-18] Check that the returned object from a service factory is an
795 instance of all classes named when the service was registered. (FELIX-540)
796* [2008-04-13] Fix an issue when logging messages while holding framework
797 internal locks that could lead to a deadlock. For now we just disable
798 logging to log services inside the framework. (FELIX-536)
799* [2008-04-13] Implemented various small performance improvments e.g.,
800 we now cache filters and create an index for objectclass to improve
801 service lookup performance and don't use the BundleInfo to get the
802 bundle id but the BundleImpl directly. Furthermore, we added an index to
803 get bundles by id.
804* [2008-04-04] Fix an NoClassDefFoundError when trying to query the
805 framework classloader for whether a class is available or not.
806* [2008-03-19] Don't try to resolve extension bundles and fix a
807 classcastexception that could happen if more then one framework is around
808 and both have extensions installed. Furthermore, make extension bundles
809 use the system bundle context.
810* [2008-03-07] Bundle.getResource does now check for AdminPermission.
811 (FELIX-150)
812* [2008-03-06] Make urlhandlers work when a handler factory is already set.
813 Furthermore, it is now possible to have more then one framework running
814 in more then one classloader. (FELIX-38).
815* [2008-03-05] Make LDAP filter reentrant.
816* [2008-02-29] Refactored the IContent abstraction from the module loader
817 layer to provide more generic access to the content of the module. This
818 makes it possible that a bundle's class path could span multiple module's,
819 which will be necessary for fragments. (FELIX-29)
820* [2008-02-27] Applied a patch to disable the class loading diagnostic message
821 when the logger is not at the DEBUG level. (FELIX-500)
822* [2008-02-15] Modified the service registry to use more fine-grained locking
823 to avoid callbacks to service factories while holding locks. (FELIX-489)
824
825Changes from 1.0.1 to 1.0.3
826---------------------------
827
828* [2008-01-27] Moved framework docs to main, since the launcher examples now
829 depend on main for the auto-property handling.
830* [2008-01-25] Applied patches to improve how Felix finds resources when
831 getResources() is called. (FELIX-466, FELIX-467)
832* [2008-01-25] Make FilterImpl.toString() add escape characters where needed.
833 (FELIX-471)
834* [2008-01-16] Fix a NPE on framework restart when extension bundles are
835 installed.
836* [2008-01-15] Try to fix a potential visibility issue on loading a class
837 form a bundle where it seems to be possible that we create two classloaders
838 instead of one.
839* [2008-01-15] Modified boot delegation to not terminate when delegating to
840 parent class loader for non-java.* packages. (FELIX-463)
841* [2008-01-04] Fix some issues related to directories on the bundle class
842 path. Specifically, leading slashes created an issue and are now stripped
843 and entries were not being properly filtered when enumerating the contents
844 of a class path directory. (FELIX-426)
845* [2007-12-20] Modified logger to have all of its public methods be final to
846 avoid it from being extended in undesired ways via the constructor supplied
847 logger. (FELIX-428)
848* [2007-12-20] The TCK has changed to verify that bundles do not depend on
849 themselves, so we filter that case now.
850* [2007-12-20] Applied patch from Guillaume Nodet to properly fire a framework
851 error event only when a bundle cannot be resolved. (FELIX-441)
852* [2007-12-19] Modified framework to accept a Logger instance so that host
853 applications can do custom logging until the log service arrives. (FELIX-428)
854* [2007-12-19] Add support for loading bundles on Google Android (FELIX-440).
855* [2007-12-18] Improve native code loading - bundle installation will now
856 fail in case a native library is not in the jar and we only use the first
857 library of a given name. Furthermore, we now support .dylib extensions on
858 the mac as well as others; should make it possible to use .netmodules as
859 well. (FELIX-439)
860* [2007-12-17] Make the win32 alias match any version of windows for native
861 clauses. (FELIX-438)
862* [2007-12-14] Removed auto-property processing out of the framework and
863 into the default launcher, i.e, main. (FELIX-393)
864* [2007-12-13] Fix a StackOverflowError in URLHandlers.createStreamHandler()
865 when creating URL on jamvm and Mika. This patch resolves an unfortunate
866 interaction between our ExtensionManager and the URLHandlers by making the
867 URLHandlers aware of the extension protocol. Pretty much like we do already
868 for the bundle protocol. (FELIX-435)
869* [2007-11-26] Fix a small oversight in the extension manager that could lead
870 to a null pointer exception and save some memory by creating less objects.
871* [2007-11-26] Degrate to version 0.0.0 if we can not find the Felix.properties
872 for some reason and avoid a null pointer in this case.
873* [2007-11-08] Reorganized usage count methods to better handle null
874 reference checking in response to Karl Pauls seeing an NPE when trying to
875 get a service that was already unregistered while shutting down the
876 framework.
877* [2007-11-06] Added a simple check to detect and work around a bug in J9.
878 (FELIX-416)
879* [2007-10-30] Change how the extension manager url stream handler handles
880 request to the root path in order to make some tomcat issue go away.
881 (FELIX-414)
882* [2007-10-26] Added support for "/" bundle resources as requested. (FELIX-383)
883* [2007-10-24] Use system bundle when firing a framework error event when an
884 install error occurs.
885* [2007-10-22] Fix a NPE when getEntryPaths is called on the system bundle.
886 (FELIX-394)
887* [2007-10-16] Modifies bundle resource URL handling such that if a resource
888 URL points to a resource that does not exist, a bundle class path search
889 for the resource will be instigated and if any matching resource is found,
890 that one will be used instead. (FELIX-383)
891* [2007-10-10] Auto-property handling now installs bundles into the default
892 bundle start level if a start level is not specified. (FELIX-359)
893* [2007-10-08] Overwrite the URLStreamHandler.getHostAddress(URL) in the
894 ExtensionManager to immediately return null to prevent DNS lookup.
895 (FELIX-388)
896* [2007-09-30] Resolved a concurrency issue that could result in the same
897 bundle being resolved more than once; also tried to simplify locking in
898 the core search policy implementation. (FELIX-381)
899
900Changes from 1.0.0 to 1.0.1
901---------------------------
902
903* [2007-07-23] Fixed a bug in the framework shutdown process which was
904 causing threads calling Felix.stopAndWait() to not get notified that
905 the framework had shutdown. (FELIX-329)
906* [2007-08-15] Fixed a bug in the LDAP filter which was not thread safe
907 on execution. (FELIX-338)
908* [2007-08-17] Added support for persistent last used bundle ID to avoid
909 re-use of bundle identifiers. (FELIX-339)
910* [2007-08-23] Modified BundleImpl.getHeaders(Locale) to accept a null
911 locale. (FELIX-346)
912* [2007-09-11] Added support to handle external termination of Felix
913 which was not handled or detected and prevented a restart of future
914 Felix instances in the same VM. (FELIX-363)
915* [2007-09-12] Add support for Collection values in the LDAP filter to
916 match the 4.1 spec.
917* [2007-09-12] Fixed a bug in the LDAP filter where attributes where
918 limited to [a-zA-Z ] so didn't allow for e.g., numbers. (FELIX-361)
919* [2007-09-13] Enable support for exporting the same package more than
920 once (FELIX-101).
921* [2007-09-13] Returns the system bundle from a call to
922 PackageAdmin.getBundle(Class) in case the class comes from the
923 classloader (or one of its parents) that loaded Felix and the system
924 bundle exports the package.
925* [2007-09-16] Fixed a bug in class space filtering in the service registry
926 that could result in class cast exceptions for service clients.
927* [2007-09-16] Fixed a bug that prevented extension bundle exports to be
928 usable.
929
930Changes from 0.8.0-incubator to 1.0.0
931-------------------------------------
932
933* [2007-01-18] Added support for bundle header localization. (FELIX-27)
934* [2007-01-22] Modified framework resolver to support a generic
935 capability/requirement model.
936* [2007-01-22] Reorganized and centralized manifest parsing code and added
937 support for resolver's generic capability/requirement model. (FELIX-98)
938* [2007-01-22] Improved native library naming normalization. (FELIX-26)
939* [2007-01-23] No longer eagerly resolving classes loaded from modules
940 since this was causing verification errors with IBM J9.
941* [2007-01-25] Added some support for execution environment checking.
942 (FELIX-23)
943* [2007-01-29] Added support for getAllServiceReferences(). (FELIX-32)
944* [2007-01-31] Added Require-Bundle support to resolve using the generic
945 capability/requirement model of the resolver. (FELIX-28)
946* [2007-02-05] Fixed a bug in processor type normalization for x86-64
947 processors.
948* [2007-02-09] The resolver previously ignored packages that were pending
949 removal when resolving new bundles, now it does not.
950* [2007-02-09] Bundles are automatically refreshed when updated/uninstalled
951 if none of their exported packages are in use.
952* [2007-02-13] Added support for extension bundles. (FELIX-30)
953* [2007-03-02] Added a Bundle.getBundleContext() method until actual
954 support for OSGi R4.1.
955* [2007-04-26] Modified Bundle.findEntries() to return URLs to directory
956 entries as well as file entries.
957* [2007-05-06] Modified LDAP evaluator to special case the fact that
958 BigDecimal is not available in Foundation profile.
959* [2007-05-21] Made some performance improvements in LDAP evaluation.
960* [2007-05-22] Modified JAR file to include Service Tracker package.
961* [2007-05-22] Improved concurrency handling around checking for already
962 loaded classes and defining classes.
963* [2007-06-05] Modified resource URLs to use port number rather than
964 prepend information to the resource path.
965* [2007-06-13] Improved dynamic imports to cycle through all available
966 candidates when checking for class space consistency.
967* [2007-06-18] Improved service registry filtering based on class versions
968 to allow a bundle to register a service for a different version of class
969 that it can access.
970* [2007-06-21] Modified our "last ditch effort" to guess when to delegate
971 to the system bundle to make it a little more robust.
972* [2007-06-29] Fixed a bug in EventDispatcher that was causing asynchronous
973 events to not be fired after stopping the framework instance and creating
974 a new instance. (FELIX-314)
975* [2007-07-03] Fixed a bug in EventDispatcher that would not correctly
976 update a listener when it implemented multiple listener interfaces.
977* [2007-07-04] Modified Felix framework class to implement the Bundle
978 interface to improve the startup/shutdown sequence and to provide a
979 simplified API for creating framework instances.
980* [2007-07-11] Removed the PropertyResolver-related classes and now only
981 use Maps for configuration properties. (FELIX-324)