You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@cxf.apache.org by "Daniel Kulp (JIRA)" <ji...@apache.org> on 2008/03/07 02:58:57 UTC
[jira] Updated: (CXF-1435) BusApplicationContext should pass empty
String array to super constructor instead of null
[ https://issues.apache.org/jira/browse/CXF-1435?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Daniel Kulp updated CXF-1435:
-----------------------------
Fix Version/s: (was: 2.0.4)
2.0.5
> BusApplicationContext should pass empty String array to super constructor instead of null
> -----------------------------------------------------------------------------------------
>
> Key: CXF-1435
> URL: https://issues.apache.org/jira/browse/CXF-1435
> Project: CXF
> Issue Type: Bug
> Components: Configuration
> Affects Versions: 2.1.1
> Environment: snapshot 20080130, Spring 2.5.2
> Reporter: Gyorgy Orban
> Assignee: Daniel Kulp
> Fix For: 2.0.5
>
>
> BusApplicationContext extends ClassPathXmlApplicationContext and calls the super constructor (see below) with configLocations == null. In this constructor Spring 2.5.1 calls StringUtils.trimArrayElements(configLocations), which sets configLocations = new String[0], but Spring 2.5.2 no longer does this, which causes a NullPointerException in Spring. Copied here the relevant lines:
> Spring 2.5.2:
> public ClassPathXmlApplicationContext(String[] configLocations, boolean refresh, ApplicationContext parent)
> throws BeansException {
> super(parent);
> setConfigLocations(configLocations);
> if (refresh) {
> refresh();
> }
> }
> /**
> * Set the config locations for this application context.
> * <p>If not set, the implementation may use a default as appropriate.
> */
> public void setConfigLocations(String[] locations) {
> Assert.noNullElements(locations, "Config locations must not be null");
> this.configLocations = new String[locations.length];
> for (int i = 0; i < locations.length; i++) {
> this.configLocations[i] = resolvePath(locations[i]);
> }
> }
> 2.5.1:
> public ClassPathXmlApplicationContext(String[] configLocations, boolean refresh, ApplicationContext parent)
> throws BeansException {
> super(parent);
> Assert.noNullElements(configLocations, "Config location must not be null");
> this.configLocations = StringUtils.trimArrayElements(configLocations);
> if (refresh) {
> refresh();
> }
> }
> public static String[] trimArrayElements(String[] array) {
> if (ObjectUtils.isEmpty(array)) {
> return new String[0];
> }
> ...
> }
> Would it be possible to pass an empty String array in BusApplicationContext to the parent constructor instead of null?
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.