/* * Copyright (C) 2013 Jeff Epler * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "interp_base.hh" #include #include #include #include InterpBase::~InterpBase() {} InterpBase *interp_from_shlib(const char *shlib) { fprintf(stderr, "interp_from_shlib(%s)\n", shlib); dlopen(NULL, RTLD_GLOBAL); void *interp_lib = dlopen(shlib, RTLD_NOW); if(!interp_lib) { fprintf(stderr, "emcTaskInit: could not open interpreter '%s': %s\n", shlib, dlerror()); char relative_interp[PATH_MAX]; snprintf(relative_interp, sizeof(relative_interp), "%s/%s", EMC2_HOME "/lib/emc2", shlib); interp_lib = dlopen(relative_interp, RTLD_NOW); } if(!interp_lib) { fprintf(stderr, "emcTaskInit: could not open interpreter '%s': %s\n", shlib, dlerror()); return 0; } typedef InterpBase* (*Constructor)(); Constructor constructor = (Constructor)dlsym(interp_lib, "makeInterp"); if(!constructor) { fprintf(stderr, "emcTaskInit: could not get symbol makeInterp from interpreter '%s': %s\n", shlib, dlerror()); return 0; } InterpBase *pinterp = constructor(); if(!pinterp) { fprintf(stderr, "emcTaskInit: makeInterp() returned NULL from interpreter '%s'\n", shlib); return 0; } return pinterp; }