khronosfws/openmax_al/src/adptcommon/xaframeworkmgr.c
author hgs
Fri, 23 Jul 2010 17:29:03 -0500
changeset 36 73253677b50a
parent 25 6f7ceef7b1d1
child 38 9e9fc5ab059f
permissions -rw-r--r--
201029
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
19
hgs
parents:
diff changeset
     1
/*
25
hgs
parents: 21
diff changeset
     2
 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents: 21
diff changeset
     3
 * All rights reserved.
hgs
parents: 21
diff changeset
     4
 * This component and the accompanying materials are made available
hgs
parents: 21
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
hgs
parents: 21
diff changeset
     6
 * which accompanies this distribution, and is available
hgs
parents: 21
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents: 21
diff changeset
     8
 *
hgs
parents: 21
diff changeset
     9
 * Initial Contributors:
hgs
parents: 21
diff changeset
    10
 * Nokia Corporation - initial contribution.
hgs
parents: 21
diff changeset
    11
 *
hgs
parents: 21
diff changeset
    12
 * Contributors:
hgs
parents: 21
diff changeset
    13
 *
hgs
parents: 21
diff changeset
    14
 * Description: Framework Manager. Parses the CFG file
hgs
parents: 21
diff changeset
    15
 *
hgs
parents: 21
diff changeset
    16
 */
19
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include <stdio.h>
hgs
parents:
diff changeset
    19
#include <string.h>
25
hgs
parents: 21
diff changeset
    20
#include "xaframeworkmgr.h"
19
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
/* Default line width permitted in the cfg file + 2 to hold "\r\n"*/
hgs
parents:
diff changeset
    23
#define LINEWIDTH 82
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
typedef enum
25
hgs
parents: 21
diff changeset
    26
    {
19
hgs
parents:
diff changeset
    27
    FWMgrTagNone,
hgs
parents:
diff changeset
    28
    FWMgrTagURIScheme,
hgs
parents:
diff changeset
    29
    FWMgrTagFileExt
25
hgs
parents: 21
diff changeset
    30
    } FWMgrTagType;
19
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
/* Config file location */
21
hgs
parents: 20
diff changeset
    33
const char configFileLocationZ[] = "z:/openmaxal/openmaxal.cfg";
hgs
parents: 20
diff changeset
    34
const char configFileLocationC[] = "c:/openmaxal/openmaxal.cfg";
19
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/* Tags used for parsing */
hgs
parents:
diff changeset
    37
const char mediaPlayerBeginTag[] = "<mediaplayer>";
hgs
parents:
diff changeset
    38
const char mediaPlayerEndTag[] = "</mediaplayer>";
hgs
parents:
diff changeset
    39
const char mediaRecorderBeginTag[] = "<mediarecorder>";
hgs
parents:
diff changeset
    40
const char mediaRecorderEndTag[] = "</mediarecorder>";
hgs
parents:
diff changeset
    41
const char mediaFrameworkMmfBeginTag[] = "<mmf>";
hgs
parents:
diff changeset
    42
const char mediaFrameworkMmfEndTag[] = "</mmf>";
hgs
parents:
diff changeset
    43
const char mediaFrameworkGstBeginTag[] = "<gst>";
hgs
parents:
diff changeset
    44
const char uriSchemeBeginTag[] = "<urischeme>";
hgs
parents:
diff changeset
    45
const char uriSchemeEndTag[] = "</urischeme>";
hgs
parents:
diff changeset
    46
const char mediaFrameworkGstEndTag[] = "</gst>";
hgs
parents:
diff changeset
    47
const char fileExtBeginTag[] = "<fileext>";
hgs
parents:
diff changeset
    48
const char fileExtEndTag[] = "</fileext>";
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
/* Local function definitions */
hgs
parents:
diff changeset
    51
/* returns FWMgrTrue if processed successfully */
25
hgs
parents: 21
diff changeset
    52
static FWMgrBool processConfigEntry(const char* buffer,
hgs
parents: 21
diff changeset
    53
        FWMgrMOType *mediaType, FWMgrFwType *frameworkType,
hgs
parents: 21
diff changeset
    54
        FWMgrTagType *tagType, FWMgrBool *newNode, FrameworkMap **node);
hgs
parents: 21
diff changeset
    55
hgs
parents: 21
diff changeset
    56
/* returns FWMgrTrue if processed successfully */
hgs
parents: 21
diff changeset
    57
static FWMgrBool processTagType(const char* buffer,
hgs
parents: 21
diff changeset
    58
        FWMgrFwType *frameworkType, FWMgrTagType *tagType,
19
hgs
parents:
diff changeset
    59
        FrameworkMap **node);
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
/* returns FWMgrTrue if processed successfully */
25
hgs
parents: 21
diff changeset
    62
static FWMgrBool tokenizeTag(FWMgrTagType tagType, const char* buffer,
19
hgs
parents:
diff changeset
    63
        FrameworkMap **node);
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
/* Crates a default rules config file */
hgs
parents:
diff changeset
    66
static int createDefaultRules(const char * filename);
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
/* Global functions from header file */
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
/* FrameworkMap* XAFrameworkMgr_CreateFrameworkMap
hgs
parents:
diff changeset
    71
 * Description: Creates a list of framework and use-case map.
hgs
parents:
diff changeset
    72
 */
hgs
parents:
diff changeset
    73
FrameworkMap* XAFrameworkMgr_CreateFrameworkMap()
25
hgs
parents: 21
diff changeset
    74
    {
19
hgs
parents:
diff changeset
    75
    char buffer[LINEWIDTH];
hgs
parents:
diff changeset
    76
    int readSize;
hgs
parents:
diff changeset
    77
    int lineNumber = 0;
hgs
parents:
diff changeset
    78
    FWMgrBool processedEntry = FWMgrTrue;
hgs
parents:
diff changeset
    79
    FWMgrMOType currentMediaType = FWMgrMOUnknown;
hgs
parents:
diff changeset
    80
    FWMgrFwType currentFrameworkType = FWMgrFWUknown;
hgs
parents:
diff changeset
    81
    FWMgrTagType currentTagType = FWMgrTagNone;
hgs
parents:
diff changeset
    82
    FrameworkMap *curNode = NULL;
hgs
parents:
diff changeset
    83
    FWMgrBool newNode;
hgs
parents:
diff changeset
    84
    FrameworkMap *frameworkMap = NULL;
25
hgs
parents: 21
diff changeset
    85
36
hgs
parents: 25
diff changeset
    86
    FILE* fp = fopen(configFileLocationC, "r");
19
hgs
parents:
diff changeset
    87
    if (fp == NULL)
hgs
parents:
diff changeset
    88
        {
36
hgs
parents: 25
diff changeset
    89
        fp = fopen(configFileLocationZ, "r");
19
hgs
parents:
diff changeset
    90
        }
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
    if (fp != NULL)
hgs
parents:
diff changeset
    93
        {
25
hgs
parents: 21
diff changeset
    94
        while ((fgets(buffer, LINEWIDTH, fp) != NULL) && processedEntry)
hgs
parents: 21
diff changeset
    95
            {
19
hgs
parents:
diff changeset
    96
            /* keep looping until NULL pointer OR error... */
hgs
parents:
diff changeset
    97
            lineNumber++;
hgs
parents:
diff changeset
    98
            readSize = strlen(buffer);
hgs
parents:
diff changeset
    99
            /* Ignore comments line */
hgs
parents:
diff changeset
   100
            if (buffer[0] == '#')
hgs
parents:
diff changeset
   101
                continue;
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
            /* Ignore replace "\r\n" with '\0' */
25
hgs
parents: 21
diff changeset
   104
            if ((readSize >= 2) && (buffer[readSize - 2] == '\r')
hgs
parents: 21
diff changeset
   105
                    && (buffer[readSize - 1] == '\n'))
hgs
parents: 21
diff changeset
   106
                buffer[readSize - 2] = '\0';
19
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
            /* Ignore new line... */
hgs
parents:
diff changeset
   109
            if (readSize == 2)
hgs
parents:
diff changeset
   110
                continue;
hgs
parents:
diff changeset
   111
25
hgs
parents: 21
diff changeset
   112
            processedEntry = processConfigEntry(buffer, &currentMediaType,
hgs
parents: 21
diff changeset
   113
                    &currentFrameworkType, &currentTagType, &newNode,
hgs
parents: 21
diff changeset
   114
                    &curNode);
19
hgs
parents:
diff changeset
   115
            if (newNode)
25
hgs
parents: 21
diff changeset
   116
                {
19
hgs
parents:
diff changeset
   117
                /*Just link to the last element in the chain*/
hgs
parents:
diff changeset
   118
                if (!frameworkMap)
25
hgs
parents: 21
diff changeset
   119
                    {
19
hgs
parents:
diff changeset
   120
                    frameworkMap = curNode;
25
hgs
parents: 21
diff changeset
   121
                    }
19
hgs
parents:
diff changeset
   122
                else
25
hgs
parents: 21
diff changeset
   123
                    {
19
hgs
parents:
diff changeset
   124
                    FrameworkMap *lastNode = frameworkMap;
hgs
parents:
diff changeset
   125
                    while (lastNode->next)
25
hgs
parents: 21
diff changeset
   126
                        {
19
hgs
parents:
diff changeset
   127
                        lastNode = lastNode->next;
25
hgs
parents: 21
diff changeset
   128
                        }
hgs
parents: 21
diff changeset
   129
                    lastNode->next = curNode;
19
hgs
parents:
diff changeset
   130
                    }
hgs
parents:
diff changeset
   131
                }
hgs
parents:
diff changeset
   132
            }
25
hgs
parents: 21
diff changeset
   133
        fclose(fp);
19
hgs
parents:
diff changeset
   134
        }
hgs
parents:
diff changeset
   135
    else
25
hgs
parents: 21
diff changeset
   136
        {
19
hgs
parents:
diff changeset
   137
        printf("unable to open config file!\n");
25
hgs
parents: 21
diff changeset
   138
        }
hgs
parents: 21
diff changeset
   139
    return frameworkMap;
19
hgs
parents:
diff changeset
   140
    }
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
#ifdef _DEBUG
hgs
parents:
diff changeset
   143
/* void XAFrameworkMgr_DumpFrameworkMap
hgs
parents:
diff changeset
   144
 * Description: Prints map to std console.
hgs
parents:
diff changeset
   145
 */
hgs
parents:
diff changeset
   146
void XAFrameworkMgr_DumpFrameworkMap(FrameworkMap *map)
25
hgs
parents: 21
diff changeset
   147
    {
19
hgs
parents:
diff changeset
   148
    FrameworkMap *node = map;
hgs
parents:
diff changeset
   149
    int i;
hgs
parents:
diff changeset
   150
    int loopIndex = 0;
hgs
parents:
diff changeset
   151
    while (node)
25
hgs
parents: 21
diff changeset
   152
        {
19
hgs
parents:
diff changeset
   153
        loopIndex++;
hgs
parents:
diff changeset
   154
        printf("%d>", loopIndex);
hgs
parents:
diff changeset
   155
        if (node->moType == FWMgrMOPlayer)
hgs
parents:
diff changeset
   156
            printf("MediaPlayer-");
hgs
parents:
diff changeset
   157
        else if (node->moType == FWMgrMORecorder)
hgs
parents:
diff changeset
   158
            printf("MediaRecrdr-");
hgs
parents:
diff changeset
   159
        else
hgs
parents:
diff changeset
   160
            printf("UKNOWN-");
hgs
parents:
diff changeset
   161
        if (node->fwType == FWMgrFWMMF)
hgs
parents:
diff changeset
   162
            printf("MMF-");
hgs
parents:
diff changeset
   163
        else if (node->fwType == FWMgrFWGST)
hgs
parents:
diff changeset
   164
            printf("GST-");
hgs
parents:
diff changeset
   165
        else
hgs
parents:
diff changeset
   166
            printf("UKNOWN-");
hgs
parents:
diff changeset
   167
        printf("Scheme[");
25
hgs
parents: 21
diff changeset
   168
        for (i = 0; i < node->uriSchemeCount; i++)
19
hgs
parents:
diff changeset
   169
            printf(" %s", node->uriSchemes[i]);
hgs
parents:
diff changeset
   170
        printf("]FileExt[");
25
hgs
parents: 21
diff changeset
   171
        for (i = 0; i < node->fileExtCount; i++)
19
hgs
parents:
diff changeset
   172
            printf(" %s", node->fileExts[i]);
hgs
parents:
diff changeset
   173
        printf("]\n");
hgs
parents:
diff changeset
   174
        node = node->next;
25
hgs
parents: 21
diff changeset
   175
        }
19
hgs
parents:
diff changeset
   176
    }
hgs
parents:
diff changeset
   177
#endif
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
/* void XAFrameworkMgr_DeleteFrameworkMap
hgs
parents:
diff changeset
   180
 * Description: Deletes the list of framework and use-case map.
hgs
parents:
diff changeset
   181
 */
hgs
parents:
diff changeset
   182
void XAFrameworkMgr_DeleteFrameworkMap(FrameworkMap **map)
25
hgs
parents: 21
diff changeset
   183
    {
19
hgs
parents:
diff changeset
   184
    FrameworkMap *node = *map;
hgs
parents:
diff changeset
   185
    FrameworkMap *nextNode = NULL;
hgs
parents:
diff changeset
   186
    int i;
hgs
parents:
diff changeset
   187
    while (node)
25
hgs
parents: 21
diff changeset
   188
        {
hgs
parents: 21
diff changeset
   189
        for (i = 0; i < node->uriSchemeCount; i++)
hgs
parents: 21
diff changeset
   190
            free(node->uriSchemes[i]);
hgs
parents: 21
diff changeset
   191
        free(node->uriSchemes);
19
hgs
parents:
diff changeset
   192
25
hgs
parents: 21
diff changeset
   193
        for (i = 0; i < node->fileExtCount; i++)
hgs
parents: 21
diff changeset
   194
            free(node->fileExts[i]);
hgs
parents: 21
diff changeset
   195
        free(node->fileExts);
19
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
        nextNode = node->next;
25
hgs
parents: 21
diff changeset
   198
        free(node);
19
hgs
parents:
diff changeset
   199
        node = nextNode;
25
hgs
parents: 21
diff changeset
   200
        }
hgs
parents: 21
diff changeset
   201
    *map = NULL;
19
hgs
parents:
diff changeset
   202
    }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
/* FWMgrFwType XAFrameworkMgr_GetFramework
hgs
parents:
diff changeset
   205
 * Description: Returns the framework enum that handles uri.
hgs
parents:
diff changeset
   206
 */
25
hgs
parents: 21
diff changeset
   207
FWMgrFwType XAFrameworkMgr_GetFramework(FrameworkMap *map, const char *uri,
hgs
parents: 21
diff changeset
   208
        FWMgrMOType mediaObject)
hgs
parents: 21
diff changeset
   209
    {
19
hgs
parents:
diff changeset
   210
    FWMgrFwType retVal = FWMgrFWUknown;
hgs
parents:
diff changeset
   211
    char fileScheme[] = "file";
hgs
parents:
diff changeset
   212
    char *uriScheme = NULL;
hgs
parents:
diff changeset
   213
    char *fileExt = NULL;
hgs
parents:
diff changeset
   214
    FrameworkMap *node = map;
hgs
parents:
diff changeset
   215
    FWMgrBool uriMatchFound = FWMgrFalse;
hgs
parents:
diff changeset
   216
    FWMgrBool fileExtMatchFound = FWMgrFalse;
hgs
parents:
diff changeset
   217
    int i = 0;
hgs
parents:
diff changeset
   218
    int copyLen = 0;
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
    if (!map || !uri)
25
hgs
parents: 21
diff changeset
   221
        {
19
hgs
parents:
diff changeset
   222
        /* TODO Log invalid uri */
hgs
parents:
diff changeset
   223
        return retVal;
25
hgs
parents: 21
diff changeset
   224
        }
19
hgs
parents:
diff changeset
   225
hgs
parents:
diff changeset
   226
    /* Get uri scheme */
hgs
parents:
diff changeset
   227
    uriScheme = strchr(uri, ':');
25
hgs
parents: 21
diff changeset
   228
    if (uriScheme == NULL)
hgs
parents: 21
diff changeset
   229
        {
19
hgs
parents:
diff changeset
   230
        /* TODO Log invalid uri */
hgs
parents:
diff changeset
   231
        return retVal;
25
hgs
parents: 21
diff changeset
   232
        }
19
hgs
parents:
diff changeset
   233
hgs
parents:
diff changeset
   234
    copyLen = (uriScheme - uri);
25
hgs
parents: 21
diff changeset
   235
    uriScheme = (char*) calloc(copyLen + 1, sizeof(char));
19
hgs
parents:
diff changeset
   236
    strncpy(uriScheme, uri, copyLen);
hgs
parents:
diff changeset
   237
    uriScheme[copyLen] = '\0'; /*Null terminate it*/
hgs
parents:
diff changeset
   238
hgs
parents:
diff changeset
   239
    if (strcasecmp(uriScheme, fileScheme) == 0)
25
hgs
parents: 21
diff changeset
   240
        {
19
hgs
parents:
diff changeset
   241
        /* Get uri extension */
hgs
parents:
diff changeset
   242
        char* dotLoc = strrchr(uri, '.');
25
hgs
parents: 21
diff changeset
   243
        if (dotLoc == NULL)
hgs
parents: 21
diff changeset
   244
            {
19
hgs
parents:
diff changeset
   245
            /* TODO Log invalid uri */
hgs
parents:
diff changeset
   246
            free(uriScheme);
hgs
parents:
diff changeset
   247
            return retVal;
25
hgs
parents: 21
diff changeset
   248
            }
19
hgs
parents:
diff changeset
   249
        /* We need to add 1 to exclude '.'*/
hgs
parents:
diff changeset
   250
        copyLen = strlen(uri) - (dotLoc + 1 - uri);
25
hgs
parents: 21
diff changeset
   251
        fileExt = (char*) calloc(copyLen + 1, sizeof(char));
19
hgs
parents:
diff changeset
   252
        strncpy(fileExt, dotLoc + 1, copyLen);
hgs
parents:
diff changeset
   253
        fileExt[copyLen] = '\0'; /*Null terminate it*/
25
hgs
parents: 21
diff changeset
   254
        }
19
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
    while (node)
25
hgs
parents: 21
diff changeset
   257
        {
19
hgs
parents:
diff changeset
   258
        if (mediaObject == node->moType)
hgs
parents:
diff changeset
   259
            {
hgs
parents:
diff changeset
   260
            uriMatchFound = FWMgrFalse;
hgs
parents:
diff changeset
   261
            fileExtMatchFound = FWMgrFalse;
hgs
parents:
diff changeset
   262
            /* Match for uri*/
25
hgs
parents: 21
diff changeset
   263
            for (i = 0; i < node->uriSchemeCount; i++)
hgs
parents: 21
diff changeset
   264
                {
19
hgs
parents:
diff changeset
   265
                if (strcasecmp(uriScheme, node->uriSchemes[i]) == 0)
hgs
parents:
diff changeset
   266
                    {
25
hgs
parents: 21
diff changeset
   267
                    uriMatchFound = FWMgrTrue;
hgs
parents: 21
diff changeset
   268
                    break;
19
hgs
parents:
diff changeset
   269
                    }
25
hgs
parents: 21
diff changeset
   270
                }
19
hgs
parents:
diff changeset
   271
            /* if uri scheme is not file, we only need to check for uri */
hgs
parents:
diff changeset
   272
            if (!fileExt)
25
hgs
parents: 21
diff changeset
   273
                {
19
hgs
parents:
diff changeset
   274
                fileExtMatchFound = FWMgrTrue;
25
hgs
parents: 21
diff changeset
   275
                }
19
hgs
parents:
diff changeset
   276
            else
hgs
parents:
diff changeset
   277
                {
25
hgs
parents: 21
diff changeset
   278
                for (i = 0; i < node->fileExtCount; i++)
hgs
parents: 21
diff changeset
   279
                    {
19
hgs
parents:
diff changeset
   280
                    if (strcasecmp(fileExt, node->fileExts[i]) == 0)
25
hgs
parents: 21
diff changeset
   281
                        {
19
hgs
parents:
diff changeset
   282
                        fileExtMatchFound = FWMgrTrue;
hgs
parents:
diff changeset
   283
                        break;
25
hgs
parents: 21
diff changeset
   284
                        }
19
hgs
parents:
diff changeset
   285
                    }
hgs
parents:
diff changeset
   286
                }
hgs
parents:
diff changeset
   287
25
hgs
parents: 21
diff changeset
   288
            if ((uriMatchFound == FWMgrTrue) && (fileExtMatchFound
hgs
parents: 21
diff changeset
   289
                    == FWMgrTrue))
19
hgs
parents:
diff changeset
   290
                {
25
hgs
parents: 21
diff changeset
   291
                retVal = node->fwType;
hgs
parents: 21
diff changeset
   292
                break;
19
hgs
parents:
diff changeset
   293
                }
hgs
parents:
diff changeset
   294
            }
hgs
parents:
diff changeset
   295
        node = node->next;
25
hgs
parents: 21
diff changeset
   296
        }
19
hgs
parents:
diff changeset
   297
    free(uriScheme);
hgs
parents:
diff changeset
   298
    free(fileExt);
hgs
parents:
diff changeset
   299
    return retVal;
25
hgs
parents: 21
diff changeset
   300
    }
19
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
/* Local functions */
hgs
parents:
diff changeset
   303
hgs
parents:
diff changeset
   304
/* FWMgrBool processConfigEntry
hgs
parents:
diff changeset
   305
 * Description: Processes a single line entry from the config file.
hgs
parents:
diff changeset
   306
 */
25
hgs
parents: 21
diff changeset
   307
FWMgrBool processConfigEntry(const char* buffer, FWMgrMOType *mediaType,
hgs
parents: 21
diff changeset
   308
        FWMgrFwType *frameworkType, FWMgrTagType *tagType,
hgs
parents: 21
diff changeset
   309
        FWMgrBool *newNode, FrameworkMap **node)
hgs
parents: 21
diff changeset
   310
    {
19
hgs
parents:
diff changeset
   311
    FWMgrBool processedSuccessfully = FWMgrTrue;
25
hgs
parents: 21
diff changeset
   312
hgs
parents: 21
diff changeset
   313
    if (!buffer || !mediaType || !frameworkType || !tagType || !newNode)
hgs
parents: 21
diff changeset
   314
        {
hgs
parents: 21
diff changeset
   315
        processedSuccessfully = FWMgrFalse;
hgs
parents: 21
diff changeset
   316
        return processedSuccessfully;
hgs
parents: 21
diff changeset
   317
        }
hgs
parents: 21
diff changeset
   318
hgs
parents: 21
diff changeset
   319
	*newNode = FWMgrFalse;
19
hgs
parents:
diff changeset
   320
    switch (*mediaType)
25
hgs
parents: 21
diff changeset
   321
        {
19
hgs
parents:
diff changeset
   322
        case FWMgrMOUnknown:
25
hgs
parents: 21
diff changeset
   323
            {
19
hgs
parents:
diff changeset
   324
            if (strcmp(buffer, mediaPlayerBeginTag) == 0)
25
hgs
parents: 21
diff changeset
   325
                {
19
hgs
parents:
diff changeset
   326
                *mediaType = FWMgrMOPlayer;
hgs
parents:
diff changeset
   327
                *frameworkType = FWMgrFWUknown;
hgs
parents:
diff changeset
   328
                *tagType = FWMgrTagNone;
hgs
parents:
diff changeset
   329
                *node = NULL;
25
hgs
parents: 21
diff changeset
   330
                }
19
hgs
parents:
diff changeset
   331
            else if (strcmp(buffer, mediaRecorderBeginTag) == 0)
25
hgs
parents: 21
diff changeset
   332
                {
19
hgs
parents:
diff changeset
   333
                *mediaType = FWMgrMORecorder;
hgs
parents:
diff changeset
   334
                *frameworkType = FWMgrFWUknown;
hgs
parents:
diff changeset
   335
                *tagType = FWMgrTagNone;
hgs
parents:
diff changeset
   336
                *node = NULL;
25
hgs
parents: 21
diff changeset
   337
                }
19
hgs
parents:
diff changeset
   338
            }
hgs
parents:
diff changeset
   339
            break;
hgs
parents:
diff changeset
   340
        case FWMgrMOPlayer:
hgs
parents:
diff changeset
   341
        case FWMgrMORecorder:
25
hgs
parents: 21
diff changeset
   342
            {
19
hgs
parents:
diff changeset
   343
            switch (*frameworkType)
hgs
parents:
diff changeset
   344
                {
25
hgs
parents: 21
diff changeset
   345
                case FWMgrFWUknown:
hgs
parents: 21
diff changeset
   346
                    {
hgs
parents: 21
diff changeset
   347
                    if ((*mediaType == FWMgrMOPlayer) && (strcmp(buffer,
hgs
parents: 21
diff changeset
   348
                            mediaPlayerEndTag) == 0))
19
hgs
parents:
diff changeset
   349
                        *mediaType = FWMgrMOUnknown;
25
hgs
parents: 21
diff changeset
   350
                    else if ((*mediaType == FWMgrMORecorder) && (strcmp(
hgs
parents: 21
diff changeset
   351
                            buffer, mediaRecorderEndTag) == 0))
hgs
parents: 21
diff changeset
   352
                        *mediaType = FWMgrMOUnknown;
hgs
parents: 21
diff changeset
   353
                    else if ((strcmp(buffer, mediaFrameworkMmfBeginTag) == 0)
hgs
parents: 21
diff changeset
   354
                            || (strcmp(buffer, mediaFrameworkGstBeginTag)
hgs
parents: 21
diff changeset
   355
                                    == 0))
hgs
parents: 21
diff changeset
   356
                        {
hgs
parents: 21
diff changeset
   357
19
hgs
parents:
diff changeset
   358
                        *frameworkType = FWMgrFWMMF;
hgs
parents:
diff changeset
   359
                        if (strcmp(buffer, mediaFrameworkGstBeginTag) == 0)
hgs
parents:
diff changeset
   360
                            *frameworkType = FWMgrFWGST;
hgs
parents:
diff changeset
   361
                        if (*node)
25
hgs
parents: 21
diff changeset
   362
                            {
hgs
parents: 21
diff changeset
   363
                            printf(
hgs
parents: 21
diff changeset
   364
                                    "Fatal error error. Entry already exists and creating another one!!!");
hgs
parents: 21
diff changeset
   365
                            processedSuccessfully = FWMgrFalse;
hgs
parents: 21
diff changeset
   366
                            }
hgs
parents: 21
diff changeset
   367
                        else
hgs
parents: 21
diff changeset
   368
                            {
hgs
parents: 21
diff changeset
   369
                            *node = (FrameworkMap*) calloc(1,
hgs
parents: 21
diff changeset
   370
                                    sizeof(FrameworkMap));
hgs
parents: 21
diff changeset
   371
                            if (!(*node))
hgs
parents: 21
diff changeset
   372
                                {
hgs
parents: 21
diff changeset
   373
                                printf(
hgs
parents: 21
diff changeset
   374
                                        "Fatal error. No memory to create an Entry!!!");
hgs
parents: 21
diff changeset
   375
                                processedSuccessfully = FWMgrFalse;
hgs
parents: 21
diff changeset
   376
                                }
hgs
parents: 21
diff changeset
   377
                            else
hgs
parents: 21
diff changeset
   378
                                {
hgs
parents: 21
diff changeset
   379
                                *newNode = FWMgrTrue;
hgs
parents: 21
diff changeset
   380
                                (*node)->moType = *mediaType;
hgs
parents: 21
diff changeset
   381
                                (*node)->fwType = *frameworkType;
hgs
parents: 21
diff changeset
   382
                                }
hgs
parents: 21
diff changeset
   383
                            }
19
hgs
parents:
diff changeset
   384
                        }
hgs
parents:
diff changeset
   385
                    }
hgs
parents:
diff changeset
   386
                    break;
hgs
parents:
diff changeset
   387
                case FWMgrFWMMF:
25
hgs
parents: 21
diff changeset
   388
                    {
hgs
parents: 21
diff changeset
   389
                    processedSuccessfully = processTagType(buffer,
hgs
parents: 21
diff changeset
   390
                            frameworkType, tagType, node);
hgs
parents: 21
diff changeset
   391
                    }
19
hgs
parents:
diff changeset
   392
                    break;
hgs
parents:
diff changeset
   393
                case FWMgrFWGST:
25
hgs
parents: 21
diff changeset
   394
                    {
hgs
parents: 21
diff changeset
   395
                    processedSuccessfully = processTagType(buffer,
hgs
parents: 21
diff changeset
   396
                            frameworkType, tagType, node);
hgs
parents: 21
diff changeset
   397
                    }
19
hgs
parents:
diff changeset
   398
                    break;
hgs
parents:
diff changeset
   399
                default:
hgs
parents:
diff changeset
   400
                    processedSuccessfully = FWMgrFalse;
hgs
parents:
diff changeset
   401
                    break;
25
hgs
parents: 21
diff changeset
   402
                };
hgs
parents: 21
diff changeset
   403
            }
19
hgs
parents:
diff changeset
   404
            break;
hgs
parents:
diff changeset
   405
        default:
hgs
parents:
diff changeset
   406
            processedSuccessfully = FWMgrFalse;
hgs
parents:
diff changeset
   407
            break;
25
hgs
parents: 21
diff changeset
   408
        };
19
hgs
parents:
diff changeset
   409
    return processedSuccessfully;
25
hgs
parents: 21
diff changeset
   410
    }
19
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
/* FWMgrBool processTagType
25
hgs
parents: 21
diff changeset
   413
 * Description: Processes a framework type, uri, file tags entry from 
hgs
parents: 21
diff changeset
   414
 * the config file.
19
hgs
parents:
diff changeset
   415
 */
25
hgs
parents: 21
diff changeset
   416
FWMgrBool processTagType(const char* buffer, FWMgrFwType *frameworkType,
hgs
parents: 21
diff changeset
   417
        FWMgrTagType *tagType, FrameworkMap **node)
hgs
parents: 21
diff changeset
   418
    {
19
hgs
parents:
diff changeset
   419
    FWMgrBool processedSuccessfully = FWMgrTrue;
25
hgs
parents: 21
diff changeset
   420
hgs
parents: 21
diff changeset
   421
    if (!buffer || !frameworkType || !tagType || (*node == NULL))
19
hgs
parents:
diff changeset
   422
        {
25
hgs
parents: 21
diff changeset
   423
        processedSuccessfully = FWMgrFalse;
hgs
parents: 21
diff changeset
   424
        return processedSuccessfully;
hgs
parents: 21
diff changeset
   425
        }
hgs
parents: 21
diff changeset
   426
hgs
parents: 21
diff changeset
   427
    switch (*tagType)
hgs
parents: 21
diff changeset
   428
        {
hgs
parents: 21
diff changeset
   429
        case FWMgrTagNone:
19
hgs
parents:
diff changeset
   430
            {
25
hgs
parents: 21
diff changeset
   431
            if (((*frameworkType == FWMgrFWMMF) && (strcmp(buffer,
hgs
parents: 21
diff changeset
   432
                    mediaFrameworkMmfEndTag) == 0)) || ((*frameworkType
hgs
parents: 21
diff changeset
   433
                    == FWMgrFWGST)
hgs
parents: 21
diff changeset
   434
                    && (strcmp(buffer, mediaFrameworkGstEndTag) == 0)))
hgs
parents: 21
diff changeset
   435
                {
19
hgs
parents:
diff changeset
   436
                *node = NULL;
hgs
parents:
diff changeset
   437
                *frameworkType = FWMgrFWUknown;
25
hgs
parents: 21
diff changeset
   438
                }
19
hgs
parents:
diff changeset
   439
            else if (strcmp(buffer, uriSchemeBeginTag) == 0)
hgs
parents:
diff changeset
   440
                *tagType = FWMgrTagURIScheme;
hgs
parents:
diff changeset
   441
            else if (strcmp(buffer, fileExtBeginTag) == 0)
hgs
parents:
diff changeset
   442
                *tagType = FWMgrTagFileExt;
25
hgs
parents: 21
diff changeset
   443
            }
19
hgs
parents:
diff changeset
   444
            break;
hgs
parents:
diff changeset
   445
        case FWMgrTagURIScheme:
25
hgs
parents: 21
diff changeset
   446
            {
19
hgs
parents:
diff changeset
   447
            if (strcmp(buffer, uriSchemeEndTag) == 0)
hgs
parents:
diff changeset
   448
                *tagType = FWMgrTagNone;
hgs
parents:
diff changeset
   449
            else
25
hgs
parents: 21
diff changeset
   450
                {
19
hgs
parents:
diff changeset
   451
                processedSuccessfully = FWMgrFalse;
hgs
parents:
diff changeset
   452
                if (*node)
25
hgs
parents: 21
diff changeset
   453
                    processedSuccessfully = tokenizeTag(FWMgrTagURIScheme,
hgs
parents: 21
diff changeset
   454
                            buffer, node);
hgs
parents: 21
diff changeset
   455
                }
19
hgs
parents:
diff changeset
   456
            }
hgs
parents:
diff changeset
   457
            break;
hgs
parents:
diff changeset
   458
        case FWMgrTagFileExt:
25
hgs
parents: 21
diff changeset
   459
            {
19
hgs
parents:
diff changeset
   460
            if (strcmp(buffer, fileExtEndTag) == 0)
hgs
parents:
diff changeset
   461
                *tagType = FWMgrTagNone;
hgs
parents:
diff changeset
   462
            else
25
hgs
parents: 21
diff changeset
   463
                {
19
hgs
parents:
diff changeset
   464
                processedSuccessfully = FWMgrFalse;
hgs
parents:
diff changeset
   465
                if (*node)
25
hgs
parents: 21
diff changeset
   466
                    processedSuccessfully = tokenizeTag(FWMgrTagFileExt,
hgs
parents: 21
diff changeset
   467
                            buffer, node);
hgs
parents: 21
diff changeset
   468
                }
19
hgs
parents:
diff changeset
   469
            }
hgs
parents:
diff changeset
   470
            break;
hgs
parents:
diff changeset
   471
        default:
25
hgs
parents: 21
diff changeset
   472
            processedSuccessfully = FWMgrFalse;
19
hgs
parents:
diff changeset
   473
            break;
25
hgs
parents: 21
diff changeset
   474
        };
19
hgs
parents:
diff changeset
   475
    return processedSuccessfully;
25
hgs
parents: 21
diff changeset
   476
    }
19
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
/* FWMgrBool processTagType
25
hgs
parents: 21
diff changeset
   479
 * Description: Processes a framework type, uri, file tags entry from 
hgs
parents: 21
diff changeset
   480
 * the config file.
19
hgs
parents:
diff changeset
   481
 */
25
hgs
parents: 21
diff changeset
   482
FWMgrBool tokenizeTag(FWMgrTagType tagType, const char* buffer,
hgs
parents: 21
diff changeset
   483
        FrameworkMap **node)
hgs
parents: 21
diff changeset
   484
    {
hgs
parents: 21
diff changeset
   485
    char* tempStartPtr;
hgs
parents: 21
diff changeset
   486
    char* tempEndPtr;
19
hgs
parents:
diff changeset
   487
    int index = 0;
hgs
parents:
diff changeset
   488
    int strLen = 0;
hgs
parents:
diff changeset
   489
25
hgs
parents: 21
diff changeset
   490
    if (!buffer || (*node == NULL))
hgs
parents: 21
diff changeset
   491
        {
hgs
parents: 21
diff changeset
   492
        return FWMgrFalse;
hgs
parents: 21
diff changeset
   493
        }
hgs
parents: 21
diff changeset
   494
hgs
parents: 21
diff changeset
   495
    tempStartPtr = /*const_cast<char*>*/(char*) (buffer);
hgs
parents: 21
diff changeset
   496
    tempEndPtr = /*const_cast<char*>*/(char*) (buffer);
hgs
parents: 21
diff changeset
   497
19
hgs
parents:
diff changeset
   498
    if (tagType == FWMgrTagURIScheme)
25
hgs
parents: 21
diff changeset
   499
        {
19
hgs
parents:
diff changeset
   500
        (*node)->uriSchemeCount = atoi(buffer);
25
hgs
parents: 21
diff changeset
   501
        (*node)->uriSchemes = (char**) calloc((*node)->uriSchemeCount,
hgs
parents: 21
diff changeset
   502
                sizeof(*((*node)->uriSchemes)));
19
hgs
parents:
diff changeset
   503
        if (!(*node)->uriSchemes)
25
hgs
parents: 21
diff changeset
   504
            {
19
hgs
parents:
diff changeset
   505
            printf("Fatal error. No memory to create an Entry!!!");
hgs
parents:
diff changeset
   506
            return FWMgrFalse;
25
hgs
parents: 21
diff changeset
   507
            }
19
hgs
parents:
diff changeset
   508
        }
hgs
parents:
diff changeset
   509
    else if (tagType == FWMgrTagFileExt)
25
hgs
parents: 21
diff changeset
   510
        {
19
hgs
parents:
diff changeset
   511
        (*node)->fileExtCount = atoi(buffer);
25
hgs
parents: 21
diff changeset
   512
        (*node)->fileExts = (char**) calloc((*node)->fileExtCount,
hgs
parents: 21
diff changeset
   513
                sizeof(*((*node)->fileExts)));
19
hgs
parents:
diff changeset
   514
        if (!(*node)->fileExts)
25
hgs
parents: 21
diff changeset
   515
            {
19
hgs
parents:
diff changeset
   516
            printf("Fatal error. No memory to create an Entry!!!");
hgs
parents:
diff changeset
   517
            return FWMgrFalse;
25
hgs
parents: 21
diff changeset
   518
            }
19
hgs
parents:
diff changeset
   519
        }
hgs
parents:
diff changeset
   520
    else
hgs
parents:
diff changeset
   521
        return FWMgrFalse;
hgs
parents:
diff changeset
   522
hgs
parents:
diff changeset
   523
    /*Find the index of :*/
hgs
parents:
diff changeset
   524
    tempStartPtr = strchr(tempStartPtr, ',');
hgs
parents:
diff changeset
   525
    index = 0;
hgs
parents:
diff changeset
   526
    while (tempStartPtr && (strlen(tempStartPtr) > 1))
25
hgs
parents: 21
diff changeset
   527
        {
19
hgs
parents:
diff changeset
   528
        tempStartPtr++; /* Ignore separator ','*/
hgs
parents:
diff changeset
   529
        tempEndPtr = strchr(tempStartPtr, ',');
hgs
parents:
diff changeset
   530
        strLen = (tempEndPtr - tempStartPtr) + 1; /* To hold null terminator */
hgs
parents:
diff changeset
   531
        if (strLen > 0)
25
hgs
parents: 21
diff changeset
   532
            {
19
hgs
parents:
diff changeset
   533
            if (tagType == FWMgrTagURIScheme)
25
hgs
parents: 21
diff changeset
   534
                {
hgs
parents: 21
diff changeset
   535
                (*node)->uriSchemes[index] = (char*) calloc(strLen,
hgs
parents: 21
diff changeset
   536
                        sizeof(char));
19
hgs
parents:
diff changeset
   537
                strncpy((*node)->uriSchemes[index], tempStartPtr, strLen);
25
hgs
parents: 21
diff changeset
   538
                (*node)->uriSchemes[index][strLen - 1] = '\0'; /*Null terminate it*/
19
hgs
parents:
diff changeset
   539
                index++;
25
hgs
parents: 21
diff changeset
   540
                }
19
hgs
parents:
diff changeset
   541
            else if (tagType == FWMgrTagFileExt)
25
hgs
parents: 21
diff changeset
   542
                {
hgs
parents: 21
diff changeset
   543
                (*node)->fileExts[index] = (char*) calloc(strLen,
hgs
parents: 21
diff changeset
   544
                        sizeof(char));
19
hgs
parents:
diff changeset
   545
                strncpy((*node)->fileExts[index], tempStartPtr, strLen);
25
hgs
parents: 21
diff changeset
   546
                (*node)->fileExts[index][strLen - 1] = '\0'; /*Null terminate it*/
19
hgs
parents:
diff changeset
   547
                index++;
25
hgs
parents: 21
diff changeset
   548
                }
19
hgs
parents:
diff changeset
   549
            }
25
hgs
parents: 21
diff changeset
   550
        tempStartPtr = tempEndPtr;
19
hgs
parents:
diff changeset
   551
        }
25
hgs
parents: 21
diff changeset
   552
    return FWMgrTrue;
19
hgs
parents:
diff changeset
   553
    }
36
hgs
parents: 25
diff changeset
   554