summaryrefslogtreecommitdiffstats
path: root/meta-agl-profile-cluster
diff options
context:
space:
mode:
authorScott Murray <scott.murray@konsulko.com>2020-01-22 18:16:17 -0500
committerScott Murray <scott.murray@konsulko.com>2020-01-22 18:16:17 -0500
commitc4952739d5d811153bacddd57fd1ecd09cbcad7d (patch)
treefdeb74d1c04d480364fd2a530cbd1a8e19fc2024 /meta-agl-profile-cluster
parentfc7f233e63feb4c4d9dac698f94cf0daecb63e0a (diff)
meta-agl-profile-core: handle freetype upgrade
Rename and update freetype bbappend in meta-agl-profile-core to work with new 2.10.1 recipe in oe-core. Bug-AGL: SPEC-2932 Change-Id: I71ae6dfde9d9ae36a3f70661fbb84afb575d6786 Signed-off-by: Scott Murray <scott.murray@konsulko.com>
Diffstat (limited to 'meta-agl-profile-cluster')
0 files changed, 0 insertions, 0 deletions
>
/*
 * Copyright (C) 2016 "IoT.bzh"
 * Author Fulup Ar Foll <fulup@iot.bzh>
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#define _GNU_SOURCE
#include <stdio.h>
#include <unistd.h>
#include <sys/stat.h>
#include <string.h>
#include <time.h>
#include <sys/prctl.h>
#include <dirent.h>

#include "filescan-utils.h"

// List Avaliable Configuration Files
json_object* ScanForConfig (const char* searchPath, CtlScanDirModeT mode, const char *prefix, const char *extention) {
    json_object *responseJ;
    char *dirPath;
    char* dirList= strdup(searchPath);
    size_t extentionLen=0;
    int count=0;

    int ScanDir (char *searchPath) {
        int found=0;
        DIR  *dirHandle;
        struct dirent *dirEnt;
        dirHandle = opendir (searchPath);
        if (!dirHandle) {
            AFB_DEBUG("CONFIG-SCANNING dir=%s not readable", searchPath);
            return 0;
        }

        //AFB_NOTICE ("CONFIG-SCANNING:ctl_listconfig scanning: %s", searchPath);
        while ((dirEnt = readdir(dirHandle)) != NULL) {

            // recursively search embedded directories ignoring any directory starting by '.' or '_'
            if (dirEnt->d_type == DT_DIR && mode == CTL_SCAN_RECURSIVE) {
                char newpath[CONTROL_MAXPATH_LEN];
                if (dirEnt->d_name[0]=='.' || dirEnt->d_name[0]=='_') continue;

                strncpy(newpath, searchPath, sizeof(newpath));
                strncat(newpath, "/", sizeof(newpath)-strlen(newpath)-1);
                strncat(newpath, dirEnt->d_name, sizeof(newpath)-strlen(newpath)-1);
                found += ScanDir(newpath);
                continue;
            }

            // Unknown type is accepted to support dump filesystems
            if (dirEnt->d_type == DT_REG || dirEnt->d_type == DT_UNKNOWN) {

                // check prefix and extention
                ssize_t extentionIdx=strlen(dirEnt->d_name)-extentionLen;
                if (extentionIdx <= 0) continue;
                if (prefix && !strcasestr (dirEnt->d_name, prefix)) continue;
                if (extention && strcasecmp (extention, &dirEnt->d_name[extentionIdx])) continue;

                struct json_object *pathJ = json_object_new_object();
                json_object_object_add(pathJ, "fullpath", json_object_new_string(searchPath));
                json_object_object_add(pathJ, "filename", json_object_new_string(dirEnt->d_name));
                json_object_array_add(responseJ, pathJ);
                found ++;
            }
        }
        closedir(dirHandle);
        return found;
    }

    if (extention) extentionLen=strlen(extention);
    responseJ = json_object_new_array();

    // loop recursively on dir
    for (dirPath= strtok(dirList, ":"); dirPath && *dirPath; dirPath=strtok(NULL,":")) {
         count += ScanDir (dirPath);
    }
    if (count == 0) {
        json_object_put (responseJ);
        free(dirList);
        return NULL;
    }
    free(dirList);
    return (responseJ);
}

const char *GetMidleName(const char*name) {
    char *fullname = strdup(name);

    for (int idx = 0; fullname[idx] != '\0'; idx++) {
        if (fullname[idx] == '-') {
            int start;
            start = idx + 1;
            for (int jdx = start; ; jdx++) {
                if (fullname[jdx] == '-' || fullname[jdx] == '.' || fullname[jdx] == '\0') {
                    fullname[jdx] = '\0';
                    return &fullname[start];
                }
            }
            break;
        }
    }
    return "";
}

const char *GetBinderName() {
    static char *binderName=NULL;

    if (binderName) return binderName;

    binderName= getenv("AFB_BINDER_NAME");
    if (!binderName) {
        static char psName[17];
        // retrieve binder name from process name afb-name-trailer
        prctl(PR_GET_NAME, psName,NULL,NULL,NULL);
        binderName=(char*)GetMidleName(psName);
    }

    return binderName;
}

char *GetBindingDirPath(struct afb_dynapi *dynapi)
{
    // A file description should not be greater than 999.999.999
    char fd_link[CONTROL_MAXPATH_LEN];
    char retdir[CONTROL_MAXPATH_LEN];
    ssize_t len;

    if(dynapi)
        sprintf(fd_link, "/proc/self/fd/%d", afb_dynapi_rootdir_get_fd(dynapi));
    else
        sprintf(fd_link, "/proc/self/fd/%d", afb_daemon_rootdir_get_fd_v2());

    if((len = readlink(fd_link, retdir, sizeof(retdir)-1)) == -1)
    {
        perror("lstat");
        strncpy(retdir, "/tmp", 4);
    }
    else
    {
        retdir[len] = '\0';
    }

    return strndup(retdir, sizeof(retdir));
}