blob: 3198d0924e78133d198ce1c730450d2c102088a7 [file] [log] [blame]
Karl Paulsc2bd5042011-09-22 14:49:24 +00001Changes from 3.2.2 to 4.0.0
Karl Pauls5bc739a2011-09-22 13:23:51 +00002---------------------------
3
4** Bug
5 * [FELIX-2762] - Substring parser incorrectly disallowing use of parentheses characters
6 * [FELIX-2990] - [Framework] Bug introduced into handling of native libraries during a fresh
7 * [FELIX-3015] - [Framework] Provide org.osgi.util.tracker version 1.5
8 * [FELIX-3033] - [Framework] Service registry hooks are not correctly filtering bundle contexts for event hook
9 * [FELIX-3038] - Framework does not offer J2SE-1.2 Execution Environment
10 * [FELIX-3043] - [Framework] Resolver is not correctly resolving fragments in all cases
11 * [FELIX-3059] - Reexported packages are not calculate correctly leading to resolver and class loading bugs
12 * [FELIX-3062] - [Framework] Resolver gets into infinite loop in the face of a require-bundle cycle
13 * [FELIX-3082] - [Framework] Bundles not allowed to add listeners while in STOPPING state
14 * [FELIX-3085] - Importing/exporting "." should not be allowed
15 * [FELIX-3096] - Could not add FrameworkListener from ServiceListener
16
17** Improvement
18 * [FELIX-2467] - The framework extensions should be returned when invoking the method PackageAdmin#getFragments with the system bundle
19 * [FELIX-2572] - JRE system packages should include "uses" constraints
20 * [FELIX-2950] - [Framework] Adopt OSGi R4.3 API as framework internal API
21 * [FELIX-2998] - [Framework] OSGi R4.3 changed filter handling of exceptions when calling equals()/compare() to return false
22 * [FELIX-3000] - Move sending service registered event out of bundle lock
Karl Pauls5bc739a2011-09-22 13:23:51 +000023 * [FELIX-3071] - [Framework] It should be possible to limit number of open JAR files
24 * [FELIX-3125] - [Framework] Use single file per bundle in bundle cache by default
25
26** New Feature
27 * [FELIX-2959] - [Framework] Implement OSGi R4.3 class loader byte-code weaving hook
28 * [FELIX-2969] - [Framework] Implement OSGi R4.3 framework wiring object
29 * [FELIX-2973] - [Framework] Implement OSGi R4.3 generic capabilities and requirements
30 * [FELIX-2975] - [Framework] Implement OSGi R4.3 framework start level object
31 * [FELIX-2986] - [Framework] Implement OSGi R4.3 resolver hooks
32 * [FELIX-2999] - [Framework] OSGi R4.3 now specifies that number types should be trimmed when evaluating filters
33 * [FELIX-3032] - [Framework] Implement OSGi R4.3 bundle hooks
34 * [FELIX-3052] - [Framework] Implement OSGi R4.3 system bundle generic capabilities
35 * [FELIX-3056] - [Framework] Implement OSGi R4.3 event listener service registry hook
36 * [FELIX-3122] - [Framework] Implement OSGi R4.3 framework UUID
37 * [FELIX-3124] - [Framework] Implement OSGi R4.3 property to allow installing bundles with the same BSN and version
38
39** Task
40 * [FELIX-3110] - [Framework] Implement 4.3 security checks
41
42
Karl Pauls5bfc61f2011-05-11 19:00:36 +000043Changes from 3.2.1 to 3.2.2
44---------------------------
45
46** Bug
47 * [FELIX-2935] - Bundle.getEntryPaths and findEntries are returning META-INF/ multiple times
48 * [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.
49 * [FELIX-2942] - Bundles with higher start level get activated even before framework reaches that start level
50
51
Karl Pauls47b9d042011-04-18 21:16:29 +000052Changes from 3.2.0 to 3.2.1
53---------------------------
54
55* Bug
56 * [FELIX-2901] - [Framework] NPE from a host bundle during framework shutdown
57 * [FELIX-2917] - Constructor of SecurityExceptino() which is incompatible to 1.4 is used
Karl Paulsf1e813f2011-04-26 20:31:30 +000058 * [FELIX-2924] - bundle stop hangs for http-2.2.0 in felix-3.2.0
Karl Pauls47b9d042011-04-18 21:16:29 +000059
60** Improvement
61 * [FELIX-2909] - [Framework] Resolver could be more efficient if it detected if fragments were present
62
63
Karl Paulsa012b532011-03-28 19:42:04 +000064Changes from 3.0.9 to 3.2.0
65---------------------------
66
67* Bug
68 * [FELIX-1816] - deadlock on SystemBundle.stop()
69 * [FELIX-2741] - NPE in ResolverImpl.calculatePackageSpaces
70 * [FELIX-2748] - Possible synchronization issue with BundleContext.getBundle()
71 * [FELIX-2877] - java6 update 24 breaks felix when used inside webstart
72
73
74** Improvement
75 * [FELIX-2858] - [Framework] Modify resolver to be self-contained with respect to fragment handling
76 * [FELIX-2859] - [Framework] Modify resolver to be self-contained with respect to singleton handling
77 * [FELIX-2864] - [Framework] Add package profile for JDK7 to default properties
78
Guillaume Nodet4b4ae502011-02-21 09:38:48 +000079Changes from 3.0.8 to 3.0.9
80---------------------------
81
82** Bug
83 * [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
84 * [FELIX-2784] - When the framework try to grab the bundle lock, it ignores thread interruption
Guillaume Nodet4b4ae502011-02-21 09:38:48 +000085 * [FELIX-2822] - [Framework] System bundle module's state not reset when framework restarted leading to NPE
86 * [FELIX-2832] - [Framework] It should not be possible to open an URLConnection to "/" for a bundle URL
87 * [FELIX-2840] - [Framework] Uninstalling an uninstalled bundle throws NoSuchElementException
88 * [FELIX-2849] - PackageAdmin is inconsistent between getFragments and getHosts
89 * [FELIX-2850] - PackageAdmin return fragments / hosts even if the host isn't resolved
90 * [FELIX-2851] - Resolution problems after a fragment can't be resolved
91
92** Improvement
93 * [FELIX-2841] - [Framework] Improve resolve exception messages
94
Richard S. Hall6de24032011-02-20 21:10:48 +000095Changes from 3.0.7 to 3.0.8
96---------------------------
97
98** Bug
99 * [FELIX-2749] - Boolean.parseBoolean() newly defined in Java5 should not be used.
100 * [FELIX-2789] - Native library matching is not correctly checking additional extensions
101 * [FELIX-2800] - Logging will throw an NPE if no bundle is specified
102 * [FELIX-2802] - A failed update doesn't rollback properly
103 * [FELIX-2805] - Cache PackageAdmin.getBundle() result for system bundle classes
104
Karl Pauls4d06aa62010-12-26 20:58:00 +0000105Changes from 3.0.6 to 3.0.7
106---------------------------
107
108** Bug
109 * [FELIX-2456] - Framework no longer fires UNRESOLVED event when a bundle is explicitly refreshed
110 * [FELIX-2693] - [Framework] Service registry should throw a ServiceException for factories resulting in a cycle
111 * [FELIX-2700] - Framework uses java.nio package which is not supported by CDC VM
112 * [FELIX-2710] - [Framework] For exploded bundles Bundle.getEntry("a/b.jar/")==Bundle.getEntry("a/b.jar")
113 * [FELIX-2717] - [Framework] Resolver treats multiple exports of same package as conflicting for fragment imports
114 * [FELIX-2725] - [Framework] Resolver is not correctly calculating exported packages for already resolved modules
115 * [FELIX-2728] - JarRevision does not close URLConnections which are instances of HttpURLConnection
116 * [FELIX-2736] - [Framework] Resolver is not correctly verifying package space consistency for dynamic imports
117 * [FELIX-2738] - [Framework] DirectoryContent does not handle security correctly
118
119** Improvement
120 * [FELIX-2703] - [Framework] Include OSGi/Minimum EEs in default properties
121 * [FELIX-2721] - [Framework] Implement custom manifest parser and avoid JarFile
122 * [FELIX-2737] - [Framework] Optimize resolver algorithm by not re-calculating uses constraints for resolved modules
123
Karl Pauls13972642010-11-03 20:44:01 +0000124Changes from 3.0.5 to 3.0.6
125---------------------------
126
127** Bug
128 * [FELIX-2670] - [Framework] Implicit boot delegation doesn't delegate for external code in all cases
129 * [FELIX-2683] - [Framework] Bundle last modified time is not persisted on deployment
130
131** Improvement
132 * [FELIX-2560] - Bundle URLs do not survive refreshes
133
134** New Feature
135 * [FELIX-2646] - [Framework] Locking could be used to prevent concurrent access to a single bundle cache
136
Karl Paulsdd404492010-10-18 21:32:43 +0000137Changes from 3.0.4 to 3.0.5
138---------------------------
139
140** Bug
141 * [FELIX-2653] - LinkageError caused by duplicate class definition during implicit boot delegation
142
143** Improvement
144 * [FELIX-2645] - Add a (hidden) way to retrieve a local URL for a given bundle URL
145 * [FELIX-2654] - [Framework] Modify bundle cache to use a single file per bundle state
146
Karl Pauls7c620342010-10-04 20:22:24 +0000147Changes from 3.0.3 to 3.0.4
148---------------------------
149
150** Bug
151 * [FELIX-2584] - No FrameworkEvent.ERROR on unchecked exception in event listener
152 * [FELIX-2629] - [Framework] Module class loader should return an empty enumeration for getResources()
153
154** Improvement
155 * [FELIX-2619] - [Framework] Bundle cache is rechecking nonexistent files again and again
156 * [FELIX-2626] - [Framework] Bundle cache is rewriting some files when restarting bundles
157
Karl Pauls1c3a4592010-09-22 20:26:29 +0000158Changes from 3.0.2 to 3.0.3
159---------------------------
160
161** Bug
162 * [FELIX-2548] - Resolver should use case sensitive indexing for capabilities
163 * [FELIX-2569] - Felix bundle classloader always delegates to parent loader in getResources()
164 * [FELIX-2589] - SecurityException "SecurityManager already installed" is thrown when calling Framework.init() multiple times with FRAMEWORK_SECURITY set
165 * [FELIX-2598] - Hang in Felix: thread owing a bundle lock waits for ever to lock it again
166 * [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
167
168** Improvement
169 * [FELIX-1022] - Classloader Exceptions should be more informative
170 * [FELIX-2549] - Fix some synchronization issues in content handling
171 * [FELIX-2555] - Log messages should contain the bundle id, when available
172 * [FELIX-2597] - Deadlock during delivery of resolved event
173
Karl Paulsbd2998e2010-08-18 20:16:33 +0000174Changes from 3.0.1 to 3.0.2
175---------------------------
176
177** Bug
178 * [FELIX-2421] - Implicit bootdelegation doesn't ignore classloaders if they are inner classes
179 * [FELIX-2437] - Deadlock on refrsh Import and refresh
180 * [FELIX-2451] - Felix uses System.out to print debug messages related to resolver...
181 * [FELIX-2459] - Wrong error message on a missing package
182 * [FELIX-2466] - Unknown attributes are not stripped from Fragment-Host header
183 * [FELIX-2473] - Subtring matching is incorreclty matching against an empty string
184 * [FELIX-2479] - Required bundles not correctly re-exporting their substitutable exports
185
186** Improvement
187 * [FELIX-2528] - Potential performance issue in resolver when uses constraint conflict is detected
188 * [FELIX-2529] - In some scenarios the resolver will not backtrack on imported package decisions
189
Karl Pauls82450a22010-06-14 20:04:02 +0000190Changes from 3.0.0 to 3.0.1
191---------------------------
192
193** Bug
194 * [FELIX-2401] - NPE in org.apache.felix.framework.FilterImpl.DictionaryCapability.getAttribute(String)
195
Karl Pauls74d9aca2010-06-06 21:23:05 +0000196Changes from 2.0.5 to 3.0.0
197---------------------------
198** Sub-task
199 * [FELIX-2036] - Improve resolver's generic capability/requirement model
200 * [FELIX-2037] - Improve resolver performance by making solution space searching smarter
201
202** Bug
203 * [FELIX-995] - JRE packages are exported with wrong version
204 * [FELIX-1967] - Freeze finding consistent class space
205 * [FELIX-2080] - Updating bundles when debugging switched on might result in a deadlock with 100% CPU usage
206 * [FELIX-2150] - URLStreamHandlerProxy.setURL may not set query component correctly
207 * [FELIX-2172] - Extremely long resolve stage when running CXF-DOSGi system test
208 * [FELIX-2177] - Fragment bundles not loaded after second start when using autodeploy
209 * [FELIX-2271] - CLONE -NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
210 * [FELIX-2273] - getClassLoader-permission required accessing classes from dynamically loaded class
211 * [FELIX-2281] - Bundle id order affects fragment resolution success
212 * [FELIX-2317] - Possible NPE for jars with null Manifest
213 * [FELIX-2321] - BundleException type should be properly set when installing a duplicate bundle
214 * [FELIX-2332] - Lots of contention on ExtensionManager.openConnection(URL)
215 * [FELIX-2335] - Bundle.loadClass() for system bundle doesn't obey boot delegation
216 * [FELIX-2356] - extension bundle cannot load class from embed jar
217 * [FELIX-2383] - Bundles are restarted during start level change
218 * [FELIX-2392] - Felix framework uses a Java5 method
219
220** Improvement
221 * [FELIX-1210] - Allow jars with missing intermediate entries to be handled as if they were present in Bundle.getEntryPaths
222 * [FELIX-1797] - Customizable Framework startup message
223 * [FELIX-2035] - Reimplement framework resolver
224 * [FELIX-2039] - Reimplement standard OSGi LDAP filter to use new filter solution for resolver
225 * [FELIX-2040] - Modify framework service registry to use resolver's new capability/requirement model
226 * [FELIX-2041] - Look into using generics in framework code
227 * [FELIX-2042] - Use Gogo as the default shell for the framework distribution
228 * [FELIX-2324] - Support execution environment so that OBR works properly
229 * [FELIX-2336] - Variable substitution in configuration files should ignore mismatched delimiters
230
231Changes from 2.0.4 to 2.0.5
232---------------------------
233** Bug
234 * [FELIX-1753] - The start level should check that the bundle still exists before starting it to avoid an ugly exception
235 * [FELIX-2087] - NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
236 * [FELIX-2107] - Bundle.findEntries() matches '*<filePattern>' instead of '<filePattern>'
237 * [FELIX-2195] - Using URLDecoder.decode on locations is wrong
238 * [FELIX-2222] - Failure to reinstall a cached bundle will corrupt the bundle cache
239
Karl Pauls1da29612010-02-14 22:08:33 +0000240Changes from 2.0.3 to 2.0.4
241---------------------------
242
243** Bug
244 * [FELIX-2056] - URLHandlersStreamHandler not getting handlers from frameworks that are inside a different classloader
245 * [FELIX-2067] - Fragment bundle ignored silently when the host Bundle-SymbolicName equals import package name
246 * [FELIX-2073] - The System Bundle is not providing WS Addressing
247
248** Improvement
249 * [FELIX-2071] - Missing checks inside ModuleImpl (in Framework) which causes exceptions
250
Karl Pauls6532a9d2010-02-04 22:44:52 +0000251Changes from 2.0.2 to 2.0.3
252---------------------------
253
254** Bug
255 * [FELIX-1838] - PackageAdmin.getExportedPackages() duplicates output for packages with different version
256 * [FELIX-1867] - ModuleImpl diagnoseClassLoadError throw NullPointerException for empty package name in debug mode
257 * [FELIX-1917] - A few minor bugs in the framework found while embedding Felix
258 * [FELIX-1919] - Fragment bundle cannot be linked to its host
259 * [FELIX-1920] - RequiredBundle.getRequiringBundles() incorrectly calculates result
260 * [FELIX-1929] - getStartLevel() always reports requested start level, not active start level
261 * [FELIX-1982] - Documented but uninterpreted felix.cache.* properties
262 * [FELIX-1998] - Use UTF-8 when decoding reference location URLs
263 * [FELIX-2002] - Uninstalled fragments are not properly detached
264
265** Improvement
266 * [FELIX-37] - Implement security for bundle resource URLs
267 * [FELIX-325] - Factor out security checks from the framework/system bundle code
268 * [FELIX-1973] - Implement all required security checks
269
270** New Feature
271 * [FELIX-30] - Implement extension bundles
272 * [FELIX-1991] - Allow boot delegation class loader to be configurable per bundle
273
274
Karl Pauls499184a2009-11-01 19:22:20 +0000275Changes from 2.0.1 to 2.0.2
276---------------------------
277
278** Bug
279 * [FELIX-1754] - Usage of BundleContext.getServiceReferences results in failure to activate components
280 * [FELIX-1782] - Errors during start-up on gnu/classpath based VMs (jamvm, kaffe, cacao) and mika
281 * [FELIX-1795] - Bundle version ignored in Fragment-Host header
282 * [FELIX-1834] - java.io.IOException: No framework context found when embedding felix frameworks as bundles
283
284** Improvement
285 * [FELIX-1534] - Improve fragment merging
286 * [FELIX-1781] - Try to reduce object allocations/usage in resolver algorithm
287 * [FELIX-1783] - Eliminate contention on ServiceRegistry.getServiceReferences(String, Filter)
288
Karl Pauls1be8b552009-10-11 20:26:42 +0000289Changes from 2.0.0 to 2.0.1
290---------------------------
291
292** Bug
293 * [FELIX-1565] - Deadlock UrlHandlers
294 * [FELIX-1573] - Occasional NPE in URLHandlersBundleStreamHandler
295 * [FELIX-1580] - Regression with native library handling
296 * [FELIX-1586] - Framework reports org.osgi.framework.version as 1.3
297 * [FELIX-1600] - ServiceReference.isAssignableTo() always returns true if requesting bundle has no wire
298 * [FELIX-1631] - Implicit bootdelegation causes hang on android
299 * [FELIX-1710] - Resolver still does not discard all partial results when a cyclical dependency fails
300 * [FELIX-1721] - Framework boot delegation has a bug due to extraneous code
301 * [FELIX-1731] - Native library extraction could be improved to help cases where there are dependencies among libraries
302
303** Improvement
304 * [FELIX-1619] - Change the default auto-deploy actions to be install and start only
305 * [FELIX-1625] - Refactor bundle cache to simplify management
306 * [FELIX-1679] - VersionRange class should use finals to be thread safe.
307 * [FELIX-1724] - Various module metadata should be cached
308
309** Task
Karl Pauls1be8b552009-10-11 20:26:42 +0000310 * [FELIX-1617] - Modify framework, main, shell, shell.tui, and obr to depend on official OSGi JAR files
311
Karl Pauls43002282009-09-06 22:01:29 +0000312Changes from 1.8.1 to 2.0.0
313---------------------------
314
315** Bug
316 * [FELIX-893] - Felix fails to start using J9 JVM
317 * [FELIX-905] - Felix needs an RFC 126 FindHook
318 * [FELIX-906] - Felix needs an RFC 126 EventHook
319 * [FELIX-1122] - Extension bundles are not being removed from the bundle list when uninstalled
320 * [FELIX-1123] - System bundle does still not correctly handle (export) package attributes
321 * [FELIX-1124] - ResourceNotFoundException too verbose
322 * [FELIX-1130] - Bundle.getHeaders() returns a Dictionary<java.util.jar.Attribute.Name,String>
323 * [FELIX-1138] - URL Handlers performance regression due to service lookups
324 * [FELIX-1170] - MemoryLeak when stopping and restarting Felix
325 * [FELIX-1187] - BundleContext.ungetService() should return false only if the usage count is zero when the method is invoked
326 * [FELIX-1197] - Bundle Fragments not resolved correctly
327 * [FELIX-1198] - config.properties still refers to old org.osgi.framework.startlevel property
328 * [FELIX-1247] - BundleEvent.UNRESOLVED should be fired during update/uninstall not refresh
329 * [FELIX-1249] - Bundle.findEntries() should search fragments as well as the bundle itself
330 * [FELIX-1254] - Bundle#findEntries does not return resources from fragments
331 * [FELIX-1271] - Improve manifest localization to handle special cases
332 * [FELIX-1272] - Need to special case getResource()/getResources()/loadClass() for fragment bundles
333 * [FELIX-1273] - Bundle.getResources() should return null for a non-existent resource
334 * [FELIX-1277] - Fix Service Hooks Tests failures in RFC 126 TCK
335 * [FELIX-1279] - Framework.waitForStop() does not obey timeout
336 * [FELIX-1280] - Package Admin - getExportedPackages must return null instead of an empty array
337 * [FELIX-1285] - SecureAction captures the calling context incorrectly
338 * [FELIX-1286] - Module class loader should use secure action instead of a privileged block
339 * [FELIX-1287] - System bundle operations from RFC-132 (e.g., init(), start(), stop(), waitForStop()) are using wrong lock object
340 * [FELIX-1288] - System bundle context should be null after stopping the framework
341 * [FELIX-1292] - PackageAdmin.getBundle(Class) should return null if the bundle associated with the passed in class is from another framework
342 * [FELIX-1293] - StringMap used for case insensitive properties does not respect ordering if case sensitivity is changed
343 * [FELIX-1295] - ServiceRegistry increments/decrements service use count after/before getService/ungetService() is called on ServiceFactory
344 * [FELIX-1371] - Automatic parent class loader delegation does not correctly filter calls to Bundle.loadClass()
345 * [FELIX-1397] - Required execution environment verification should happen at resolve time, not install time
346 * [FELIX-1400] - bootdelegation and dynamic-import-packages are accepting invalid patterns
347 * [FELIX-1401] - Manifest localization with fragments not handled correctly
348 * [FELIX-1422] - Resolver does not always discard partial results when a cyclically dependency fails
349 * [FELIX-1435] - Resolver does not always resolve a dynamic import to a fragment export
350 * [FELIX-1527] - R4.2 spec errata now specifies uninstalling a bundle must transition through INSTALLED on its way to UNINSTALLED
351 * [FELIX-1551] - Start level service must synchronously persist bundle start level changes
352 * [FELIX-1556] - Bundle.getResource/s is not able to find resources if the package is not alraedy wired when I use DynamicImport-Package: *
353
354** Improvement
355 * [FELIX-712] - Ability to disable automatic parent classloader delegation
356 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
357 * [FELIX-1120] - Enable BundleCache customization
358 * [FELIX-1134] - Add support for native libraries in fragments
359 * [FELIX-1189] - Improve error message in main when there is an error processing auto-install/start bundles
360 * [FELIX-1246] - PackageAdmin.getBundle() is not implemented efficiently
361 * [FELIX-1260] - Make Bundle.findEntries() and Bundle.getEntryPaths() more thread safe
362 * [FELIX-1291] - Implement support for proper return type from Framework.waitForStop()
363 * [FELIX-1300] - Remove legacy bundle cache support when extracting embedded JAR files
364 * [FELIX-1360] - Improve native library matching algorithm (part 2)
365 * [FELIX-1404] - Use provided classes from OSGi R4.2 companion code
366 * [FELIX-1432] - Manifest parser doesn't return import package declarations in order of manifest
367 * [FELIX-1462] - Felix framework launcher should only use standard launching API
368
369** New Feature
370 * [FELIX-33] - Implement system bundle update
371 * [FELIX-749] - Add support for lazy activation of bundles
372 * [FELIX-1193] - Implement org.osgi.framework.bundle.parent from RFC 132
373 * [FELIX-1205] - Update to the latest OSGi R4.2 API
374 * [FELIX-1244] - Add support for ServiceEvent.MODIFIED_ENDMATCH
375 * [FELIX-1250] - Support service exceptions for service factories
376 * [FELIX-1289] - Support for FrameworkUtil.getBundle()
377 * [FELIX-1297] - Implement support for new org.osgi.framework.command.execpermission configuration property
378 * [FELIX-1298] - Implement support for new org.osgi.framework.library.extensions configuration property
379 * [FELIX-1446] - Framework launcher should automatically deploy bundles in bundle directory
380 * [FELIX-1478] - Add shutdown hook to launcher to cleanly shutdown the framework if the process is killed
381
382
383
384
385** Task
386 * [FELIX-1144] - The NOTICE file for Main subproject is not correctly copied into the source JAR
387
388
389** Test
390 * [FELIX-1208] - Need migrate the EventDispatcherTest to newer version of EasyMock
391
Karl Pauls1919aa72009-05-10 21:17:30 +0000392Changes form 1.6.1 to 1.8.0
393---------------------------
394** Bug
395 * [FELIX-1034] - bootdelegation property seems to be matching more packages than desired
396 * [FELIX-1059] - DynamicImport-Package matches more packages than desired
397
398** Improvement
399 * [FELIX-1060] - URLHandlers doesn't support URLStreamHandler.openConnection(proxy,url) method
400
401** New Feature
402 * [FELIX-29] - Implement bundle fragments
403
Karl Pauls962f89f2009-04-26 20:36:08 +0000404Changes from 1.6.0 to 1.6.1
405---------------------------
406** Bug
407 * [FELIX-1027] - deadlock with felix 1.6.0 ?
408 * [FELIX-1028] - NPE in configuration view when running webconsole with Equinox
409 * [FELIX-1033] - Exceptions when Felix is started with security manager
410 * [FELIX-1035] - deadlock observed while using fileinstall to monitor multiple directories
411 * [FELIX-1045] - Felix 1.6.0 fails with ClassCircularityError
412
Karl Pauls62ff7ab2009-03-31 21:06:46 +0000413Changes from 1.4.1 to 1.6.0
414---------------------------
415
416** Bug
417 * [FELIX-737] - Resolver does not correctly discard export when module imports the same package (part 2)
418 * [FELIX-852] - Fragment support is currently limited to directly resolved hosts
419 * [FELIX-869] - SCR throws exception on invalidating a component with a reference to a service that was already unregistered
420 * [FELIX-891] - Bundle lock acquisition should not record lock until it verifies the bundle is lockable
421 * [FELIX-892] - ServiceReferenceImpl improper implementation of equals and hashcode
422 * [FELIX-893] - Felix fails to start using J9 JVM
423 * [FELIX-897] - Empty system package is exported when a semicolon is present in "extra" configuration
424 * [FELIX-902] - Empty bundle.state file produces NPE
425 * [FELIX-910] - Framework may ignore framework startlevel on startup
426 * [FELIX-911] - Potential deadlock between Bundle.stop() and BundleContext.registerService()
427 * [FELIX-915] - PackageAdmin returns null on getBundle(...) with system classes
428 * [FELIX-934] - Bootdelegation bug
429 * [FELIX-947] - Behaviour of startlevel comman doesn't adhere to spec
430 * [FELIX-948] - ServiceReferenceImpl.compareTo should handle other types than integer for service ranking
431 * [FELIX-951] - Deadlock in iPojo when stopping Felix
432 * [FELIX-952] - Exception thrown when unregistering services because the bundle is stopped
433 * [FELIX-953] - Bundle#loadClass sometimes return null instead of throwing a CNFE
434 * [FELIX-961] - 100% CPU looping inside uses calculation
435 * [FELIX-962] - Erroneous class loading delegation to the application launcher classloader in some cases
436 * [FELIX-969] - system bundle does not correctly handle (export) package attributes
437 * [FELIX-971] - Exception thrown in ServiceTracker at shutdown
438 * [FELIX-978] - Resolver does not clean up properly on a failed recursive attempt to resolve
439 * [FELIX-1004] - Extensionmanager openConnection(URL) method should be public
440 * [FELIX-1005] - Strange list of imported packages returned by the package admin
441
442** Improvement
443 * [FELIX-681] - Modify daemon threads to catch all exceptions and log them to avoid premature thread death
444 * [FELIX-851] - Refactor the module abstraction layer to align more closely to OSGi concepts
445 * [FELIX-872] - JarContent swallows exception when opening manifest, it should log it
446 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
447 * [FELIX-894] - Loosen locking when starting/stopping/uninstalling a bundle by firing event without holding a lock
448 * [FELIX-908] - Unsynchronize access to bundle state inside BundleInfo by making the variable volatile
449
Karl Pauls1be3b032008-12-20 16:27:49 +0000450Changes from 1.4.0 to 1.4.1
451---------------------------
452
453* [2008-12-19] Refactor the URLHandlers implementation to fix a possible
454 Linkage-Error when running embedded inside tomcat. Furthermore, make it possible
455 to dynamically set a SecurityManager, change the url we add to the framework
456 classloader to fix issues with rmi and make sure we restore the previous URLStreamHandlerFactory
457 after stopping. (FELIX-842, FELIX-837, FELIX-844, FELIX-827)
458* [2008-12-19] Add missing javax.security.cert in JRE 1.4 and 1.5. (FELIX-854)
459* [2008-12-19] Improve framework internal locking protocol.
460* [2008-12-18] Fixed an issue where bundles with a non-existing native library
461 would not be removed correctly. (FELIX-835)
462* [2008-11-21] Throw an exception when there is an attempt to start or stop a
463 fragment, as per the spec. (FELIX-820)
464* [2008-11-20] Fixed a bug during shutdown where uninstalled fragments are not
465 properly closed. (FELIX-819)
466* [2008-11-14] Added partial support for new service registry hooks as proposed
467 for OSGi R4.2; currently, only listener hooks are supported. (FELIX-804)
468* [2008-11-08] Fixed Felix' delegation hack so that it correctly delegates to
469 the parent class loader for resources as appropriate; previously it was always
470 delegating for class loading, which was incorrect. (FELIX-808)
471
Karl Pauls89beb9b2008-11-06 16:17:00 +0000472Changes from 1.2.2 to 1.4.0
473---------------------------
Karl Pauls1be3b032008-12-20 16:27:49 +0000474
Karl Pauls89beb9b2008-11-06 16:17:00 +0000475* [2008-11-05] URLStreamHandlerService and ContentHandlerService override
476 built-in handlers and make it possible to use URLHandlers when extending the
477 Felix class. (FELIX-756, FELIX-800)
478* [2008-11-04] Implement ServiceReference.compareTo() method. (FELIX-799)
479* [2008-10-31] Fix some visibility issues in the LDAP operators which could
480 result in incorrect toString values. (FELIX-765)
481* [2008-10-31] Fixed spec compliance issues around getting a service reference
482 from an invalid registration and throwing an exception when there are
483 duplicate property keys. (FELIX-798)
484* [2008-10-21] Fixed an issue with extension bundles which would be installed
485 as fragments and fail to install extension bundles if they have incomplete
486 metadata. (FELIX-770)
487* [2008-10-21] Fix a possible deadlock in URLHandlers. (FELIX-748)
488* [2008-10-16] Modified framework to have default values for the system
489 packages property, which also required modifying main to no longer expect to
490 set it. Now it is possible to start Felix with no configuration properties.
491 (FELIX-753)
492* [2008-10-16] Update felix to work with the 1.0.0-rc1 version of the android
493 sdk.
494* [2008-10-15] Implemented remaining PackageAdmin methods from R4. (FELIX-35)
495* [2008-10-15] Modified resolver to correctly mark fragment modules as resolved.
496 (FELIX-777)
497* [2008-10-15] Modified the resolver to longer consider uninstalled fragments
498 and hosts when resolving dependencies; this required a new "stale" flag on
499 modules that gets set when their associated bundle is uninstalled. (FELIX-776)
500* [2008-10-15] Modified the resolver to sort candidates when resolving
501 Require-Bundle dependencies. (FELIX-775)
502* [2008-10-14] Modified ExportedPackage.getImportingBundles() to include
503 bundles requiring the exporting bundle, in addition to those bundles
504 importing the package. Also tried to simplify dependency management code
505 by separating it out. (FELIX-764)
506* [2008-10-14] Fix a NullPointerException in SecureAction when a
507 SecurityManager is used by keeping pointers on the local stack. (FELIX-766)
508* [2008-10-13] Use System.gc to allow to update and uninstall bundles with
509 native libs on Windows. (FELIX-733)
510* [2008-10-10] Set the activator to null on Bundle.stop() to allow for earlier
511 garbage collection. (FELIX-762)
512* [2008-10-10] Implements support for flushing the cache on framework
513 initialization. (FELIX-755)
514* [2008-10-10] Improve exception messages. (FELIX-750)
515* [2008-10-09] Modified the bundle cache to no longer have profiles. (FELIX-754)
516* [2008-10-08] Modified the Felix API to aligned with the proposed standard
517 OSGi framework API. The framework instance can now be stopped and restarted.
518 (FELIX-753)
519* [2008-09-29] Support transiently starting/stopping bundles. (FELIX-713)
520* [2008-09-25] Correctly discard exported packages when a bundle is chosen to
521 import a package it exports. (FELIX-736)
522* [2008-09-24] Clearly distinguish between "resolved" and "unresolved"
523 capabilities, which is necessary since "resolved" capabilities have higher
524 priority than "unresolved" ones. (FELIX-730)
525* [2008-09-24] Do not bootdelegate in the case where Bundle.loadClass() has
526 been used. (FELIX-712)
527* [2008-09-23] Improve decoding of reference URLs. (FELIX-731)
528* [2008-09-23] For completeness, added symbolic names to framework and main.
529* [2008-09-17] Improve gc by fixing an issue with StartLevel and PackageAdmin.
530 (FELIX-728)
531* [2008-09-15] Fix an issue with Require-Bundle not aggregating packages
532 correctly. (FELIX-722)
533* [2008-09-15] Fixed a bug where class loader delegation for dynamic imports
534 was happening when it shouldn't. (FELIX-724)
535* [2008-09-12] Added a configuration property to determine whether installing a
536 fragment that uses unimplemented features throws an exception or logs a
537 warning. (FELIX-725)
538* [2008-09-12] Removed some experimental code for "implicit requirements",
539 since it was no longer needed.
540* [2008-09-12] Fix some visibility issues within the LDAP filter. (FELIX-721)
541
542Changes from 1.2.1 to 1.2.2
543---------------------------
Karl Pauls1be3b032008-12-20 16:27:49 +0000544
Karl Pauls89beb9b2008-11-06 16:17:00 +0000545* [2008-10-14] Fixed a NullPointer exception that could happen when
546 running with a SecurityManager as a backport of FELIX-766.
547
Karl Paulsfa99d5e2008-09-07 19:54:09 +0000548Changes from 1.2.0 to 1.2.1
549---------------------------
550
551* [2008-09-05] Fixed a performance regression that was caused by uncached
552 access to the bundle manifest headers. (FELIX-711)
553* [2008-09-03] Fixed a bug in calculating the system bundle's exported
554 packages which added a null export package.
555
Karl Pauls30d88e12008-08-31 22:15:39 +0000556Changes from 1.0.4 to 1.2.0
557---------------------------
558
559* [2008-08-29] Support JAR-wide manifest package metadata. (FELIX-682)
560* [2008-08-29] Throw an exception when installing a fragment that uses
561 features that we do not support.
562* [2008-08-20] Improve error reporting when loading bundle classes using
563 Bundle.loadClass.
564* [2008-08-16] Fix attribute checking when resolving dynamic imports.
565 (FELIX-676)
566* [2008-08-08] Implement singleton bundle support. (FELIX-102)
567* [2008-08-06] Default to current security policy if no security extension is
568 installed in order to make Subject.doAs work. (FELIX-654)
569* [2008-08-04] Return Bundle.getLastModified() for bundle URLs
570 lastModified(). (FELIX-582)
571* [2008-08-04] Improve handling of improper resource URLs. (FELIX-577)
572* [2008-08-01] Add necessary stub methods to implement new R4.1 methods.
573 (FELIX-595)
574* [2008-08-01] Applied patch to properly return symbolic name when it has
575 parameters. (FELIX-650)
576* [2008-07-25] Fix some rollback issues after a bundle update throws an
577 exception. (FELIX-647)
578* [2008-07-23] Modified manifest parser to be more lenient. (FELIX-641)
579* [2008-07-07] Add support for the standard symbolic name for the system
580 bundle. (FELIX-602)
581* [2008-06-01] Add initial fragment support for extending the host bundle
582 class path. (FELIX-29, FELIX-656)
583
Karl Paulsecf4cc82008-04-21 23:32:57 +0000584Changes from 1.0.3 to 1.0.4
585___________________________
586
587* [2008-04-18] Check that the returned object from a service factory is an
588 instance of all classes named when the service was registered. (FELIX-540)
589* [2008-04-13] Fix an issue when logging messages while holding framework
590 internal locks that could lead to a deadlock. For now we just disable
591 logging to log services inside the framework. (FELIX-536)
592* [2008-04-13] Implemented various small performance improvments e.g.,
593 we now cache filters and create an index for objectclass to improve
594 service lookup performance and don't use the BundleInfo to get the
595 bundle id but the BundleImpl directly. Furthermore, we added an index to
596 get bundles by id.
597* [2008-04-04] Fix an NoClassDefFoundError when trying to query the
598 framework classloader for whether a class is available or not.
599* [2008-03-19] Don't try to resolve extension bundles and fix a
600 classcastexception that could happen if more then one framework is around
601 and both have extensions installed. Furthermore, make extension bundles
602 use the system bundle context.
603* [2008-03-07] Bundle.getResource does now check for AdminPermission.
604 (FELIX-150)
605* [2008-03-06] Make urlhandlers work when a handler factory is already set.
606 Furthermore, it is now possible to have more then one framework running
607 in more then one classloader. (FELIX-38).
608* [2008-03-05] Make LDAP filter reentrant.
609* [2008-02-29] Refactored the IContent abstraction from the module loader
610 layer to provide more generic access to the content of the module. This
611 makes it possible that a bundle's class path could span multiple module's,
612 which will be necessary for fragments. (FELIX-29)
613* [2008-02-27] Applied a patch to disable the class loading diagnostic message
614 when the logger is not at the DEBUG level. (FELIX-500)
615* [2008-02-15] Modified the service registry to use more fine-grained locking
616 to avoid callbacks to service factories while holding locks. (FELIX-489)
617
Karl Pauls7db0d882008-01-28 09:37:24 +0000618Changes from 1.0.1 to 1.0.3
Karl Paulsc0335862008-01-27 19:49:56 +0000619---------------------------
620
621* [2008-01-27] Moved framework docs to main, since the launcher examples now
622 depend on main for the auto-property handling.
623* [2008-01-25] Applied patches to improve how Felix finds resources when
624 getResources() is called. (FELIX-466, FELIX-467)
625* [2008-01-25] Make FilterImpl.toString() add escape characters where needed.
626 (FELIX-471)
627* [2008-01-16] Fix a NPE on framework restart when extension bundles are
628 installed.
629* [2008-01-15] Try to fix a potential visibility issue on loading a class
630 form a bundle where it seems to be possible that we create two classloaders
631 instead of one.
632* [2008-01-15] Modified boot delegation to not terminate when delegating to
633 parent class loader for non-java.* packages. (FELIX-463)
634* [2008-01-04] Fix some issues related to directories on the bundle class
635 path. Specifically, leading slashes created an issue and are now stripped
636 and entries were not being properly filtered when enumerating the contents
637 of a class path directory. (FELIX-426)
638* [2007-12-20] Modified logger to have all of its public methods be final to
639 avoid it from being extended in undesired ways via the constructor supplied
640 logger. (FELIX-428)
641* [2007-12-20] The TCK has changed to verify that bundles do not depend on
642 themselves, so we filter that case now.
643* [2007-12-20] Applied patch from Guillaume Nodet to properly fire a framework
644 error event only when a bundle cannot be resolved. (FELIX-441)
645* [2007-12-19] Modified framework to accept a Logger instance so that host
646 applications can do custom logging until the log service arrives. (FELIX-428)
647* [2007-12-19] Add support for loading bundles on Google Android (FELIX-440).
648* [2007-12-18] Improve native code loading - bundle installation will now
649 fail in case a native library is not in the jar and we only use the first
650 library of a given name. Furthermore, we now support .dylib extensions on
651 the mac as well as others; should make it possible to use .netmodules as
652 well. (FELIX-439)
653* [2007-12-17] Make the win32 alias match any version of windows for native
654 clauses. (FELIX-438)
655* [2007-12-14] Removed auto-property processing out of the framework and
656 into the default launcher, i.e, main. (FELIX-393)
657* [2007-12-13] Fix a StackOverflowError in URLHandlers.createStreamHandler()
658 when creating URL on jamvm and Mika. This patch resolves an unfortunate
659 interaction between our ExtensionManager and the URLHandlers by making the
660 URLHandlers aware of the extension protocol. Pretty much like we do already
661 for the bundle protocol. (FELIX-435)
662* [2007-11-26] Fix a small oversight in the extension manager that could lead
663 to a null pointer exception and save some memory by creating less objects.
664* [2007-11-26] Degrate to version 0.0.0 if we can not find the Felix.properties
665 for some reason and avoid a null pointer in this case.
666* [2007-11-08] Reorganized usage count methods to better handle null
667 reference checking in response to Karl Pauls seeing an NPE when trying to
668 get a service that was already unregistered while shutting down the
669 framework.
670* [2007-11-06] Added a simple check to detect and work around a bug in J9.
671 (FELIX-416)
672* [2007-10-30] Change how the extension manager url stream handler handles
673 request to the root path in order to make some tomcat issue go away.
674 (FELIX-414)
675* [2007-10-26] Added support for "/" bundle resources as requested. (FELIX-383)
676* [2007-10-24] Use system bundle when firing a framework error event when an
677 install error occurs.
678* [2007-10-22] Fix a NPE when getEntryPaths is called on the system bundle.
679 (FELIX-394)
680* [2007-10-16] Modifies bundle resource URL handling such that if a resource
681 URL points to a resource that does not exist, a bundle class path search
682 for the resource will be instigated and if any matching resource is found,
683 that one will be used instead. (FELIX-383)
684* [2007-10-10] Auto-property handling now installs bundles into the default
685 bundle start level if a start level is not specified. (FELIX-359)
686* [2007-10-08] Overwrite the URLStreamHandler.getHostAddress(URL) in the
687 ExtensionManager to immediately return null to prevent DNS lookup.
688 (FELIX-388)
689* [2007-09-30] Resolved a concurrency issue that could result in the same
690 bundle being resolved more than once; also tried to simplify locking in
691 the core search policy implementation. (FELIX-381)
692
Karl Pauls305c9642007-09-16 20:46:04 +0000693Changes from 1.0.0 to 1.0.1
694---------------------------
695
696* [2007-07-23] Fixed a bug in the framework shutdown process which was
697 causing threads calling Felix.stopAndWait() to not get notified that
698 the framework had shutdown. (FELIX-329)
699* [2007-08-15] Fixed a bug in the LDAP filter which was not thread safe
700 on execution. (FELIX-338)
701* [2007-08-17] Added support for persistent last used bundle ID to avoid
702 re-use of bundle identifiers. (FELIX-339)
703* [2007-08-23] Modified BundleImpl.getHeaders(Locale) to accept a null
704 locale. (FELIX-346)
705* [2007-09-11] Added support to handle external termination of Felix
706 which was not handled or detected and prevented a restart of future
707 Felix instances in the same VM. (FELIX-363)
708* [2007-09-12] Add support for Collection values in the LDAP filter to
709 match the 4.1 spec.
710* [2007-09-12] Fixed a bug in the LDAP filter where attributes where
711 limited to [a-zA-Z ] so didn't allow for e.g., numbers. (FELIX-361)
712* [2007-09-13] Enable support for exporting the same package more than
713 once (FELIX-101).
714* [2007-09-13] Returns the system bundle from a call to
715 PackageAdmin.getBundle(Class) in case the class comes from the
716 classloader (or one of its parents) that loaded Felix and the system
717 bundle exports the package.
718* [2007-09-16] Fixed a bug in class space filtering in the service registry
719 that could result in class cast exceptions for service clients.
720* [2007-09-16] Fixed a bug that prevented extension bundle exports to be
721 usable.
722
Richard S. Hall2cd5bed2007-07-16 20:32:41 +0000723Changes from 0.8.0-incubator to 1.0.0
724-------------------------------------
725
726* [2007-01-18] Added support for bundle header localization. (FELIX-27)
727* [2007-01-22] Modified framework resolver to support a generic
728 capability/requirement model.
729* [2007-01-22] Reorganized and centralized manifest parsing code and added
730 support for resolver's generic capability/requirement model. (FELIX-98)
731* [2007-01-22] Improved native library naming normalization. (FELIX-26)
732* [2007-01-23] No longer eagerly resolving classes loaded from modules
733 since this was causing verification errors with IBM J9.
734* [2007-01-25] Added some support for execution environment checking.
735 (FELIX-23)
736* [2007-01-29] Added support for getAllServiceReferences(). (FELIX-32)
737* [2007-01-31] Added Require-Bundle support to resolve using the generic
738 capability/requirement model of the resolver. (FELIX-28)
739* [2007-02-05] Fixed a bug in processor type normalization for x86-64
740 processors.
741* [2007-02-09] The resolver previously ignored packages that were pending
742 removal when resolving new bundles, now it does not.
743* [2007-02-09] Bundles are automatically refreshed when updated/uninstalled
744 if none of their exported packages are in use.
745* [2007-02-13] Added support for extension bundles. (FELIX-30)
746* [2007-03-02] Added a Bundle.getBundleContext() method until actual
747 support for OSGi R4.1.
748* [2007-04-26] Modified Bundle.findEntries() to return URLs to directory
749 entries as well as file entries.
750* [2007-05-06] Modified LDAP evaluator to special case the fact that
751 BigDecimal is not available in Foundation profile.
752* [2007-05-21] Made some performance improvements in LDAP evaluation.
753* [2007-05-22] Modified JAR file to include Service Tracker package.
754* [2007-05-22] Improved concurrency handling around checking for already
755 loaded classes and defining classes.
756* [2007-06-05] Modified resource URLs to use port number rather than
757 prepend information to the resource path.
758* [2007-06-13] Improved dynamic imports to cycle through all available
759 candidates when checking for class space consistency.
760* [2007-06-18] Improved service registry filtering based on class versions
761 to allow a bundle to register a service for a different version of class
762 that it can access.
763* [2007-06-21] Modified our "last ditch effort" to guess when to delegate
764 to the system bundle to make it a little more robust.
765* [2007-06-29] Fixed a bug in EventDispatcher that was causing asynchronous
766 events to not be fired after stopping the framework instance and creating
767 a new instance. (FELIX-314)
768* [2007-07-03] Fixed a bug in EventDispatcher that would not correctly
769 update a listener when it implemented multiple listener interfaces.
770* [2007-07-04] Modified Felix framework class to implement the Bundle
771 interface to improve the startup/shutdown sequence and to provide a
772 simplified API for creating framework instances.
773* [2007-07-11] Removed the PropertyResolver-related classes and now only
774 use Maps for configuration properties. (FELIX-324)