| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
 | 
BUGS
----
o Some invalid DXF data gets pass the import checks and breaks the tessing code
o Tesselation via GLU sometimes produces strange results
o Export STL: Exports existing CGAL model even though the current model is changed, but not CGAL rendered
o It's now possible to start a new rendering while one is already running (which call processEvents())
  -> turn off most (or all) interaction while rendering
  -> Lock all or only one MainWindow (MDI)?
o Look into the polygon winding and rotate_extrude() problem reported by Britton
STL Import BUGS
---------------
Using STL-imported models is tricky and triggers multiple issues:
(these all fail with the usual "Illegal polygonal object" error)
1) null-faces causes F6 rendering to fail while F5 rendering succeeds.
   (null-faces are exported by OpenSCAD). Example: adns2610_dev_circuit_inv.stl
   by Andrew Plumb
2) Even very simple imported STL models don't render correctly with F5 when taking 
   a difference(), though F6 looks correct. Example: test_cube.stl by Andrew Plumb
   with this scad file:
   difference() {
     import_stl("test_cube.stl");
     translate([2,2,2]) cylinder(h=10);
   }
3) More complex STL models with something simple unioned or subtracted fails rendering 
   using F6 even though F5 works. Example: adns2610_dev_circuit_inv.stl
   by Andrew Plumb with the three null-faces removed by MeshLab with this scad file:
   union() {
     import_stl("adns2610_dev_circuit_inv_4.stl");
     sphere(r=5);
   }
4) More complex STL models cannot be projected (both F5 and F6).
   Example: adns2610_dev_circuit_inv.stl by Andrew Plumb with the three 
   null-faces removed by MeshLab and this scad file:
   projection(cut=true) {
     import_stl("adns2610_dev_circuit_inv.stl");
   }
CRASH BUGS
----------
o Broken polyhedron() entities are not correctly detected and cause CGAL segfaults
o linear_extrude(50) square([5,0]);
o union() {
    linear_extrude(height=10, twist=90) circle(5);
    translate([7,-5,0]) linear_extrude(height=10, twist=180) polygon(points = [[0,0], [10,0], [5,10]]);
  }
o non-convex minkowski example from chrysn fails with an exception
USER INTERFACE
--------------
o Preferences
  - Remember settings done in menus between sessions (automatic reload, perspective, show*, hide*)
  - Beautify color schemes
  - Color schemes read from file
  - Color scheme editor
  - wireframe width
  - pointsize
  - OpenGL params
  - Default language feature settings
  - Auto-view CSG/thrown together on load
  - Make the library search path configurable?
o Export etc.: automatically add missing extension as in SaveAs
o MDI
  - Think about how to do MDI the right way
  - Ctrl-W should close the current dialog, not the current main window
    -> implement as for Preferences?
  - Menu bar handling:
    Mac: share menubar among all top-level windows?
  - currentPath is global but is used by each document, e.g. parser
    and handle_dep.
o 3D View
  - OpenGL 2.0 test: What, exactly, is needed from OpenGL 2.0? Can we use 1.x with extensions?
  - Improve mouse rotation
  - Add modifier key combos to handle pan and zoom on 1 mouse button systems
  - Show grid
  - Measurement ticks on the axes that look like rulers that one can turn off and on.
  - 4 x split view w/orthogonal cameras?
  - Quick highlighting of object under the cursor in the editor
  - View All
  - Allow specifying viewpoint in the scad file
  - overlay indicator displaying current view mode
  - OpenCSG rendering: Coincident surfaces causes z-buffer fighting. Is this somehow
    avoidable tuning the depth tests in OpenCSG? 
  - Use OpenGL picking to facilitate ray-tracing like features like measuring
    thicknesses, distances, slot thicknesses etc.
o Editor wishlist
  - More infrastructure for external editor (allow communication from the outside)
  - Preferences GUI for the features below
  - line numbers
  - tear-off/maximize options?
  - Save somehow uses current dir, even if the file is already saved earlier
  - Code completion/hints for builtin (and user-defined) functions/modules
  - builtin quick function reference/help
  - Drawer/popup with all modules/functions listed which can be inserted into
    the editor by clicking or drag&drop -> icons in toolbar?
    -> This would be moving in the direction of a traditional CAD GUI
       and needs a fair bit of thinking.
  - Display some kind of line wrap indicator
  - Couple the source code to the AST to allow highlighting selected elements
    in the source code in the 3D view
  - Tabbed editor for designs including other files
  - C-c/C-v should work on the focused widget, not always in the editor
o Error reporting/debugging
  - Provide better error messages when polygon ordering causes CGAL errors:
    o Supply syntax highlighting of the exact polygon indices which are 
      reported to be wrong
    o Provide some interaction for debug walk-through?
  - Provide visual highlighting of geometry corresponding to code
    -> could aid debugging a lot
o Computation
  - Run CGAL rendering in a background thread
  - Enable viewing/editing while rendering
  - Progress: Call progresswidget more often to avoid app hanging for multiple
    seconds (i.e. make cancel button more responsive)
o Misc
  - Reload and compile: Ask for confirmation if file is locally edited
    (make this configurable in preferences?)
  - Save: Ask for confirmation if file has been externally changed
  - Rename OpenCSG and CGAL to smth. not specific to the underlying libraries
    (e.g Preview, Render)
ENGINE
------
o Primitives
  - Springs, spirals (requested by Cathal Garvey)
  - (TTF) Text
  - Image-based height field like http://www.thingiverse.com/thing:2078
  - mesh (coordinates and indices)
o 2D Subsystem
  - Performance: Is it necessary to union children before extrusion
    when compiling? Can this be postponed to CGAL evaluation time?
  - Add inset() operation
o Built-in modules
  - extrude*: Allow the base 2D primitive to have a Z value
  - rotate_extrude(): Allow for specification of start/stop/sweep angle?
  - Convex hull of multiple 2D or 2D objects
o Advanced Transformations
  - Add statement for refinement via surface subdivision
  - Add statement for intersections in cartesian product of childs
o Function-Module-Interface
  - Pass a module instanciation to a function (e.g. for a volume() function)
  - Pass a function to a module instanciation (e.g. for dynamic extrusion paths)
o Language Frontend
  - include statement doesn't support nesting. This can be fixed by
    keeping a nested stack of current input files in the lexer. See
    the "Flex & Bison" O'Reilly book, "Start States and Nested Input
    Files", page 28, for an example.
  - Allow local variables and functions everywhere (not only on module level)
  - allow any expression to be evaluated as boolean (!0 = true, 0 = false)
  - Rethink for vs. intersection_for vs. group. Should for loops
    generate child lists instead, and make these passable to other
    modules or accessible by child()?
  - constants: PI
o DXF Import/Export
  - Use dxflib from RibbonSoft for import/export? -> investigate
  - Import
    - Support for POLYLINE entity
    - Support for SPLINE entity
    - Support for LEADER entity
    - Support for MTEXT entity ?
    - idea: DXF inline - convert from dxf to OpenSCAD syntax -> parametrize dxf content
o Mesh optimization on STL export
  - Remove super small triangles (all sides are short)
  - Replace super thin triangles (one h is short)
o Misc
  - Add symbolic colors to the color() statement
  - When specifying a transparency with the color() statement,
    the object is not sorted and will be rendered wrongly
  - Go through default values of parameters (e.g. cube() has x,y,z=1 while linear_extrude() has height=100)
  - Add support for symbolic names to child() statement 
  - Add 'lines' object type for non-solid 2d drawings
  - Is there a reason why modules like echo, empty if, empty for loop returns an
    empty AbstractNode instead of being ignored?
  - Bug: Using the background operator (%) on the only object in a scene triggers a
    CSG error: No top level object found
o Grammar
  - dim->name -> dim->label
  - A random(seed) function
  - import_*() -> *_import() (consistent prefix vs. postfix)
  - linear_extrude()/rotate_extrude(): Cumbersome names? -> (extrude, revolve, lathe, sweep ?) 
IDEAS FOR LANGUAGE CHANGES
--------------------------
o More strict checking of module parameters to make e.g. this fail:
  module test(a,b) { a=1; b=2; echo(a,b,c); } test(c=3);
CODE
----
o Refactor from MainWindow:
  - Put all application-global data in one place (QApplication subtype?)
  - Fix current_win hack
  - CSG data structure (compiled model)
  - CGAL data structure (compiled model)
o C++-ify
  - Use smart pointers where it makes sense (e.g. instead of homegrown refcount,
    and to get memory ownership under control)
  - Use static_cast/dynamic_cast instead of C-style casts
o dxflinextrude and dxfrotextrude could share code
o Consider decoupling DXF-specific functionality from the 2D subsystem
o Visitation refactoring
  - Make AbstractNode members private/protected?
BUILD SYSTEM
------------
o Fedora is reported to ship with byacc, which doesn't support bison extensions (e.g. %debuig). Look into this, either be yacc-compatible or force the build system to use bison.
o We currently link in -lboost_thread. Should we always use -lboost_thread-mt under Linux or can we pick this up using qmake?
TESTING
-------
o Caching and MDI looks suspicious when the code relies on external resources
  which might be loaded from difference locations in different documents
  -> we might get a false cache hit
o Are contructs like "child(0)" cached? Could this give false cache hits?
o Write some cmd-line apps that dump an openscad file to misc. formats
  (dump, stl, dxf)
o Write a simple test script that collects verified and current STL renderings
  and displays them side-by-side or smth.
o Write simple driver scripts for comparing output of above command
o Collect "all" available OpenSCAD scripts from the internets and run the integration
  tests on them all
INFRASTRUCTURE
--------------
o Use a logging framework to get debugging/info output more under control?
  (check log4j, google project)
MISC
----
o Streamline the cmd-line interface a bit
  - Implicit output file format
o Write checklists for typical extension work (add new module, add new function)
  -> make sure new test files are added
 |