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
Avisos | Marcas Registradas | Downloads | Biblioteca | Suporte | Feedback
Direitos Autorais IBM Corporation 1999, 2006 Última Atualização: 1 Sep 2006
as36040_