Chilkat Online Tools

BatchDescribeMergeConflicts unicodeCpp Example

AWS CodeCommit

#include <CkRestW.h>
#include <CkAuthAwsW.h>
#include <CkJsonObjectW.h>
#include <CkStringBuilderW.h>

void ChilkatSample(void)
    {
    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkRestW rest;
    bool success;

    CkAuthAwsW authAws;
    authAws.put_AccessKey(L"AWS_ACCESS_KEY");
    authAws.put_SecretKey(L"AWS_SECRET_KEY");

    // Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
    authAws.put_Region(L"us-west-2");
    authAws.put_ServiceName(L"codecommit");
    // SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
    rest.SetAuthAws(authAws);

    // URL: https://codecommit.us-west-2.amazonaws.com/
    // Use the same region as specified above.
    success = rest.Connect(L"codecommit.us-west-2.amazonaws.com",443,true,true);
    if (success != true) {
        wprintf(L"ConnectFailReason: %d\n",rest.get_ConnectFailReason());
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    // The following code creates the JSON request body.
    // The JSON created by this code is shown below.

    // Use this online tool to generate code from sample JSON:
    // Generate Code to Create JSON

    CkJsonObjectW json;
    json.UpdateString(L"conflictDetailLevel",L"string");
    json.UpdateString(L"conflictResolutionStrategy",L"string");
    json.UpdateString(L"destinationCommitSpecifier",L"string");
    json.UpdateString(L"filePaths[0]",L"string");
    json.UpdateInt(L"maxConflictFiles",123);
    json.UpdateInt(L"maxMergeHunks",123);
    json.UpdateString(L"mergeOption",L"string");
    json.UpdateString(L"nextToken",L"string");
    json.UpdateString(L"repositoryName",L"string");
    json.UpdateString(L"sourceCommitSpecifier",L"string");

    // The JSON request body created by the above code:

    // {
    //   "conflictDetailLevel": "string",
    //   "conflictResolutionStrategy": "string",
    //   "destinationCommitSpecifier": "string",
    //   "filePaths": [
    //     "string"
    //   ],
    //   "maxConflictFiles": number,
    //   "maxMergeHunks": number,
    //   "mergeOption": "string",
    //   "nextToken": "string",
    //   "repositoryName": "string",
    //   "sourceCommitSpecifier": "string"
    // }

    rest.AddHeader(L"Content-Type",L"application/x-amz-json-1.1");
    rest.AddHeader(L"X-Amz-Target",L"CodeCommit_20150413.BatchDescribeMergeConflicts");

    CkStringBuilderW sbRequestBody;
    json.EmitSb(sbRequestBody);
    CkStringBuilderW sbResponseBody;
    success = rest.FullRequestSb(L"POST",L"/",sbRequestBody,sbResponseBody);
    if (success != true) {
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    int respStatusCode = rest.get_ResponseStatusCode();
    wprintf(L"response status code = %d\n",respStatusCode);
    if (respStatusCode != 200) {
        wprintf(L"Response Header:\n");
        wprintf(L"%s\n",rest.responseHeader());
        wprintf(L"Response Body:\n");
        wprintf(L"%s\n",sbResponseBody.getAsString());
        return;
    }

    CkJsonObjectW jResp;
    jResp.LoadSb(sbResponseBody);

    // The following code parses the JSON response.
    // A sample JSON response is shown below the sample code.

    // Use this online tool to generate parsing code from sample JSON:
    // Generate Parsing Code from JSON

    // Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
    // See this example explaining how this memory should be used: const char * functions.

    int ContentConflict;
    int FileModeConflict;
    const wchar_t *Base = 0;
    const wchar_t *Destination = 0;
    const wchar_t *Source = 0;
    const wchar_t *FilePath = 0;
    int FileSizesBase;
    int FileSizesDestination;
    int FileSizesSource;
    int IsBinaryFileBase;
    int IsBinaryFileDestination;
    int IsBinaryFileSource;
    const wchar_t *MergeOperationsDestination = 0;
    const wchar_t *MergeOperationsSource = 0;
    int NumberOfConflicts;
    int ObjectTypeConflict;
    const wchar_t *ObjectTypesBase = 0;
    const wchar_t *ObjectTypesDestination = 0;
    const wchar_t *ObjectTypesSource = 0;
    int j;
    int count_j;
    int EndLine;
    const wchar_t *HunkContent = 0;
    int StartLine;
    int destinationEndLine;
    const wchar_t *destinationHunkContent = 0;
    int destinationStartLine;
    int isConflict;
    int sourceEndLine;
    const wchar_t *sourceHunkContent = 0;
    int sourceStartLine;
    const wchar_t *exceptionName = 0;
    const wchar_t *filePath = 0;
    const wchar_t *message = 0;

    const wchar_t *baseCommitId = jResp.stringOf(L"baseCommitId");
    const wchar_t *destinationCommitId = jResp.stringOf(L"destinationCommitId");
    const wchar_t *nextToken = jResp.stringOf(L"nextToken");
    const wchar_t *sourceCommitId = jResp.stringOf(L"sourceCommitId");
    int i = 0;
    int count_i = jResp.SizeOfArray(L"conflicts");
    while (i < count_i) {
        jResp.put_I(i);
        ContentConflict = jResp.IntOf(L"conflicts[i].conflictMetadata.contentConflict");
        FileModeConflict = jResp.IntOf(L"conflicts[i].conflictMetadata.fileModeConflict");
        Base = jResp.stringOf(L"conflicts[i].conflictMetadata.fileModes.base");
        Destination = jResp.stringOf(L"conflicts[i].conflictMetadata.fileModes.destination");
        Source = jResp.stringOf(L"conflicts[i].conflictMetadata.fileModes.source");
        FilePath = jResp.stringOf(L"conflicts[i].conflictMetadata.filePath");
        FileSizesBase = jResp.IntOf(L"conflicts[i].conflictMetadata.fileSizes.base");
        FileSizesDestination = jResp.IntOf(L"conflicts[i].conflictMetadata.fileSizes.destination");
        FileSizesSource = jResp.IntOf(L"conflicts[i].conflictMetadata.fileSizes.source");
        IsBinaryFileBase = jResp.IntOf(L"conflicts[i].conflictMetadata.isBinaryFile.base");
        IsBinaryFileDestination = jResp.IntOf(L"conflicts[i].conflictMetadata.isBinaryFile.destination");
        IsBinaryFileSource = jResp.IntOf(L"conflicts[i].conflictMetadata.isBinaryFile.source");
        MergeOperationsDestination = jResp.stringOf(L"conflicts[i].conflictMetadata.mergeOperations.destination");
        MergeOperationsSource = jResp.stringOf(L"conflicts[i].conflictMetadata.mergeOperations.source");
        NumberOfConflicts = jResp.IntOf(L"conflicts[i].conflictMetadata.numberOfConflicts");
        ObjectTypeConflict = jResp.IntOf(L"conflicts[i].conflictMetadata.objectTypeConflict");
        ObjectTypesBase = jResp.stringOf(L"conflicts[i].conflictMetadata.objectTypes.base");
        ObjectTypesDestination = jResp.stringOf(L"conflicts[i].conflictMetadata.objectTypes.destination");
        ObjectTypesSource = jResp.stringOf(L"conflicts[i].conflictMetadata.objectTypes.source");
        j = 0;
        count_j = jResp.SizeOfArray(L"conflicts[i].mergeHunks");
        while (j < count_j) {
            jResp.put_J(j);
            EndLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].base.endLine");
            HunkContent = jResp.stringOf(L"conflicts[i].mergeHunks[j].base.hunkContent");
            StartLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].base.startLine");
            destinationEndLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].destination.endLine");
            destinationHunkContent = jResp.stringOf(L"conflicts[i].mergeHunks[j].destination.hunkContent");
            destinationStartLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].destination.startLine");
            isConflict = jResp.IntOf(L"conflicts[i].mergeHunks[j].isConflict");
            sourceEndLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].source.endLine");
            sourceHunkContent = jResp.stringOf(L"conflicts[i].mergeHunks[j].source.hunkContent");
            sourceStartLine = jResp.IntOf(L"conflicts[i].mergeHunks[j].source.startLine");
            j = j + 1;
        }

        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray(L"errors");
    while (i < count_i) {
        jResp.put_I(i);
        exceptionName = jResp.stringOf(L"errors[i].exceptionName");
        filePath = jResp.stringOf(L"errors[i].filePath");
        message = jResp.stringOf(L"errors[i].message");
        i = i + 1;
    }

    // A sample JSON response body parsed by the above code:

    // {
    //   "baseCommitId": "string",
    //   "conflicts": [
    //     {
    //       "conflictMetadata": {
    //         "contentConflict": boolean,
    //         "fileModeConflict": boolean,
    //         "fileModes": {
    //           "base": "string",
    //           "destination": "string",
    //           "source": "string"
    //         },
    //         "filePath": "string",
    //         "fileSizes": {
    //           "base": number,
    //           "destination": number,
    //           "source": number
    //         },
    //         "isBinaryFile": {
    //           "base": boolean,
    //           "destination": boolean,
    //           "source": boolean
    //         },
    //         "mergeOperations": {
    //           "destination": "string",
    //           "source": "string"
    //         },
    //         "numberOfConflicts": number,
    //         "objectTypeConflict": boolean,
    //         "objectTypes": {
    //           "base": "string",
    //           "destination": "string",
    //           "source": "string"
    //         }
    //       },
    //       "mergeHunks": [
    //         {
    //           "base": {
    //             "endLine": number,
    //             "hunkContent": "string",
    //             "startLine": number
    //           },
    //           "destination": {
    //             "endLine": number,
    //             "hunkContent": "string",
    //             "startLine": number
    //           },
    //           "isConflict": boolean,
    //           "source": {
    //             "endLine": number,
    //             "hunkContent": "string",
    //             "startLine": number
    //           }
    //         }
    //       ]
    //     }
    //   ],
    //   "destinationCommitId": "string",
    //   "errors": [
    //     {
    //       "exceptionName": "string",
    //       "filePath": "string",
    //       "message": "string"
    //     }
    //   ],
    //   "nextToken": "string",
    //   "sourceCommitId": "string"
    // }
    }