Browse Source

cosmetic improvements of the client

Stasik0 10 years ago
parent
commit
44d55e1ef5
1 changed files with 14 additions and 14 deletions
  1. 14 14
      examples/client.c

+ 14 - 14
examples/client.c

@@ -20,35 +20,35 @@ int main(int argc, char *argv[]) {
 	}
 
 	// Browse some objects
-	UA_BrowseDescription bd;
-	UA_BrowseDescription_init(&bd);
-	bd.nodeId = UA_NODEID_NUMERIC(0, UA_NS0ID_OBJECTSFOLDER);
-	bd.resultMask = UA_BROWSERESULTMASK_ALL;	// everything
+	printf("Browsing nodes in objects folder:\n");
+	UA_BrowseDescription* bd = UA_BrowseDescription_new();
+	bd->nodeId = UA_NODEID_NUMERIC(0, UA_NS0ID_OBJECTSFOLDER); //browse objects folder
+	bd->resultMask = UA_BROWSERESULTMASK_ALL;	//return everything
 
 	UA_BrowseRequest breq;
 	UA_BrowseRequest_init(&breq);
 	breq.requestedMaxReferencesPerNode = 0;
-	breq.nodesToBrowse = &bd;
+	breq.nodesToBrowse = bd;
 	breq.nodesToBrowseSize = 1;
 
 	UA_BrowseResponse bresp = UA_Client_browse(client, &breq);
-	printf("result code: %d, results: %d, diagnostics: %d\n", bresp.responseHeader.serviceResult, bresp.resultsSize, bresp.diagnosticInfosSize);
-	puts("id, namespace, browse name, display name");
-	if (bresp.resultsSize > 0) for (int i = 0; i < bresp.resultsSize; ++i) {
-		if (bresp.results[i].referencesSize > 0) for (int j = 0; j < bresp.results[i].referencesSize; ++j) {
+	printf("%-9s %-16s %-16s %-16s\n", "NAMESPACE", "NODEID", "BROWSE NAME", "DISPLAY NAME");
+	for (int i = 0; i < bresp.resultsSize; ++i) {
+		for (int j = 0; j < bresp.results[i].referencesSize; ++j) {
 			UA_ReferenceDescription *ref = &(bresp.results[i].references[j]);
 			if(ref->nodeId.nodeId.identifierType == UA_NODEIDTYPE_NUMERIC){
-				printf("%d, %d, %.*s, %.*s\n", ref->nodeId.nodeId.identifier.numeric, ref->browseName.namespaceIndex, ref->browseName.name.length, ref->browseName.name.data, ref->displayName.text.length, ref->displayName.text.data);
+				printf("%-9d %-16d %-16.*s %-16.*s\n", ref->browseName.namespaceIndex, ref->nodeId.nodeId.identifier.numeric, ref->browseName.name.length, ref->browseName.name.data, ref->displayName.text.length, ref->displayName.text.data);
 			}else if(ref->nodeId.nodeId.identifierType == UA_NODEIDTYPE_STRING){
-				printf("%.*s, %d, %.*s, %.*s\n", ref->nodeId.nodeId.identifier.string.length, ref->nodeId.nodeId.identifier.string.data, ref->browseName.namespaceIndex, ref->browseName.name.length, ref->browseName.name.data, ref->displayName.text.length, ref->displayName.text.data);
-			}else{
-				printf("--, %d, %.*s, %.*s\n", ref->browseName.namespaceIndex, ref->browseName.name.length, ref->browseName.name.data, ref->displayName.text.length, ref->displayName.text.data);
+				printf("%-9d %-16.*s %-16.*s %-16.*s\n", ref->browseName.namespaceIndex, ref->nodeId.nodeId.identifier.string.length, ref->nodeId.nodeId.identifier.string.data, ref->browseName.name.length, ref->browseName.name.data, ref->displayName.text.length, ref->displayName.text.data);
 			}
+			//TODO: distinguish further types
 		}
 	}
+	UA_BrowseRequest_deleteMembers(&breq);
 	UA_BrowseResponse_deleteMembers(&bresp);
 
 	// Read a node
+	printf("\nReading the value of node (1, \"the.answer\"):\n");
 	UA_ReadRequest req;
 	UA_ReadRequest_init(&req);
 	req.nodesToRead = UA_ReadValueId_new();
@@ -61,7 +61,7 @@ int main(int argc, char *argv[]) {
 	   resp.resultsSize > 0 && resp.results[0].hasValue &&
 	   resp.results[0].value.data /* an empty array returns a null-ptr */ &&
 	   resp.results[0].value.type == &UA_TYPES[UA_TYPES_INT32])
-		printf("the answer is: %i\n", *(UA_Int32*)resp.results[0].value.data);
+		printf("the value is: %i\n", *(UA_Int32*)resp.results[0].value.data);
 
 	UA_ReadRequest_deleteMembers(&req);
 	UA_ReadResponse_deleteMembers(&resp);