bdedd8b0d3
Reasoning: The old behavior was a little confusing. mca_base_components_open does not open an output stream so it is a little unexpected that mca_base_components_close does. To add to this several frameworks (that don't use mca_base_components_close) failed to close their output in the framework close function and others closed their output a second time. This change is an improvement to the symantics of mca_base_components_open/close as they are now symetric in their functionality. This commit was SVN r27570.
41 строка
941 B
C
41 строка
941 B
C
/*
|
|
* Copyright (c) 2010 Cisco Systems, Inc. All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
|
|
#include "opal_config.h"
|
|
|
|
#include "opal/constants.h"
|
|
#include "opal/mca/mca.h"
|
|
#include "opal/mca/base/base.h"
|
|
#include "opal/mca/event/event.h"
|
|
#include "opal/mca/event/base/base.h"
|
|
|
|
int opal_event_base_close(void)
|
|
{
|
|
opal_list_item_t *item;
|
|
|
|
opal_event_base_inited--;
|
|
|
|
/* no need to close the component as it was statically opened */
|
|
|
|
/* for support of tools such as ompi_info */
|
|
for (item = opal_list_remove_first(&opal_event_components);
|
|
NULL != item;
|
|
item = opal_list_remove_first(&opal_event_components)) {
|
|
OBJ_RELEASE(item);
|
|
}
|
|
OBJ_DESTRUCT(&opal_event_components);
|
|
|
|
/* Close the framework output */
|
|
opal_output_close (opal_event_base_output);
|
|
opal_event_base_output = -1;
|
|
|
|
/* All done */
|
|
return OPAL_SUCCESS;
|
|
}
|