Revision: 53410
http://brlcad.svn.sourceforge.net/brlcad/?rev=53410&view=rev
Author: bob1961
Date: 2012-11-01 11:20:19 +0000 (Thu, 01 Nov 2012)
Log Message:
-----------
Updated ged_select() and ged_rselect() to also select the points within a bot.
Modified Paths:
--------------
brlcad/trunk/src/libged/select.c
Modified: brlcad/trunk/src/libged/select.c
===================================================================
--- brlcad/trunk/src/libged/select.c 2012-11-01 11:18:43 UTC (rev 53409)
+++ brlcad/trunk/src/libged/select.c 2012-11-01 11:20:19 UTC (rev 53410)
@@ -25,8 +25,8 @@
#include "common.h"
+#include <string.h>
#include "bio.h"
-
#include "solid.h"
#include "./ged_private.h"
@@ -260,18 +260,23 @@
/*
* Returns a list of items within the specified rectangle or circle.
+ * If bot is specified, the bot points within the specified area are returned.
*
* Usage:
- * select vx vy {vr | vw vh}
+ * select [-b bot] [-p] [-z vminz] vx vy {vr | vw vh}
*
*/
int
ged_select(struct ged *gedp, int argc, const char *argv[])
{
- int pflag;
+ int c;
double vx, vy, vw, vh, vr;
- static const char *usage = "[-p] vx vy {vr | vw vh}";
+ static const char *usage = "[-b bot] [-p] [-z vminz] vx vy {vr | vw vh}";
const char *cmd = argv[0];
+ struct rt_db_internal intern;
+ struct rt_bot_internal *botip;
+ int pflag = 0;
+ double vminz = -1000.0;
GED_CHECK_DATABASE_OPEN(gedp, GED_ERROR);
GED_CHECK_DRAWABLE(gedp, GED_ERROR);
@@ -281,16 +286,57 @@
/* initialize result */
bu_vls_trunc(gedp->ged_result_str, 0);
- /* Process the -p option */
- if (argc > 1 && argv[1][0] == '-' && argv[1][1] == 'p' && argv[1][2] ==
'\0') {
- pflag = 1;
+ /* Get command line options. */
+ bu_optind = 1;
+ while ((c = bu_getopt(argc, (char * const *)argv, "b:pz:")) != -1) {
+ switch (c) {
+ case 'b':
+ {
+ mat_t mat;
- /* Skip past the -p option */
- --argc;
- ++argv;
- } else
- pflag = 0;
+ /* skip subsequent bot specifications */
+ if (botip != (struct rt_bot_internal *)NULL)
+ break;
+ if (wdb_import_from_path2(gedp->ged_result_str, &intern, bu_optarg,
gedp->ged_wdbp, mat) == GED_ERROR) {
+ bu_vls_printf(gedp->ged_result_str, "%s: failed to find %s",
cmd, bu_optarg);
+ return GED_ERROR;
+ }
+
+ if (intern.idb_major_type != DB5_MAJORTYPE_BRLCAD ||
+ intern.idb_minor_type != DB5_MINORTYPE_BRLCAD_BOT) {
+ bu_vls_printf(gedp->ged_result_str, "%s: %s is not a BOT", cmd,
bu_optarg);
+ rt_db_free_internal(&intern);
+
+ return GED_ERROR;
+ }
+
+ botip = (struct rt_bot_internal *)intern.idb_ptr;
+ }
+
+ break;
+ case 'p':
+ pflag = 1;
+ break;
+ case 'z':
+ if (sscanf(bu_optarg, "%lf", &vminz) != 1) {
+ if (botip != (struct rt_bot_internal *)NULL)
+ rt_db_free_internal(&intern);
+
+ bu_vls_printf(gedp->ged_result_str, "%s: bad vminz - %s", cmd,
bu_optarg);
+ bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
+ }
+
+ break;
+ default:
+ bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
+ return GED_ERROR;
+ }
+ }
+
+ argc -= (bu_optind - 1);
+ argv += (bu_optind - 1);
+
if (argc < 4 || 5 < argc) {
bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
return GED_ERROR;
@@ -304,10 +350,19 @@
return GED_ERROR;
}
- if (pflag)
- return _ged_select_partial(gedp, vx, vy, vr, vr, 1);
- else
- return _ged_select(gedp, vx, vy, vr, vr, 1);
+ if (botip != (struct rt_bot_internal *)NULL) {
+ int ret;
+
+ ret = _ged_select_botpts(gedp, botip, vx, vy, vr, vr, vminz, 1);
+ rt_db_free_internal(&intern);
+
+ return ret;
+ } else {
+ if (pflag)
+ return _ged_select_partial(gedp, vx, vy, vr, vr, 1);
+ else
+ return _ged_select(gedp, vx, vy, vr, vr, 1);
+ }
} else {
if (sscanf(argv[1], "%lf", &vx) != 1 ||
sscanf(argv[2], "%lf", &vy) != 1 ||
@@ -317,10 +372,19 @@
return GED_ERROR;
}
- if (pflag)
- return _ged_select_partial(gedp, vx, vy, vw, vh, 0);
- else
- return _ged_select(gedp, vx, vy, vw, vh, 0);
+ if (botip != (struct rt_bot_internal *)NULL) {
+ int ret;
+
+ ret = _ged_select_botpts(gedp, botip, vx, vy, vw, vh, vminz, 0);
+ rt_db_free_internal(&intern);
+
+ return ret;
+ } else {
+ if (pflag)
+ return _ged_select_partial(gedp, vx, vy, vw, vh, 0);
+ else
+ return _ged_select(gedp, vx, vy, vw, vh, 0);
+ }
}
}
@@ -329,15 +393,19 @@
* Returns a list of items within the previously defined rectangle.
*
* Usage:
- * rselect
+ * rselect [-b bot] [-p] [-z vminz]
*
*/
int
ged_rselect(struct ged *gedp, int argc, const char *argv[])
{
- int pflag;
- static const char *usage = "[-p]";
+ int c;
+ static const char *usage = "[-b bot] [-p] [-z vminz]";
const char *cmd = argv[0];
+ struct rt_db_internal intern;
+ struct rt_bot_internal *botip = (struct rt_bot_internal *)NULL;
+ int pflag = 0;
+ double vminz = -1000.0;
GED_CHECK_DATABASE_OPEN(gedp, GED_ERROR);
GED_CHECK_DRAWABLE(gedp, GED_ERROR);
@@ -347,35 +415,91 @@
/* initialize result */
bu_vls_trunc(gedp->ged_result_str, 0);
- /* Process the -p option */
- if (argc > 1 && argv[1][0] == '-' && argv[1][1] == 'p' && argv[1][2] ==
'\0') {
- pflag = 1;
+ /* Get command line options. */
+ bu_optind = 1;
+ while ((c = bu_getopt(argc, (char * const *)argv, "b:pz:")) != -1) {
+ switch (c) {
+ case 'b':
+ {
+ mat_t mat;
- /* Skip past the -p option */
- --argc;
- ++argv;
- } else
- pflag = 0;
+ /* skip subsequent bot specifications */
+ if (botip != (struct rt_bot_internal *)NULL)
+ break;
+ if (wdb_import_from_path2(gedp->ged_result_str, &intern, bu_optarg,
gedp->ged_wdbp, mat) == GED_ERROR) {
+ bu_vls_printf(gedp->ged_result_str, "%s: failed to find %s",
cmd, bu_optarg);
+ return GED_ERROR;
+ }
+
+ if (intern.idb_major_type != DB5_MAJORTYPE_BRLCAD ||
+ intern.idb_minor_type != DB5_MINORTYPE_BRLCAD_BOT) {
+ bu_vls_printf(gedp->ged_result_str, "%s: %s is not a BOT", cmd,
bu_optarg);
+ rt_db_free_internal(&intern);
+
+ return GED_ERROR;
+ }
+
+ botip = (struct rt_bot_internal *)intern.idb_ptr;
+ }
+
+ break;
+ case 'p':
+ pflag = 1;
+ break;
+ case 'z':
+ if (sscanf(bu_optarg, "%lf", &vminz) != 1) {
+ if (botip != (struct rt_bot_internal *)NULL)
+ rt_db_free_internal(&intern);
+
+ bu_vls_printf(gedp->ged_result_str, "%s: bad vminz - %s", cmd,
bu_optarg);
+ bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
+ }
+
+ break;
+ default:
+ bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
+ return GED_ERROR;
+ }
+ }
+
+ argc -= (bu_optind - 1);
+ argv += (bu_optind - 1);
+
if (argc != 1) {
bu_vls_printf(gedp->ged_result_str, "Usage: %s %s", cmd, usage);
return GED_ERROR;
}
- if (pflag)
- return _ged_select_partial(gedp,
- gedp->ged_gvp->gv_rect.grs_x,
- gedp->ged_gvp->gv_rect.grs_y,
- gedp->ged_gvp->gv_rect.grs_width,
- gedp->ged_gvp->gv_rect.grs_height,
- 0);
- else
- return _ged_select(gedp,
- gedp->ged_gvp->gv_rect.grs_x,
- gedp->ged_gvp->gv_rect.grs_y,
- gedp->ged_gvp->gv_rect.grs_width,
- gedp->ged_gvp->gv_rect.grs_height,
- 0);
+ if (botip != (struct rt_bot_internal *)NULL) {
+ int ret;
+
+ ret = _ged_select_botpts(gedp, botip,
+ gedp->ged_gvp->gv_rect.grs_x,
+ gedp->ged_gvp->gv_rect.grs_y,
+ gedp->ged_gvp->gv_rect.grs_width,
+ gedp->ged_gvp->gv_rect.grs_height,
+ vminz,
+ 0);
+
+ rt_db_free_internal(&intern);
+ return ret;
+ } else {
+ if (pflag)
+ return _ged_select_partial(gedp,
+ gedp->ged_gvp->gv_rect.grs_x,
+ gedp->ged_gvp->gv_rect.grs_y,
+ gedp->ged_gvp->gv_rect.grs_width,
+ gedp->ged_gvp->gv_rect.grs_height,
+ 0);
+ else
+ return _ged_select(gedp,
+ gedp->ged_gvp->gv_rect.grs_x,
+ gedp->ged_gvp->gv_rect.grs_y,
+ gedp->ged_gvp->gv_rect.grs_width,
+ gedp->ged_gvp->gv_rect.grs_height,
+ 0);
+ }
}
This was sent by the SourceForge.net collaborative development platform, the
world's largest Open Source development site.
------------------------------------------------------------------------------
Everyone hates slow websites. So do we.
Make your web apps faster with AppDynamics
Download AppDynamics Lite for free today:
http://p.sf.net/sfu/appdyn_sfd2d_oct
_______________________________________________
BRL-CAD Source Commits mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/brlcad-commits