⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cdl_exec.cxx

📁 移植到WLIT项目的redboot源代码
💻 CXX
📖 第 1 页 / 共 2 页
字号:
            char cwd [_MAX_PATH + 1];#else            char cwd [PATH_MAX + 1];#endif            getcwd (cwd, sizeof cwd);#ifdef __CYGWIN__            char cwd_win32 [MAXPATHLEN + 1];            cygwin_conv_to_win32_path (cwd, cwd_win32);            generate_build_tree (config, cwd_win32, install_prefix);#else            generate_build_tree (config, cwd, install_prefix);#endif            config->generate_config_headers (install_prefix.empty () ? "install/include/pkgconf" : install_prefix + "/include/pkgconf");            status = true;        } else {            printf("\nUnable to generate build tree, this configuration still contains conflicts.\n");            printf("Either resolve the conflicts or use --ignore-errors\n");        }    } catch (CdlStringException exception) {        exception_handler (exception);    } catch (...) {        exception_handler ();    }    delete_cdl_data ();    return status;}// ----------------------------------------------------------------------------boolcdl_exec::cmd_list (){    bool status = false;    try {        init(false);        // list the installed packages        std::vector<std::string> packages = pkgdata->get_packages ();        std::sort (packages.begin (), packages.end ());        for (unsigned int package = 0; package < packages.size (); package++) {            const std::vector<std::string> & aliases = pkgdata->get_package_aliases (packages [package]);            printf ("Package %s (%s):\n aliases:", packages [package].c_str (), aliases [0].c_str ());            for (unsigned int alias = 1; alias < aliases.size (); alias++) {                printf (" %s", aliases [alias].c_str ());            }            const std::vector<std::string> & versions = pkgdata->get_package_versions (packages [package]);            printf ("\n versions:");            for (unsigned int version = 0; version < versions.size (); version++) {                printf (" %s", versions [version].c_str ());            }            printf ("\n");        }        // list the available targets        std::vector<std::string> targets = pkgdata->get_targets ();        std::sort (targets.begin (), targets.end ());        for (unsigned int target = 0; target < targets.size (); target++) {            const std::vector<std::string> & aliases = pkgdata->get_target_aliases (targets [target]);            printf ("Target %s (%s):\n aliases:", targets [target].c_str (), aliases [0].c_str ());            for (unsigned int alias = 1; alias < aliases.size (); alias++) {                printf (" %s", aliases [alias].c_str ());            }            printf ("\n");        }        // list the available templates        std::vector<std::string> templates = pkgdata->get_templates ();        std::sort (templates.begin (), templates.end ());        for (unsigned int templ = 0; templ < templates.size (); templ++) {            const std::vector<std::string> & versions = pkgdata->get_template_versions (templates [templ]);            printf ("Template %s:\n versions:", templates [templ].c_str ());            for (unsigned int version = 0; version < versions.size (); version++) {                printf (" %s", versions [version].c_str ());            }            printf ("\n");        }        status = true;    } catch (CdlStringException exception) {        exception_handler (exception);    } catch (...) {        exception_handler ();    }    delete_cdl_data ();    return status;}// ----------------------------------------------------------------------------boolcdl_exec::cmd_check (){    bool status = false;    unsigned int n;    try {        init(true);        // check() should never invoke the inference engine. The user        // wants to determine the current status, which should not        // change.        // However, updating the savefile is worthwhile because it        // will now contain more accurate information about the state.        config->save (savefile);        // report current target and template        printf ("Target: %s\n", config->get_hardware ().c_str ());        printf ("Template: %s\n", config->get_template ().c_str ());        std::vector<std::string> template_packages = pkgdata->get_template_packages (config->get_template ());        const std::vector<std::string> & hardware_packages = pkgdata->get_target_packages (config->get_hardware ());        for (n = 0; n < hardware_packages.size (); n++) {            template_packages.push_back (hardware_packages [n]);        }        // report loaded packages not in the templates        const std::vector<CdlLoadable> & loadables = config->get_loadables ();        std::vector<std::string> added_packages;        std::vector<CdlLoadable>::const_iterator loadable_i;        for (loadable_i = loadables.begin (); loadable_i != loadables.end (); loadable_i++) {            const CdlNode & node = dynamic_cast<CdlNode> (* loadable_i);            if (template_packages.end () == std::find (template_packages.begin (), template_packages.end (), node->get_name ())) {                added_packages.push_back (node->get_name ());            }        }        if (added_packages.size ()) {            printf ("Added:\n");        }        for (n = 0; n < added_packages.size (); n++) {            printf (" %s\n", added_packages [n].c_str ());        }        // report template packages not in the configuration        std::vector<std::string> removed_packages;        for (n = 0; n < template_packages.size (); n++) {            if (! config->lookup (template_packages [n])) {                removed_packages.push_back (template_packages [n]);            }        }        if (removed_packages.size ()) {            printf ("Removed:\n");        }        for (n = 0; n < removed_packages.size (); n++) {            printf (" %s\n", removed_packages [n].c_str ());        }        // report packages of non-default version        std::vector<CdlValuable> version_packages;        for (loadable_i = loadables.begin (); loadable_i != loadables.end (); loadable_i++) {            const CdlValuable & valuable = dynamic_cast<CdlValuable> (* loadable_i);            if (pkgdata->get_package_versions (valuable->get_name ()) [0] != valuable->get_value ()) {                version_packages.push_back (valuable);            }        }        if (version_packages.size ()) {            printf ("Version(s):\n");        }        for (n = 0; n < version_packages.size (); n++) {            printf (" %s %s\n", version_packages [n]->get_name ().c_str (), version_packages [n]->get_value ().c_str ());        }        // report conflicts        const std::list<CdlConflict> & conflicts = config->get_all_conflicts ();        if (conflicts.size ()) {            printf ("%u conflict(s):\n", conflicts.size ());        } else {            printf ("No conflicts\n");        }        report_conflicts();        status = true;    } catch (CdlStringException exception) {        exception_handler (exception);    } catch (...) {        exception_handler ();    }    delete_cdl_data ();    return status;}// ----------------------------------------------------------------------------boolcdl_exec::cmd_resolve (){    bool status = false;    try {        init(true);        CdlTransactionBody::set_callback_fn(&transaction_callback);        config->resolve_all_conflicts ();        report_conflicts();        config->save (savefile);        if (ignore_errors || (0 == config->get_all_conflicts().size())) {            status = true;        }    } catch (CdlStringException exception) {        exception_handler (exception);    } catch (...) {        exception_handler ();    }    delete_cdl_data ();    return status;}// ----------------------------------------------------------------------------// The inference callback. This could give some useful diagnostics, or it// could do useful things when running in some interactive mode. In batch// mode it should not do anything.CdlInferenceCallbackResultcdl_exec::inference_callback (CdlTransaction transaction){    return CdlInferenceCallbackResult_Continue;}// ----------------------------------------------------------------------------// Output a message with indentation after newlines.static voiddump_string(unsigned int indent, const std::string& str){    bool newline_pending = false;    unsigned int i, j;    for (i = 0; i < str.size(); i++) {        if (newline_pending) {            putchar('\n');            if ('\n' != str[i]) {                for (j = 0; j < indent; j++) {                    putchar(' ');                }            }            newline_pending = false;        }        if ('\n' == str[i]) {            newline_pending = true;        } else {            putchar(str[i]);        }    }    if (newline_pending) {        putchar('\n');  // But not the indentation.    }}// ----------------------------------------------------------------------------// The transaction callback. This should report any changes that have been// made to the configuration. The amount of output depends on the verbosity// level selected by the user.//// 1) quiet     - no output at all// 2) default   - list updates done by the inference engine.// 3) verbose   - this does not currently add anything.// // There is no reporting of new or resolved conflicts. Resolved// conflicts are probably of no interest in batch mode. New conflicts// will be handled by report_conflicts(). There is also no information// given about active state changes, although arguably there should be// especially in the case of containers.voidcdl_exec::transaction_callback(const CdlTransactionCallback& callback_data){    if (quiet) {        return;    }    unsigned int i;    for (i = 0; i < callback_data.value_changes.size(); i++) {        CdlValuable valuable = callback_data.value_changes[i];        if (CdlValueSource_Inferred == valuable->get_source()) {            CdlEvalContext context(0, valuable, 0);            CdlSimpleValue simple_val;            CdlSimpleValue::eval_valuable(context, valuable, simple_val);            std::string msg = std::string("U ") + valuable->get_name() + ", new inferred value ";            std::string value = simple_val.get_value();            if ("" == value) {                msg += "\"\"";            } else {                msg += value;            }            msg += "\n";            dump_string(4, msg);        }    }}// ----------------------------------------------------------------------------// Report the remaining conflicts in the configuration. These indicate// problems that the user should fix before going further with the// configuration, e.g. before generating a build tree.//// Quiet verbosity level has no effect on this, but at the verbose level// it is a good idea to look for a possible solution to the conflict.voidcdl_exec::report_conflicts(){    const std::list<CdlConflict>& all_conflicts = config->get_all_conflicts();    std::list<CdlConflict>::const_iterator conf_i;    for (conf_i = all_conflicts.begin(); conf_i != all_conflicts.end(); conf_i++) {        CdlNode     node = (*conf_i)->get_node();        std::string msg = std::string("C ") + node->get_name() + ", " + (*conf_i)->get_explanation() + "\n";        dump_string(2, msg);        if (verbose && (*conf_i)->resolution_implemented()) {            // See if there is a possible solution to this conflict.            // This involves creating a transaction, invoking the            // inference engine, and cancelling the transaction            // (thus making sure that nothing actually changes).            //            // NOTE: at some stage libcdl may keep track of solutions            // globally. However, although it will know when a solution            // becomes invalid it will not necessarily try to resolve            // all global conflicts after every change, so attempting            // to do this in a transaction may still be necessary.            CdlTransaction transact = CdlTransactionBody::make(config);            transact->resolve(*conf_i);            if ((*conf_i)->has_known_solution()) {                std::string soln_msg = "  Possible solution:\n";                const std::vector<std::pair<CdlValuable, CdlValue> > & soln = (*conf_i)->get_solution();                unsigned int i;                for (i = 0; i < soln.size(); i++) {                    soln_msg += soln[i].first->get_name() + " -> " + soln[i].second.get_value() + "\n";                }#if 0                // FIXME: currently this member only works for nested sub-transactions.                if (transact->user_confirmation_required()) {                    msg += "This change affects previous user settings.\n";                }#endif                                dump_string(4, soln_msg);            }            transact->cancel();            delete transact;        }    }}// ----------------------------------------------------------------------------voidcdl_exec::diagnostic_handler (std::string message){    printf ("%s\n", message.c_str ());}void cdl_exec::exception_handler (CdlStringException exception) {    printf ("%s\n", exception.get_message ().c_str ());}voidcdl_exec::exception_handler (){    printf ("Unknown error\n");}// ----------------------------------------------------------------------------std::stringcdl_exec::resolve_package_alias (const std::string alias){    std::string package = alias;    if (! pkgdata->is_known_package (alias)) { // if the alias is not a package name        const std::vector<std::string> & packages = pkgdata->get_packages (); // get packages        for (unsigned int n = 0; n < packages.size (); n++) { // for each package            const std::vector<std::string> & aliases = pkgdata->get_package_aliases (packages [n]); // get package aliases            if (aliases.end () != std::find (aliases.begin (), aliases.end (), alias)) { // if alias is found                package = packages [n]; // note the package                break;            }        }    }    return package;}std::stringcdl_exec::resolve_hardware_alias (const std::string alias){    std::string target = alias;    if (! pkgdata->is_known_target (alias)) { // if the alias is not a target name        const std::vector<std::string> & targets = pkgdata->get_targets (); // get targets        for (unsigned int n = 0; n < targets.size (); n++) { // for each target            const std::vector<std::string> & aliases = pkgdata->get_target_aliases (targets [n]); // get target aliases            if (aliases.end () != std::find (aliases.begin (), aliases.end (), alias)) { // if alias is found                target = targets [n]; // note the target                break;            }        }    }    return target;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -