Início da mudança

cciGetBrokerInfo

Esta função consulta o ambiente atual do intermediário (por exemplo, para obter informações sobre o nome do intermediário, o nome do grupo de execução e o nome do gerenciador de fila). As informações são retornadas em uma estrutura do tipo CCI_BROKER_INFO_ST.
Nota: Ela difere de cniGetBrokerInfo existente, na qual não é necessário fornecer uma manipulação CciNode*, e o cciGetBrokerInfo não retorna nenhuma informação sobre um fluxo de mensagem. Conseqüentemente, cciGetBrokerInfo pode ser chamado a partir das funções de inicialização, por exemplo, bipInitializeUserExits, bipGetMessageParserFactory e bipGetMessageFlowNodeFactory.

Sintaxe

void cciGetBrokerInfo(
int*         returnCode,
CCI_BROKER_INFO_ST* broker_info_st);

Parâmetros

returnCode (saída)
Recebe o código de retorno da função (saída).
Os possíveis códigos de retorno são:
  • CCI_SUCCESS
  • CCI_INV_BROKER_INFO_ST
  • CCI_EXCEPTION
broker_info_st(saída)
O endereço de uma estrutura CCI_BROKER_INFO_ST a ser preenchida com os valores relevantes em uma conclusão bem-sucedida.

Valores de Retorno

Nenhum Se ocorrer um erro, o parâmetro returnCode indica o motivo do erro.

Exemplo

int              rc = CCI_SUCCESS;
CCI_BROKER_INFO_ST brokerInfo = {CCI_BROKER_INFO_ST_DEFAULT};
#definir INTITIAL_STR_LEN 256
CciChar brokerNameStr[INTITIAL_STR_LEN];
CciChar executionGroupNameStr[INTITIAL_STR_LEN];
CciChar queueManagerNameStr[INTITIAL_STR_LEN];
brokerInfo.brokerName.bufferLength = INTITIAL_STR_LEN;
brokerInfo.brokerName.buffer = brokerNameStr;
brokerInfo.executionGroupName.bufferLength = INTITIAL_STR_LEN;
brokerInfo.executionGroupName.buffer = executionGroupNameStr;
brokerInfo.queueManagerName.bufferLength = INTITIAL_STR_LEN;
brokerInfo.queueManagerName.buffer = queueManagerNameStr;
cciGetBrokerInfo(&rc,&brokerInfo);
/* apenas no caso de algum dos buffers ser muito pequeno*/
if ((brokerInfo.brokerName.bytesOutput < brokerInfo.brokerName.dataLength) ||
(brokerInfo.executionGroupName.bytesOutput < brokerInfo.executionGroupName.dataLength) ||
(brokerInfo.queueManagerName.bytesOutput < brokerInfo.queueManagerName.dataLength)) {
/*pelo menos um dos buffers eram muito pequenos, tente novamente*/
/* NOTA: É improvável que os tamanhos iniciais eram razoavelmente grandes*/
brokerInfo.brokerName.bufferLength =
brokerInfo.brokerName.dataLength;
brokerInfo.brokerName.buffer =
(CciChar*)malloc (brokerInfo.brokerName.bufferLength * sizeof(CciChar));
brokerInfo.executionGroupName.bufferLength =
brokerInfo.executionGroupName.dataLength;
brokerInfo.executionGroupName.buffer =
(CciChar*)malloc (brokerInfo.executionGroupName.bufferLength * sizeof(CciChar));
brokerInfo.queueManagerName.bufferLength =
brokerInfo.queueManagerName.dataLength;
brokerInfo.queueManagerName.buffer =
(CciChar*)malloc (brokerInfo.queueManagerName.bufferLength * sizeof(CciChar));
cciGetBrokerInfo(&rc,&brokerInfo);
/*agora faça algo que tenha sentido com essas cadeias antes de os buffers ficarem fora do escopo*/
/* por exemplo, chame uma função gravada do usuário para copiá-las para outro local*/
copyBrokerInfo(brokerInfo.brokerName.buffer,
brokerInfo.executionGroupName.buffer,
brokerInfo.queueManagerName.buffer);
free((void*)brokerInfo.brokerName.buffer);
free((void*)brokerInfo.executionGroupName.buffer);
free((void*)brokerInfo.queueManagerName.buffer);
}else{
/*agora faça algo que tenha sentido com essas cadeias antes de os buffers ficarem fora do escopo*/
/* por exemplo, chame uma função gravada do usuário para copiá-las para outro local*/
copyBrokerInfo(brokerInfo.brokerName.buffer,
brokerInfo.executionGroupName.buffer,
brokerInfo.queueManagerName.buffer);
}
Conceitos relacionados
Desenvolvendo Saídas do Usuário
Notices | Trademarks | Downloads | Library | Support | Feedback
Copyright IBM Corporation 1999, 2006 Last updated: 5월 25, 2006
as36040_


Fim da mudança