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

Comparing ray/src/hd/rhdisp.c (file contents):
Revision 3.43 by greg, Sat Feb 22 02:07:24 2003 UTC vs.
Revision 3.49 by schorsch, Sun Jul 27 22:12:02 2003 UTC

# Line 5 | Line 5 | static const char      RCSid[] = "$Id$";
5   * Holodeck display process.
6   */
7  
8 + #include <string.h>
9 + #include <ctype.h>
10 +
11   #include "rholo.h"
12   #include "rhdisp.h"
13   #include "rhdriver.h"
14   #include "selcall.h"
12 #include <ctype.h>
15  
16   #ifndef VIEWHISTLEN
17   #define VIEWHISTLEN     4       /* number of remembered views */
# Line 216 | Line 218 | char   *gfn, *pfn;
218          hdlist[hd] = (HOLO *)malloc(sizeof(HOLO));
219          if (hdlist[hd] == NULL)
220                  error(SYSTEM, "out of memory in add_holo");
221 <        bcopy((char *)hdg, (char *)hdlist[hd], sizeof(HDGRID));
221 >        memcpy((void *)hdlist[hd], (void *)hdg, sizeof(HDGRID));
222          hdcompgrid(hdlist[hd]);
223          hdgfn[hd] = savestr(gfn);
224          hdpfn[hd] = pfn && *pfn ? savestr(pfn) : (char *)NULL;
225          if (hd)
226                  return;
227                                          /* set initial viewpoint */
228 <        copystruct(&nv, &odev.v);
228 >        nv = odev.v;
229          VSUM(nv.vp, hdlist[0]->orig, hdlist[0]->xv[0], 0.5);
230          VSUM(nv.vp, nv.vp, hdlist[0]->xv[1], 0.5);
231          VSUM(nv.vp, nv.vp, hdlist[0]->xv[2], 0.5);
# Line 247 | Line 249 | register PACKHEAD      *p;
249          double  d;
250          register int    i;
251                                          /* get beam coordinates */
252 <        if (p->hd < 0 | p->hd >= HDMAX || hdlist[p->hd] == NULL)
252 >        if ((p->hd < 0) | (p->hd >= HDMAX) || hdlist[p->hd] == NULL)
253                  error(INTERNAL, "bad holodeck number in disp_bundle");
254          if (!hdbcoord(gc, hdlist[p->hd], p->bi))
255                  error(INTERNAL, "bad beam index in disp_bundle");
# Line 275 | Line 277 | register VIEW  *v;
277          static unsigned nhist;
278          VIEW    *dv;
279          int     i, res[2];
280 <        int2    *slist;
280 >        int16   *slist;
281          char    *err;
282                                  /* restore previous view? */
283          if (v == NULL) {
# Line 304 | Line 306 | again:
306                                  error(COMMAND, "invalid starting view");
307                                  return;
308                          }
309 <                        copystruct(v, viewhist + ((nhist-1)%VIEWHISTLEN));
309 >                        *v = *(viewhist + ((nhist-1)%VIEWHISTLEN));
310                          goto again;     /* poss. overloading dev_section()? */
311                  }
312                  DCHECK(*slist < 0, WARNING, "no visible sections in new_view");
# Line 317 | Line 319 | again:
319          imm_mode = beam_sync(odev.firstuse) > 0;
320                                  /* record new view */
321          if (v < viewhist || v >= viewhist+VIEWHISTLEN) {
322 <                copystruct(viewhist + (nhist%VIEWHISTLEN), v);
322 >                *(viewhist + (nhist%VIEWHISTLEN)) = *v;
323                  nhist++;
324          }
325   }
# Line 347 | Line 349 | char   *args;
349          beam_init(0);                                   /* add basic views */
350          for (i = 0; (dv = dev_auxview(i, res)) != NULL; i++)
351                  beam_view(dv, res[0]>>4, res[1]>>4);
352 <        copystruct(&vwfocus, &odev.v);                  /* add focus view */
352 >        vwfocus = odev.v;                       /* add focus view */
353          switch (odev.v.type) {
354          case VT_PER:
355                  vwfocus.horiz = 2.*180./PI*atan(
# Line 413 | Line 415 | usr_input()                    /* get user input and process it */
415          }
416          switch (i) {
417          case DC_SETVIEW:                /* set the view */
418 <                copystruct(&vparams, &odev.v);
418 >                vparams = odev.v;
419                  if (!sscanview(&vparams, args))
420                          error(COMMAND, "missing view options");
421                  else
# Line 479 | Line 481 | serv_result()                  /* get next server result and process
481                          if (buf == NULL)
482                                  buf = (char *)malloc(bufsiz=msg.nbytes);
483                          else
484 <                                buf = (char *)realloc(buf, bufsiz=msg.nbytes);
484 >                                buf = (char *)realloc((void *)buf,
485 >                                                bufsiz=msg.nbytes);
486                          if (buf == NULL)
487                                  error(SYSTEM, "out of memory in serv_result");
488                  }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines