blob: a95ad4a157cd88027b1657433c345155101b360b [file] [log] [blame]
Karl Pauls74d9aca2010-06-06 21:23:05 +00001Changes from 2.0.5 to 3.0.0
2---------------------------
3** Sub-task
4 * [FELIX-2036] - Improve resolver's generic capability/requirement model
5 * [FELIX-2037] - Improve resolver performance by making solution space searching smarter
6
7** Bug
8 * [FELIX-995] - JRE packages are exported with wrong version
9 * [FELIX-1967] - Freeze finding consistent class space
10 * [FELIX-2080] - Updating bundles when debugging switched on might result in a deadlock with 100% CPU usage
11 * [FELIX-2150] - URLStreamHandlerProxy.setURL may not set query component correctly
12 * [FELIX-2172] - Extremely long resolve stage when running CXF-DOSGi system test
13 * [FELIX-2177] - Fragment bundles not loaded after second start when using autodeploy
14 * [FELIX-2271] - CLONE -NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
15 * [FELIX-2273] - getClassLoader-permission required accessing classes from dynamically loaded class
16 * [FELIX-2281] - Bundle id order affects fragment resolution success
17 * [FELIX-2317] - Possible NPE for jars with null Manifest
18 * [FELIX-2321] - BundleException type should be properly set when installing a duplicate bundle
19 * [FELIX-2332] - Lots of contention on ExtensionManager.openConnection(URL)
20 * [FELIX-2335] - Bundle.loadClass() for system bundle doesn't obey boot delegation
21 * [FELIX-2356] - extension bundle cannot load class from embed jar
22 * [FELIX-2383] - Bundles are restarted during start level change
23 * [FELIX-2392] - Felix framework uses a Java5 method
24
25** Improvement
26 * [FELIX-1210] - Allow jars with missing intermediate entries to be handled as if they were present in Bundle.getEntryPaths
27 * [FELIX-1797] - Customizable Framework startup message
28 * [FELIX-2035] - Reimplement framework resolver
29 * [FELIX-2039] - Reimplement standard OSGi LDAP filter to use new filter solution for resolver
30 * [FELIX-2040] - Modify framework service registry to use resolver's new capability/requirement model
31 * [FELIX-2041] - Look into using generics in framework code
32 * [FELIX-2042] - Use Gogo as the default shell for the framework distribution
33 * [FELIX-2324] - Support execution environment so that OBR works properly
34 * [FELIX-2336] - Variable substitution in configuration files should ignore mismatched delimiters
35
36Changes from 2.0.4 to 2.0.5
37---------------------------
38** Bug
39 * [FELIX-1753] - The start level should check that the bundle still exists before starting it to avoid an ugly exception
40 * [FELIX-2087] - NPE "name can't be null" when trying to install a bundle in Felix 2.0.3
41 * [FELIX-2107] - Bundle.findEntries() matches '*<filePattern>' instead of '<filePattern>'
42 * [FELIX-2195] - Using URLDecoder.decode on locations is wrong
43 * [FELIX-2222] - Failure to reinstall a cached bundle will corrupt the bundle cache
44
Karl Pauls1da29612010-02-14 22:08:33 +000045Changes from 2.0.3 to 2.0.4
46---------------------------
47
48** Bug
49 * [FELIX-2056] - URLHandlersStreamHandler not getting handlers from frameworks that are inside a different classloader
50 * [FELIX-2067] - Fragment bundle ignored silently when the host Bundle-SymbolicName equals import package name
51 * [FELIX-2073] - The System Bundle is not providing WS Addressing
52
53** Improvement
54 * [FELIX-2071] - Missing checks inside ModuleImpl (in Framework) which causes exceptions
55
Karl Pauls6532a9d2010-02-04 22:44:52 +000056Changes from 2.0.2 to 2.0.3
57---------------------------
58
59** Bug
60 * [FELIX-1838] - PackageAdmin.getExportedPackages() duplicates output for packages with different version
61 * [FELIX-1867] - ModuleImpl diagnoseClassLoadError throw NullPointerException for empty package name in debug mode
62 * [FELIX-1917] - A few minor bugs in the framework found while embedding Felix
63 * [FELIX-1919] - Fragment bundle cannot be linked to its host
64 * [FELIX-1920] - RequiredBundle.getRequiringBundles() incorrectly calculates result
65 * [FELIX-1929] - getStartLevel() always reports requested start level, not active start level
66 * [FELIX-1982] - Documented but uninterpreted felix.cache.* properties
67 * [FELIX-1998] - Use UTF-8 when decoding reference location URLs
68 * [FELIX-2002] - Uninstalled fragments are not properly detached
69
70** Improvement
71 * [FELIX-37] - Implement security for bundle resource URLs
72 * [FELIX-325] - Factor out security checks from the framework/system bundle code
73 * [FELIX-1973] - Implement all required security checks
74
75** New Feature
76 * [FELIX-30] - Implement extension bundles
77 * [FELIX-1991] - Allow boot delegation class loader to be configurable per bundle
78
79
Karl Pauls499184a2009-11-01 19:22:20 +000080Changes from 2.0.1 to 2.0.2
81---------------------------
82
83** Bug
84 * [FELIX-1754] - Usage of BundleContext.getServiceReferences results in failure to activate components
85 * [FELIX-1782] - Errors during start-up on gnu/classpath based VMs (jamvm, kaffe, cacao) and mika
86 * [FELIX-1795] - Bundle version ignored in Fragment-Host header
87 * [FELIX-1834] - java.io.IOException: No framework context found when embedding felix frameworks as bundles
88
89** Improvement
90 * [FELIX-1534] - Improve fragment merging
91 * [FELIX-1781] - Try to reduce object allocations/usage in resolver algorithm
92 * [FELIX-1783] - Eliminate contention on ServiceRegistry.getServiceReferences(String, Filter)
93
Karl Pauls1be8b552009-10-11 20:26:42 +000094Changes from 2.0.0 to 2.0.1
95---------------------------
96
97** Bug
98 * [FELIX-1565] - Deadlock UrlHandlers
99 * [FELIX-1573] - Occasional NPE in URLHandlersBundleStreamHandler
100 * [FELIX-1580] - Regression with native library handling
101 * [FELIX-1586] - Framework reports org.osgi.framework.version as 1.3
102 * [FELIX-1600] - ServiceReference.isAssignableTo() always returns true if requesting bundle has no wire
103 * [FELIX-1631] - Implicit bootdelegation causes hang on android
104 * [FELIX-1710] - Resolver still does not discard all partial results when a cyclical dependency fails
105 * [FELIX-1721] - Framework boot delegation has a bug due to extraneous code
106 * [FELIX-1731] - Native library extraction could be improved to help cases where there are dependencies among libraries
107
108** Improvement
109 * [FELIX-1619] - Change the default auto-deploy actions to be install and start only
110 * [FELIX-1625] - Refactor bundle cache to simplify management
111 * [FELIX-1679] - VersionRange class should use finals to be thread safe.
112 * [FELIX-1724] - Various module metadata should be cached
113
114** Task
Karl Pauls1be8b552009-10-11 20:26:42 +0000115 * [FELIX-1617] - Modify framework, main, shell, shell.tui, and obr to depend on official OSGi JAR files
116
Karl Pauls43002282009-09-06 22:01:29 +0000117Changes from 1.8.1 to 2.0.0
118---------------------------
119
120** Bug
121 * [FELIX-893] - Felix fails to start using J9 JVM
122 * [FELIX-905] - Felix needs an RFC 126 FindHook
123 * [FELIX-906] - Felix needs an RFC 126 EventHook
124 * [FELIX-1122] - Extension bundles are not being removed from the bundle list when uninstalled
125 * [FELIX-1123] - System bundle does still not correctly handle (export) package attributes
126 * [FELIX-1124] - ResourceNotFoundException too verbose
127 * [FELIX-1130] - Bundle.getHeaders() returns a Dictionary<java.util.jar.Attribute.Name,String>
128 * [FELIX-1138] - URL Handlers performance regression due to service lookups
129 * [FELIX-1170] - MemoryLeak when stopping and restarting Felix
130 * [FELIX-1187] - BundleContext.ungetService() should return false only if the usage count is zero when the method is invoked
131 * [FELIX-1197] - Bundle Fragments not resolved correctly
132 * [FELIX-1198] - config.properties still refers to old org.osgi.framework.startlevel property
133 * [FELIX-1247] - BundleEvent.UNRESOLVED should be fired during update/uninstall not refresh
134 * [FELIX-1249] - Bundle.findEntries() should search fragments as well as the bundle itself
135 * [FELIX-1254] - Bundle#findEntries does not return resources from fragments
136 * [FELIX-1271] - Improve manifest localization to handle special cases
137 * [FELIX-1272] - Need to special case getResource()/getResources()/loadClass() for fragment bundles
138 * [FELIX-1273] - Bundle.getResources() should return null for a non-existent resource
139 * [FELIX-1277] - Fix Service Hooks Tests failures in RFC 126 TCK
140 * [FELIX-1279] - Framework.waitForStop() does not obey timeout
141 * [FELIX-1280] - Package Admin - getExportedPackages must return null instead of an empty array
142 * [FELIX-1285] - SecureAction captures the calling context incorrectly
143 * [FELIX-1286] - Module class loader should use secure action instead of a privileged block
144 * [FELIX-1287] - System bundle operations from RFC-132 (e.g., init(), start(), stop(), waitForStop()) are using wrong lock object
145 * [FELIX-1288] - System bundle context should be null after stopping the framework
146 * [FELIX-1292] - PackageAdmin.getBundle(Class) should return null if the bundle associated with the passed in class is from another framework
147 * [FELIX-1293] - StringMap used for case insensitive properties does not respect ordering if case sensitivity is changed
148 * [FELIX-1295] - ServiceRegistry increments/decrements service use count after/before getService/ungetService() is called on ServiceFactory
149 * [FELIX-1371] - Automatic parent class loader delegation does not correctly filter calls to Bundle.loadClass()
150 * [FELIX-1397] - Required execution environment verification should happen at resolve time, not install time
151 * [FELIX-1400] - bootdelegation and dynamic-import-packages are accepting invalid patterns
152 * [FELIX-1401] - Manifest localization with fragments not handled correctly
153 * [FELIX-1422] - Resolver does not always discard partial results when a cyclically dependency fails
154 * [FELIX-1435] - Resolver does not always resolve a dynamic import to a fragment export
155 * [FELIX-1527] - R4.2 spec errata now specifies uninstalling a bundle must transition through INSTALLED on its way to UNINSTALLED
156 * [FELIX-1551] - Start level service must synchronously persist bundle start level changes
157 * [FELIX-1556] - Bundle.getResource/s is not able to find resources if the package is not alraedy wired when I use DynamicImport-Package: *
158
159** Improvement
160 * [FELIX-712] - Ability to disable automatic parent classloader delegation
161 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
162 * [FELIX-1120] - Enable BundleCache customization
163 * [FELIX-1134] - Add support for native libraries in fragments
164 * [FELIX-1189] - Improve error message in main when there is an error processing auto-install/start bundles
165 * [FELIX-1246] - PackageAdmin.getBundle() is not implemented efficiently
166 * [FELIX-1260] - Make Bundle.findEntries() and Bundle.getEntryPaths() more thread safe
167 * [FELIX-1291] - Implement support for proper return type from Framework.waitForStop()
168 * [FELIX-1300] - Remove legacy bundle cache support when extracting embedded JAR files
169 * [FELIX-1360] - Improve native library matching algorithm (part 2)
170 * [FELIX-1404] - Use provided classes from OSGi R4.2 companion code
171 * [FELIX-1432] - Manifest parser doesn't return import package declarations in order of manifest
172 * [FELIX-1462] - Felix framework launcher should only use standard launching API
173
174** New Feature
175 * [FELIX-33] - Implement system bundle update
176 * [FELIX-749] - Add support for lazy activation of bundles
177 * [FELIX-1193] - Implement org.osgi.framework.bundle.parent from RFC 132
178 * [FELIX-1205] - Update to the latest OSGi R4.2 API
179 * [FELIX-1244] - Add support for ServiceEvent.MODIFIED_ENDMATCH
180 * [FELIX-1250] - Support service exceptions for service factories
181 * [FELIX-1289] - Support for FrameworkUtil.getBundle()
182 * [FELIX-1297] - Implement support for new org.osgi.framework.command.execpermission configuration property
183 * [FELIX-1298] - Implement support for new org.osgi.framework.library.extensions configuration property
184 * [FELIX-1446] - Framework launcher should automatically deploy bundles in bundle directory
185 * [FELIX-1478] - Add shutdown hook to launcher to cleanly shutdown the framework if the process is killed
186
187
188
189
190** Task
191 * [FELIX-1144] - The NOTICE file for Main subproject is not correctly copied into the source JAR
192
193
194** Test
195 * [FELIX-1208] - Need migrate the EventDispatcherTest to newer version of EasyMock
196
Karl Pauls1919aa72009-05-10 21:17:30 +0000197Changes form 1.6.1 to 1.8.0
198---------------------------
199** Bug
200 * [FELIX-1034] - bootdelegation property seems to be matching more packages than desired
201 * [FELIX-1059] - DynamicImport-Package matches more packages than desired
202
203** Improvement
204 * [FELIX-1060] - URLHandlers doesn't support URLStreamHandler.openConnection(proxy,url) method
205
206** New Feature
207 * [FELIX-29] - Implement bundle fragments
208
Karl Pauls962f89f2009-04-26 20:36:08 +0000209Changes from 1.6.0 to 1.6.1
210---------------------------
211** Bug
212 * [FELIX-1027] - deadlock with felix 1.6.0 ?
213 * [FELIX-1028] - NPE in configuration view when running webconsole with Equinox
214 * [FELIX-1033] - Exceptions when Felix is started with security manager
215 * [FELIX-1035] - deadlock observed while using fileinstall to monitor multiple directories
216 * [FELIX-1045] - Felix 1.6.0 fails with ClassCircularityError
217
Karl Pauls62ff7ab2009-03-31 21:06:46 +0000218Changes from 1.4.1 to 1.6.0
219---------------------------
220
221** Bug
222 * [FELIX-737] - Resolver does not correctly discard export when module imports the same package (part 2)
223 * [FELIX-852] - Fragment support is currently limited to directly resolved hosts
224 * [FELIX-869] - SCR throws exception on invalidating a component with a reference to a service that was already unregistered
225 * [FELIX-891] - Bundle lock acquisition should not record lock until it verifies the bundle is lockable
226 * [FELIX-892] - ServiceReferenceImpl improper implementation of equals and hashcode
227 * [FELIX-893] - Felix fails to start using J9 JVM
228 * [FELIX-897] - Empty system package is exported when a semicolon is present in "extra" configuration
229 * [FELIX-902] - Empty bundle.state file produces NPE
230 * [FELIX-910] - Framework may ignore framework startlevel on startup
231 * [FELIX-911] - Potential deadlock between Bundle.stop() and BundleContext.registerService()
232 * [FELIX-915] - PackageAdmin returns null on getBundle(...) with system classes
233 * [FELIX-934] - Bootdelegation bug
234 * [FELIX-947] - Behaviour of startlevel comman doesn't adhere to spec
235 * [FELIX-948] - ServiceReferenceImpl.compareTo should handle other types than integer for service ranking
236 * [FELIX-951] - Deadlock in iPojo when stopping Felix
237 * [FELIX-952] - Exception thrown when unregistering services because the bundle is stopped
238 * [FELIX-953] - Bundle#loadClass sometimes return null instead of throwing a CNFE
239 * [FELIX-961] - 100% CPU looping inside uses calculation
240 * [FELIX-962] - Erroneous class loading delegation to the application launcher classloader in some cases
241 * [FELIX-969] - system bundle does not correctly handle (export) package attributes
242 * [FELIX-971] - Exception thrown in ServiceTracker at shutdown
243 * [FELIX-978] - Resolver does not clean up properly on a failed recursive attempt to resolve
244 * [FELIX-1004] - Extensionmanager openConnection(URL) method should be public
245 * [FELIX-1005] - Strange list of imported packages returned by the package admin
246
247** Improvement
248 * [FELIX-681] - Modify daemon threads to catch all exceptions and log them to avoid premature thread death
249 * [FELIX-851] - Refactor the module abstraction layer to align more closely to OSGi concepts
250 * [FELIX-872] - JarContent swallows exception when opening manifest, it should log it
251 * [FELIX-883] - JarContent logs and then swallows exceptions when reading from JAR file, should probably throw an exception
252 * [FELIX-894] - Loosen locking when starting/stopping/uninstalling a bundle by firing event without holding a lock
253 * [FELIX-908] - Unsynchronize access to bundle state inside BundleInfo by making the variable volatile
254
Karl Pauls1be3b032008-12-20 16:27:49 +0000255Changes from 1.4.0 to 1.4.1
256---------------------------
257
258* [2008-12-19] Refactor the URLHandlers implementation to fix a possible
259 Linkage-Error when running embedded inside tomcat. Furthermore, make it possible
260 to dynamically set a SecurityManager, change the url we add to the framework
261 classloader to fix issues with rmi and make sure we restore the previous URLStreamHandlerFactory
262 after stopping. (FELIX-842, FELIX-837, FELIX-844, FELIX-827)
263* [2008-12-19] Add missing javax.security.cert in JRE 1.4 and 1.5. (FELIX-854)
264* [2008-12-19] Improve framework internal locking protocol.
265* [2008-12-18] Fixed an issue where bundles with a non-existing native library
266 would not be removed correctly. (FELIX-835)
267* [2008-11-21] Throw an exception when there is an attempt to start or stop a
268 fragment, as per the spec. (FELIX-820)
269* [2008-11-20] Fixed a bug during shutdown where uninstalled fragments are not
270 properly closed. (FELIX-819)
271* [2008-11-14] Added partial support for new service registry hooks as proposed
272 for OSGi R4.2; currently, only listener hooks are supported. (FELIX-804)
273* [2008-11-08] Fixed Felix' delegation hack so that it correctly delegates to
274 the parent class loader for resources as appropriate; previously it was always
275 delegating for class loading, which was incorrect. (FELIX-808)
276
Karl Pauls89beb9b2008-11-06 16:17:00 +0000277Changes from 1.2.2 to 1.4.0
278---------------------------
Karl Pauls1be3b032008-12-20 16:27:49 +0000279
Karl Pauls89beb9b2008-11-06 16:17:00 +0000280* [2008-11-05] URLStreamHandlerService and ContentHandlerService override
281 built-in handlers and make it possible to use URLHandlers when extending the
282 Felix class. (FELIX-756, FELIX-800)
283* [2008-11-04] Implement ServiceReference.compareTo() method. (FELIX-799)
284* [2008-10-31] Fix some visibility issues in the LDAP operators which could
285 result in incorrect toString values. (FELIX-765)
286* [2008-10-31] Fixed spec compliance issues around getting a service reference
287 from an invalid registration and throwing an exception when there are
288 duplicate property keys. (FELIX-798)
289* [2008-10-21] Fixed an issue with extension bundles which would be installed
290 as fragments and fail to install extension bundles if they have incomplete
291 metadata. (FELIX-770)
292* [2008-10-21] Fix a possible deadlock in URLHandlers. (FELIX-748)
293* [2008-10-16] Modified framework to have default values for the system
294 packages property, which also required modifying main to no longer expect to
295 set it. Now it is possible to start Felix with no configuration properties.
296 (FELIX-753)
297* [2008-10-16] Update felix to work with the 1.0.0-rc1 version of the android
298 sdk.
299* [2008-10-15] Implemented remaining PackageAdmin methods from R4. (FELIX-35)
300* [2008-10-15] Modified resolver to correctly mark fragment modules as resolved.
301 (FELIX-777)
302* [2008-10-15] Modified the resolver to longer consider uninstalled fragments
303 and hosts when resolving dependencies; this required a new "stale" flag on
304 modules that gets set when their associated bundle is uninstalled. (FELIX-776)
305* [2008-10-15] Modified the resolver to sort candidates when resolving
306 Require-Bundle dependencies. (FELIX-775)
307* [2008-10-14] Modified ExportedPackage.getImportingBundles() to include
308 bundles requiring the exporting bundle, in addition to those bundles
309 importing the package. Also tried to simplify dependency management code
310 by separating it out. (FELIX-764)
311* [2008-10-14] Fix a NullPointerException in SecureAction when a
312 SecurityManager is used by keeping pointers on the local stack. (FELIX-766)
313* [2008-10-13] Use System.gc to allow to update and uninstall bundles with
314 native libs on Windows. (FELIX-733)
315* [2008-10-10] Set the activator to null on Bundle.stop() to allow for earlier
316 garbage collection. (FELIX-762)
317* [2008-10-10] Implements support for flushing the cache on framework
318 initialization. (FELIX-755)
319* [2008-10-10] Improve exception messages. (FELIX-750)
320* [2008-10-09] Modified the bundle cache to no longer have profiles. (FELIX-754)
321* [2008-10-08] Modified the Felix API to aligned with the proposed standard
322 OSGi framework API. The framework instance can now be stopped and restarted.
323 (FELIX-753)
324* [2008-09-29] Support transiently starting/stopping bundles. (FELIX-713)
325* [2008-09-25] Correctly discard exported packages when a bundle is chosen to
326 import a package it exports. (FELIX-736)
327* [2008-09-24] Clearly distinguish between "resolved" and "unresolved"
328 capabilities, which is necessary since "resolved" capabilities have higher
329 priority than "unresolved" ones. (FELIX-730)
330* [2008-09-24] Do not bootdelegate in the case where Bundle.loadClass() has
331 been used. (FELIX-712)
332* [2008-09-23] Improve decoding of reference URLs. (FELIX-731)
333* [2008-09-23] For completeness, added symbolic names to framework and main.
334* [2008-09-17] Improve gc by fixing an issue with StartLevel and PackageAdmin.
335 (FELIX-728)
336* [2008-09-15] Fix an issue with Require-Bundle not aggregating packages
337 correctly. (FELIX-722)
338* [2008-09-15] Fixed a bug where class loader delegation for dynamic imports
339 was happening when it shouldn't. (FELIX-724)
340* [2008-09-12] Added a configuration property to determine whether installing a
341 fragment that uses unimplemented features throws an exception or logs a
342 warning. (FELIX-725)
343* [2008-09-12] Removed some experimental code for "implicit requirements",
344 since it was no longer needed.
345* [2008-09-12] Fix some visibility issues within the LDAP filter. (FELIX-721)
346
347Changes from 1.2.1 to 1.2.2
348---------------------------
Karl Pauls1be3b032008-12-20 16:27:49 +0000349
Karl Pauls89beb9b2008-11-06 16:17:00 +0000350* [2008-10-14] Fixed a NullPointer exception that could happen when
351 running with a SecurityManager as a backport of FELIX-766.
352
Karl Paulsfa99d5e2008-09-07 19:54:09 +0000353Changes from 1.2.0 to 1.2.1
354---------------------------
355
356* [2008-09-05] Fixed a performance regression that was caused by uncached
357 access to the bundle manifest headers. (FELIX-711)
358* [2008-09-03] Fixed a bug in calculating the system bundle's exported
359 packages which added a null export package.
360
Karl Pauls30d88e12008-08-31 22:15:39 +0000361Changes from 1.0.4 to 1.2.0
362---------------------------
363
364* [2008-08-29] Support JAR-wide manifest package metadata. (FELIX-682)
365* [2008-08-29] Throw an exception when installing a fragment that uses
366 features that we do not support.
367* [2008-08-20] Improve error reporting when loading bundle classes using
368 Bundle.loadClass.
369* [2008-08-16] Fix attribute checking when resolving dynamic imports.
370 (FELIX-676)
371* [2008-08-08] Implement singleton bundle support. (FELIX-102)
372* [2008-08-06] Default to current security policy if no security extension is
373 installed in order to make Subject.doAs work. (FELIX-654)
374* [2008-08-04] Return Bundle.getLastModified() for bundle URLs
375 lastModified(). (FELIX-582)
376* [2008-08-04] Improve handling of improper resource URLs. (FELIX-577)
377* [2008-08-01] Add necessary stub methods to implement new R4.1 methods.
378 (FELIX-595)
379* [2008-08-01] Applied patch to properly return symbolic name when it has
380 parameters. (FELIX-650)
381* [2008-07-25] Fix some rollback issues after a bundle update throws an
382 exception. (FELIX-647)
383* [2008-07-23] Modified manifest parser to be more lenient. (FELIX-641)
384* [2008-07-07] Add support for the standard symbolic name for the system
385 bundle. (FELIX-602)
386* [2008-06-01] Add initial fragment support for extending the host bundle
387 class path. (FELIX-29, FELIX-656)
388
Karl Paulsecf4cc82008-04-21 23:32:57 +0000389Changes from 1.0.3 to 1.0.4
390___________________________
391
392* [2008-04-18] Check that the returned object from a service factory is an
393 instance of all classes named when the service was registered. (FELIX-540)
394* [2008-04-13] Fix an issue when logging messages while holding framework
395 internal locks that could lead to a deadlock. For now we just disable
396 logging to log services inside the framework. (FELIX-536)
397* [2008-04-13] Implemented various small performance improvments e.g.,
398 we now cache filters and create an index for objectclass to improve
399 service lookup performance and don't use the BundleInfo to get the
400 bundle id but the BundleImpl directly. Furthermore, we added an index to
401 get bundles by id.
402* [2008-04-04] Fix an NoClassDefFoundError when trying to query the
403 framework classloader for whether a class is available or not.
404* [2008-03-19] Don't try to resolve extension bundles and fix a
405 classcastexception that could happen if more then one framework is around
406 and both have extensions installed. Furthermore, make extension bundles
407 use the system bundle context.
408* [2008-03-07] Bundle.getResource does now check for AdminPermission.
409 (FELIX-150)
410* [2008-03-06] Make urlhandlers work when a handler factory is already set.
411 Furthermore, it is now possible to have more then one framework running
412 in more then one classloader. (FELIX-38).
413* [2008-03-05] Make LDAP filter reentrant.
414* [2008-02-29] Refactored the IContent abstraction from the module loader
415 layer to provide more generic access to the content of the module. This
416 makes it possible that a bundle's class path could span multiple module's,
417 which will be necessary for fragments. (FELIX-29)
418* [2008-02-27] Applied a patch to disable the class loading diagnostic message
419 when the logger is not at the DEBUG level. (FELIX-500)
420* [2008-02-15] Modified the service registry to use more fine-grained locking
421 to avoid callbacks to service factories while holding locks. (FELIX-489)
422
Karl Pauls7db0d882008-01-28 09:37:24 +0000423Changes from 1.0.1 to 1.0.3
Karl Paulsc0335862008-01-27 19:49:56 +0000424---------------------------
425
426* [2008-01-27] Moved framework docs to main, since the launcher examples now
427 depend on main for the auto-property handling.
428* [2008-01-25] Applied patches to improve how Felix finds resources when
429 getResources() is called. (FELIX-466, FELIX-467)
430* [2008-01-25] Make FilterImpl.toString() add escape characters where needed.
431 (FELIX-471)
432* [2008-01-16] Fix a NPE on framework restart when extension bundles are
433 installed.
434* [2008-01-15] Try to fix a potential visibility issue on loading a class
435 form a bundle where it seems to be possible that we create two classloaders
436 instead of one.
437* [2008-01-15] Modified boot delegation to not terminate when delegating to
438 parent class loader for non-java.* packages. (FELIX-463)
439* [2008-01-04] Fix some issues related to directories on the bundle class
440 path. Specifically, leading slashes created an issue and are now stripped
441 and entries were not being properly filtered when enumerating the contents
442 of a class path directory. (FELIX-426)
443* [2007-12-20] Modified logger to have all of its public methods be final to
444 avoid it from being extended in undesired ways via the constructor supplied
445 logger. (FELIX-428)
446* [2007-12-20] The TCK has changed to verify that bundles do not depend on
447 themselves, so we filter that case now.
448* [2007-12-20] Applied patch from Guillaume Nodet to properly fire a framework
449 error event only when a bundle cannot be resolved. (FELIX-441)
450* [2007-12-19] Modified framework to accept a Logger instance so that host
451 applications can do custom logging until the log service arrives. (FELIX-428)
452* [2007-12-19] Add support for loading bundles on Google Android (FELIX-440).
453* [2007-12-18] Improve native code loading - bundle installation will now
454 fail in case a native library is not in the jar and we only use the first
455 library of a given name. Furthermore, we now support .dylib extensions on
456 the mac as well as others; should make it possible to use .netmodules as
457 well. (FELIX-439)
458* [2007-12-17] Make the win32 alias match any version of windows for native
459 clauses. (FELIX-438)
460* [2007-12-14] Removed auto-property processing out of the framework and
461 into the default launcher, i.e, main. (FELIX-393)
462* [2007-12-13] Fix a StackOverflowError in URLHandlers.createStreamHandler()
463 when creating URL on jamvm and Mika. This patch resolves an unfortunate
464 interaction between our ExtensionManager and the URLHandlers by making the
465 URLHandlers aware of the extension protocol. Pretty much like we do already
466 for the bundle protocol. (FELIX-435)
467* [2007-11-26] Fix a small oversight in the extension manager that could lead
468 to a null pointer exception and save some memory by creating less objects.
469* [2007-11-26] Degrate to version 0.0.0 if we can not find the Felix.properties
470 for some reason and avoid a null pointer in this case.
471* [2007-11-08] Reorganized usage count methods to better handle null
472 reference checking in response to Karl Pauls seeing an NPE when trying to
473 get a service that was already unregistered while shutting down the
474 framework.
475* [2007-11-06] Added a simple check to detect and work around a bug in J9.
476 (FELIX-416)
477* [2007-10-30] Change how the extension manager url stream handler handles
478 request to the root path in order to make some tomcat issue go away.
479 (FELIX-414)
480* [2007-10-26] Added support for "/" bundle resources as requested. (FELIX-383)
481* [2007-10-24] Use system bundle when firing a framework error event when an
482 install error occurs.
483* [2007-10-22] Fix a NPE when getEntryPaths is called on the system bundle.
484 (FELIX-394)
485* [2007-10-16] Modifies bundle resource URL handling such that if a resource
486 URL points to a resource that does not exist, a bundle class path search
487 for the resource will be instigated and if any matching resource is found,
488 that one will be used instead. (FELIX-383)
489* [2007-10-10] Auto-property handling now installs bundles into the default
490 bundle start level if a start level is not specified. (FELIX-359)
491* [2007-10-08] Overwrite the URLStreamHandler.getHostAddress(URL) in the
492 ExtensionManager to immediately return null to prevent DNS lookup.
493 (FELIX-388)
494* [2007-09-30] Resolved a concurrency issue that could result in the same
495 bundle being resolved more than once; also tried to simplify locking in
496 the core search policy implementation. (FELIX-381)
497
Karl Pauls305c9642007-09-16 20:46:04 +0000498Changes from 1.0.0 to 1.0.1
499---------------------------
500
501* [2007-07-23] Fixed a bug in the framework shutdown process which was
502 causing threads calling Felix.stopAndWait() to not get notified that
503 the framework had shutdown. (FELIX-329)
504* [2007-08-15] Fixed a bug in the LDAP filter which was not thread safe
505 on execution. (FELIX-338)
506* [2007-08-17] Added support for persistent last used bundle ID to avoid
507 re-use of bundle identifiers. (FELIX-339)
508* [2007-08-23] Modified BundleImpl.getHeaders(Locale) to accept a null
509 locale. (FELIX-346)
510* [2007-09-11] Added support to handle external termination of Felix
511 which was not handled or detected and prevented a restart of future
512 Felix instances in the same VM. (FELIX-363)
513* [2007-09-12] Add support for Collection values in the LDAP filter to
514 match the 4.1 spec.
515* [2007-09-12] Fixed a bug in the LDAP filter where attributes where
516 limited to [a-zA-Z ] so didn't allow for e.g., numbers. (FELIX-361)
517* [2007-09-13] Enable support for exporting the same package more than
518 once (FELIX-101).
519* [2007-09-13] Returns the system bundle from a call to
520 PackageAdmin.getBundle(Class) in case the class comes from the
521 classloader (or one of its parents) that loaded Felix and the system
522 bundle exports the package.
523* [2007-09-16] Fixed a bug in class space filtering in the service registry
524 that could result in class cast exceptions for service clients.
525* [2007-09-16] Fixed a bug that prevented extension bundle exports to be
526 usable.
527
Richard S. Hall2cd5bed2007-07-16 20:32:41 +0000528Changes from 0.8.0-incubator to 1.0.0
529-------------------------------------
530
531* [2007-01-18] Added support for bundle header localization. (FELIX-27)
532* [2007-01-22] Modified framework resolver to support a generic
533 capability/requirement model.
534* [2007-01-22] Reorganized and centralized manifest parsing code and added
535 support for resolver's generic capability/requirement model. (FELIX-98)
536* [2007-01-22] Improved native library naming normalization. (FELIX-26)
537* [2007-01-23] No longer eagerly resolving classes loaded from modules
538 since this was causing verification errors with IBM J9.
539* [2007-01-25] Added some support for execution environment checking.
540 (FELIX-23)
541* [2007-01-29] Added support for getAllServiceReferences(). (FELIX-32)
542* [2007-01-31] Added Require-Bundle support to resolve using the generic
543 capability/requirement model of the resolver. (FELIX-28)
544* [2007-02-05] Fixed a bug in processor type normalization for x86-64
545 processors.
546* [2007-02-09] The resolver previously ignored packages that were pending
547 removal when resolving new bundles, now it does not.
548* [2007-02-09] Bundles are automatically refreshed when updated/uninstalled
549 if none of their exported packages are in use.
550* [2007-02-13] Added support for extension bundles. (FELIX-30)
551* [2007-03-02] Added a Bundle.getBundleContext() method until actual
552 support for OSGi R4.1.
553* [2007-04-26] Modified Bundle.findEntries() to return URLs to directory
554 entries as well as file entries.
555* [2007-05-06] Modified LDAP evaluator to special case the fact that
556 BigDecimal is not available in Foundation profile.
557* [2007-05-21] Made some performance improvements in LDAP evaluation.
558* [2007-05-22] Modified JAR file to include Service Tracker package.
559* [2007-05-22] Improved concurrency handling around checking for already
560 loaded classes and defining classes.
561* [2007-06-05] Modified resource URLs to use port number rather than
562 prepend information to the resource path.
563* [2007-06-13] Improved dynamic imports to cycle through all available
564 candidates when checking for class space consistency.
565* [2007-06-18] Improved service registry filtering based on class versions
566 to allow a bundle to register a service for a different version of class
567 that it can access.
568* [2007-06-21] Modified our "last ditch effort" to guess when to delegate
569 to the system bundle to make it a little more robust.
570* [2007-06-29] Fixed a bug in EventDispatcher that was causing asynchronous
571 events to not be fired after stopping the framework instance and creating
572 a new instance. (FELIX-314)
573* [2007-07-03] Fixed a bug in EventDispatcher that would not correctly
574 update a listener when it implemented multiple listener interfaces.
575* [2007-07-04] Modified Felix framework class to implement the Bundle
576 interface to improve the startup/shutdown sequence and to provide a
577 simplified API for creating framework instances.
578* [2007-07-11] Removed the PropertyResolver-related classes and now only
579 use Maps for configuration properties. (FELIX-324)