blob: b491d1799a5fb98b01de19a4ff33e8fc3d65975a [file] [log] [blame]
/*
* yosys -- Yosys Open SYnthesis Suite
*
* Copyright (C) 2012 Clifford Wolf <clifford@clifford.at>
* Copyright (C) 2020 The Symbiflow Authors
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
*/
#include "get_count.h"
#include "kernel/rtlil.h"
USING_YOSYS_NAMESPACE
void GetCount::help()
{
log("\n");
log(" get_count <options> [selection]");
log("\n");
log("When used from inside the TCL interpreter returns count of selected objects.\n");
log("The object type to count may be given as an argument. Only one at a time.\n");
log("If none is given then the total count of all selected objects is returned.\n");
log("\n");
log(" -modules\n");
log(" Returns the count of modules in selection\n");
log("\n");
log(" -cells\n");
log(" Returns the count of cells in selection\n");
log("\n");
log(" -wires\n");
log(" Returns the count of wires in selection\n");
log("\n");
}
void GetCount::execute(std::vector<std::string> a_Args, RTLIL::Design *a_Design)
{
// Parse args
ObjectType type = ObjectType::NONE;
if (a_Args.size() < 2) {
log_error("Invalid argument!\n");
}
if (a_Args[1] == "-modules") {
type = ObjectType::MODULE;
} else if (a_Args[1] == "-cells") {
type = ObjectType::CELL;
} else if (a_Args[1] == "-wires") {
type = ObjectType::WIRE;
} else if (a_Args[1][0] == '-') {
log_error("Invalid argument '%s'!\n", a_Args[1].c_str());
} else {
log_error("Object type not specified!\n");
}
extra_args(a_Args, 2, a_Design);
// Get the TCL interpreter
Tcl_Interp *tclInterp = yosys_get_tcl_interp();
// Count objects
size_t moduleCount = 0;
size_t cellCount = 0;
size_t wireCount = 0;
moduleCount += a_Design->selected_modules().size();
for (auto module : a_Design->selected_modules()) {
cellCount += module->selected_cells().size();
wireCount += module->selected_wires().size();
}
size_t count = 0;
switch (type) {
case ObjectType::MODULE:
count = moduleCount;
break;
case ObjectType::CELL:
count = cellCount;
break;
case ObjectType::WIRE:
count = wireCount;
break;
default:
log_assert(false);
}
// Return the value as string to the TCL interpreter
std::string value = std::to_string(count);
Tcl_Obj *tclStr = Tcl_NewStringObj(value.c_str(), value.size());
Tcl_SetObjResult(tclInterp, tclStr);
}