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

Comparing ray/src/hd/sm_list.c (file contents):
Revision 3.2 by gwlarson, Fri Sep 11 11:52:26 1998 UTC vs.
Revision 3.5 by gwlarson, Tue Jan 5 16:52:38 1999 UTC

# Line 50 | Line 50 | LIST *a,*b;
50   {
51      LIST * l;
52  
53    if(!a)
54      return(b);
55
53      if(!b)
54         return(a);
55      
# Line 65 | Line 62 | LIST *a,*b;
62      return(b);
63   }
64  
65 + /* attaches list a at the end of list b */
66 + LIST
67 + *add_data(l,d,end)
68 + LIST *l;
69 + int d;
70 + LIST **end;
71 +
72 + {
73 +    LIST *list,*lptr;
74 +
75 +    list = new_list();
76 +    SET_LIST_DATA(list,d);
77 +
78 +    if(!l)
79 +    {
80 +      if(end)
81 +        *end = list;
82 +      return(list);
83 +    }
84 +    if(end)
85 +      lptr = *end;
86 +    else
87 +    {
88 +      lptr = l;
89 +      while(LIST_NEXT(lptr))
90 +        lptr = LIST_NEXT(lptr);
91 +    }
92 +    LIST_NEXT(lptr) = list;
93 +    if(end)
94 +      *end = list;
95 +
96 +    return(l);
97 + }
98 +
99   /* Adds data to the end of a circular list. If set, "end"
100   * is a pointer to the last element in the list
101   */
# Line 93 | Line 124 | int d;
124      return(l);
125   }
126  
96 /* Pushes data element d at the top of the list- returns pointer
97   to new top of list
98 */
99 LIST
100 *push_data(l,d)
101 LIST *l;
102 int d;
103 {
104    LIST * list;
105    
106    list = new_list();
107    SET_LIST_DATA(list,d);
108    SET_LIST_NEXT(list,l);
109    return(list);
110 }
127  
128 +
129   /* frees the list */
130   LIST
131   *free_list(l)
# Line 122 | Line 139 | LIST * l;
139      return(NULL);
140   }
141  
142 + /* Pushes data element d at the top of the list- returns pointer
143 +   to new top of list
144 + */
145 + LIST
146 + *push_data(l,d)
147 + LIST *l;
148 + int d;
149 + {
150 +  LIST *list;
151 +
152 +  list = new_list();
153 +  SET_LIST_DATA(list,d);
154 +  SET_LIST_NEXT(list,l);
155 +  return(list);
156 + }
157   /* Returns data element d at the top of the list- returns pointer
158     to new top of list
159   */

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines