ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/rv2.c
(Generate patch)

Comparing ray/src/rt/rv2.c (file contents):
Revision 2.46 by greg, Thu Apr 14 04:42:33 2005 UTC vs.
Revision 2.49 by greg, Tue Apr 19 01:15:06 2005 UTC

# Line 305 | Line 305 | getfocus(                              /* set focus distance */
305                          error(COMMAND, "not on image");
306                          return;
307                  }
308 <                rayorigin(&thisray, NULL, PRIMARY, 1.0);
308 >                rayorigin(&thisray, PRIMARY, NULL, NULL);
309                  if (!localhit(&thisray, &thescene)) {
310                          error(COMMAND, "not a local object");
311                          return;
# Line 719 | Line 719 | char  *s;
719                  return;
720          }
721  
722 <        rayorigin(&thisray, NULL, PRIMARY, 1.0);
722 >        rayorigin(&thisray, PRIMARY, NULL, NULL);
723          
724          rayvalue(&thisray);
725  
726          if (thisray.ro == NULL)
727                  (*dev->comout)("ray hit nothing");
728          else {
729 <                OBJREC  *mat = findmaterial(thisray.ro);
730 <                sprintf(buf, "ray hit %s%s %s \"%s\"",
731 <                                thisray.rod < 0.0 ? "back of " : "",
732 <                                mat==NULL ? VOIDID : mat->oname,
729 >                OBJREC  *mat = NULL;
730 >                OBJREC  *mod = NULL;;
731 >                char    matspec[256];
732 >                matspec[0] = '\0';
733 >                if (thisray.ro->omod != OVOID) {
734 >                        mod = objptr(thisray.ro->omod);
735 >                        mat = findmaterial(mod);
736 >                }
737 >                if (thisray.rod < 0.0)
738 >                        strcpy(matspec, "back of ");
739 >                if (mod != NULL) {
740 >                        strcat(matspec, mod->oname);
741 >                        if (mat != mod && mat != NULL)
742 >                                sprintf(matspec+strlen(matspec),
743 >                                        " (%s)", mat->oname);
744 >                } else
745 >                        strcat(matspec, VOIDID);
746 >                sprintf(buf, "ray hit %s %s \"%s\"", matspec,
747                                  ofun[thisray.ro->otype].funame,
748                                  thisray.ro->oname);
749                  if ((ino = objptr(thisray.robj)) != thisray.ro)

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines