diff --git a/Parser/Gmsh.tab.cpp b/Parser/Gmsh.tab.cpp
index 5f2cb8bc3e77011cf049f9052b5b996a7df43424..e5885785b9393550a0422acda0ef5a2f3d707350 100644
--- a/Parser/Gmsh.tab.cpp
+++ b/Parser/Gmsh.tab.cpp
@@ -121,7 +121,7 @@
 
 #line 1 "Gmsh.y"
 
-// $Id: Gmsh.tab.cpp,v 1.304 2007-02-12 08:36:11 geuzaine Exp $
+// $Id: Gmsh.tab.cpp,v 1.305 2007-02-13 07:51:47 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
@@ -516,27 +516,27 @@ static const short yyrline[] = { 0,
   1436,  1474,  1496,  1512,  1532,  1549,  1566,  1586,  1592,  1597,
   1602,  1609,  1611,  1612,  1615,  1620,  1624,  1640,  1656,  1672,
   1692,  1707,  1713,  1719,  1730,  1740,  1750,  1766,  1784,  1798,
-  1805,  1811,  1820,  1833,  1879,  1894,  1905,  1925,  1935,  1957,
-  1961,  1966,  1971,  1981,  1998,  2014,  2040,  2067,  2099,  2106,
-  2111,  2117,  2121,  2129,  2138,  2146,  2154,  2159,  2167,  2172,
-  2180,  2185,  2195,  2202,  2209,  2216,  2223,  2230,  2237,  2244,
-  2251,  2258,  2263,  2270,  2275,  2282,  2287,  2294,  2299,  2306,
-  2311,  2318,  2323,  2330,  2335,  2342,  2347,  2354,  2359,  2369,
-  2373,  2378,  2388,  2410,  2434,  2442,  2461,  2479,  2497,  2526,
-  2561,  2566,  2593,  2607,  2625,  2632,  2638,  2641,  2649,  2659,
-  2661,  2662,  2663,  2664,  2665,  2666,  2667,  2668,  2675,  2676,
-  2677,  2678,  2679,  2680,  2681,  2682,  2683,  2684,  2685,  2686,
-  2687,  2688,  2689,  2690,  2691,  2692,  2693,  2694,  2695,  2696,
-  2697,  2698,  2699,  2700,  2701,  2702,  2703,  2704,  2705,  2706,
-  2708,  2709,  2710,  2711,  2712,  2713,  2714,  2715,  2716,  2717,
-  2718,  2719,  2720,  2721,  2722,  2723,  2724,  2725,  2726,  2727,
-  2728,  2733,  2738,  2739,  2740,  2741,  2742,  2743,  2747,  2763,
-  2778,  2798,  2812,  2825,  2848,  2866,  2884,  2902,  2920,  2927,
-  2932,  2936,  2940,  2944,  2950,  2955,  2959,  2963,  2969,  2975,
-  2982,  2988,  2992,  2997,  3001,  3012,  3019,  3030,  3050,  3060,
-  3070,  3080,  3097,  3116,  3140,  3168,  3174,  3178,  3182,  3194,
-  3199,  3211,  3218,  3239,  3244,  3258,  3264,  3270,  3275,  3283,
-  3291,  3305,  3319,  3323,  3342,  3364
+  1805,  1811,  1820,  1833,  1884,  1899,  1910,  1930,  1940,  1962,
+  1966,  1971,  1976,  1986,  2003,  2019,  2045,  2072,  2104,  2111,
+  2116,  2122,  2126,  2134,  2143,  2151,  2159,  2164,  2172,  2177,
+  2185,  2190,  2200,  2207,  2214,  2221,  2228,  2235,  2242,  2249,
+  2256,  2263,  2268,  2275,  2280,  2287,  2292,  2299,  2304,  2311,
+  2316,  2323,  2328,  2335,  2340,  2347,  2352,  2359,  2364,  2374,
+  2378,  2383,  2393,  2415,  2439,  2447,  2466,  2484,  2502,  2531,
+  2566,  2571,  2598,  2612,  2630,  2637,  2643,  2646,  2654,  2664,
+  2666,  2667,  2668,  2669,  2670,  2671,  2672,  2673,  2680,  2681,
+  2682,  2683,  2684,  2685,  2686,  2687,  2688,  2689,  2690,  2691,
+  2692,  2693,  2694,  2695,  2696,  2697,  2698,  2699,  2700,  2701,
+  2702,  2703,  2704,  2705,  2706,  2707,  2708,  2709,  2710,  2711,
+  2713,  2714,  2715,  2716,  2717,  2718,  2719,  2720,  2721,  2722,
+  2723,  2724,  2725,  2726,  2727,  2728,  2729,  2730,  2731,  2732,
+  2733,  2738,  2743,  2744,  2745,  2746,  2747,  2748,  2752,  2768,
+  2783,  2803,  2817,  2830,  2853,  2871,  2889,  2907,  2925,  2932,
+  2937,  2941,  2945,  2949,  2955,  2960,  2964,  2968,  2974,  2980,
+  2987,  2993,  2997,  3002,  3006,  3017,  3024,  3035,  3055,  3065,
+  3075,  3085,  3102,  3121,  3145,  3173,  3179,  3183,  3187,  3199,
+  3204,  3216,  3223,  3244,  3249,  3263,  3269,  3275,  3280,  3288,
+  3296,  3310,  3324,  3328,  3347,  3369
 };
 #endif
 
@@ -4489,6 +4489,10 @@ case 134:
       }
       else if(!strcmp(yyvsp[-2].c, "Print")){
 #if defined(HAVE_FLTK)
+	// make sure we have the latest data from THEM in GModel
+	// (fixes bug where we would have no geometry in the picture if
+	// the print command is in the same file as the geometry)
+	GMODEL->importTHEM();
 	char tmpstring[1024];
 	FixRelativePath(yyvsp[-1].c, tmpstring);
 	CreateOutputFile(tmpstring, CTX.print.format);
@@ -4496,6 +4500,7 @@ case 134:
       }
       else if(!strcmp(yyvsp[-2].c, "Save")){
 #if defined(HAVE_FLTK)
+	GMODEL->importTHEM();
 	char tmpstring[1024];
 	FixRelativePath(yyvsp[-1].c, tmpstring);
 	CreateOutputFile(tmpstring, CTX.mesh.format);
@@ -4517,7 +4522,7 @@ case 134:
     ;
     break;}
 case 135:
-#line 1880 "Gmsh.y"
+#line 1885 "Gmsh.y"
 {
       if(!strcmp(yyvsp[-6].c, "Save") && !strcmp(yyvsp[-5].c, "View")){
 	Post_View **vv = (Post_View **)List_Pointer_Test(CTX.post.list, (int)yyvsp[-3].d);
@@ -4534,7 +4539,7 @@ case 135:
     ;
     break;}
 case 136:
-#line 1895 "Gmsh.y"
+#line 1900 "Gmsh.y"
 {
       if(!strcmp(yyvsp[-6].c, "Background") && !strcmp(yyvsp[-5].c, "Mesh")  && !strcmp(yyvsp[-4].c, "View")){
 	Post_View **vv = (Post_View **)List_Pointer_Test(CTX.post.list, (int)yyvsp[-2].d);
@@ -4547,7 +4552,7 @@ case 136:
     ;
     break;}
 case 137:
-#line 1906 "Gmsh.y"
+#line 1911 "Gmsh.y"
 {
       if(!strcmp(yyvsp[-2].c, "Sleep")){
 	SleepInSeconds(yyvsp[-1].d);
@@ -4569,7 +4574,7 @@ case 137:
     ;
     break;}
 case 138:
-#line 1926 "Gmsh.y"
+#line 1931 "Gmsh.y"
 {
        try {
 	 GMSH_PluginManager::instance()->action(yyvsp[-4].c, yyvsp[-1].c, 0);
@@ -4581,7 +4586,7 @@ case 138:
      ;
     break;}
 case 139:
-#line 1936 "Gmsh.y"
+#line 1941 "Gmsh.y"
 {
       if(!strcmp(yyvsp[-1].c, "ElementsFromAllViews"))
 	CombineViews(0, 1, CTX.post.combine_remove_orig);
@@ -4605,27 +4610,27 @@ case 139:
     ;
     break;}
 case 140:
-#line 1958 "Gmsh.y"
+#line 1963 "Gmsh.y"
 {
       exit(0);
     ;
     break;}
 case 141:
-#line 1962 "Gmsh.y"
+#line 1967 "Gmsh.y"
 {
       CTX.forced_bbox = 0;
       SetBoundingBox();
     ;
     break;}
 case 142:
-#line 1967 "Gmsh.y"
+#line 1972 "Gmsh.y"
 {
       CTX.forced_bbox = 1;
       SetBoundingBox(yyvsp[-12].d, yyvsp[-10].d, yyvsp[-8].d, yyvsp[-6].d, yyvsp[-4].d, yyvsp[-2].d);
     ;
     break;}
 case 143:
-#line 1972 "Gmsh.y"
+#line 1977 "Gmsh.y"
 {
 #if defined(HAVE_FLTK)
       Draw();
@@ -4633,7 +4638,7 @@ case 143:
     ;
     break;}
 case 144:
-#line 1984 "Gmsh.y"
+#line 1989 "Gmsh.y"
 {
       LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d;
       LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d;
@@ -4650,7 +4655,7 @@ case 144:
     ;
     break;}
 case 145:
-#line 1999 "Gmsh.y"
+#line 2004 "Gmsh.y"
 {
       LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d;
       LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d;
@@ -4668,7 +4673,7 @@ case 145:
     ;
     break;}
 case 146:
-#line 2015 "Gmsh.y"
+#line 2020 "Gmsh.y"
 {
       LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d;
       LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d;
@@ -4696,7 +4701,7 @@ case 146:
     ;
     break;}
 case 147:
-#line 2041 "Gmsh.y"
+#line 2046 "Gmsh.y"
 {
       LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d;
       LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d;
@@ -4725,7 +4730,7 @@ case 147:
     ;
     break;}
 case 148:
-#line 2068 "Gmsh.y"
+#line 2073 "Gmsh.y"
 {
       if(ImbricatedLoop <= 0){
 	yymsg(GERROR, "Invalid For/EndFor loop");
@@ -4759,7 +4764,7 @@ case 148:
     ;
     break;}
 case 149:
-#line 2100 "Gmsh.y"
+#line 2105 "Gmsh.y"
 {
       if(!FunctionManager::Instance()->createFunction(yyvsp[0].c, yyin, yyname, yylineno))
 	yymsg(GERROR, "Redefinition of function %s", yyvsp[0].c);
@@ -4768,14 +4773,14 @@ case 149:
     ;
     break;}
 case 150:
-#line 2107 "Gmsh.y"
+#line 2112 "Gmsh.y"
 {
       if(!FunctionManager::Instance()->leaveFunction(&yyin, yyname, yylineno))
 	yymsg(GERROR, "Error while exiting function");
     ;
     break;}
 case 151:
-#line 2112 "Gmsh.y"
+#line 2117 "Gmsh.y"
 {
       if(!FunctionManager::Instance()->enterFunction(yyvsp[-1].c, &yyin, yyname, yylineno))
 	yymsg(GERROR, "Unknown function %s", yyvsp[-1].c);
@@ -4783,18 +4788,18 @@ case 151:
     ;
     break;}
 case 152:
-#line 2118 "Gmsh.y"
+#line 2123 "Gmsh.y"
 {
       if(!yyvsp[-1].d) skip_until("If", "EndIf");
     ;
     break;}
 case 153:
-#line 2122 "Gmsh.y"
+#line 2127 "Gmsh.y"
 {
     ;
     break;}
 case 154:
-#line 2131 "Gmsh.y"
+#line 2136 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(TRANSLATE, yyvsp[-1].l, 
@@ -4804,7 +4809,7 @@ case 154:
     ;
     break;}
 case 155:
-#line 2139 "Gmsh.y"
+#line 2144 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(ROTATE, yyvsp[-1].l, 
@@ -4814,7 +4819,7 @@ case 155:
     ;
     break;}
 case 156:
-#line 2147 "Gmsh.y"
+#line 2152 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(TRANSLATE_ROTATE, yyvsp[-1].l, 
@@ -4824,14 +4829,14 @@ case 156:
     ;
     break;}
 case 157:
-#line 2155 "Gmsh.y"
+#line 2160 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 158:
-#line 2160 "Gmsh.y"
+#line 2165 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(TRANSLATE, yyvsp[-3].l, 
@@ -4841,14 +4846,14 @@ case 158:
     ;
     break;}
 case 159:
-#line 2168 "Gmsh.y"
+#line 2173 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 160:
-#line 2173 "Gmsh.y"
+#line 2178 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(ROTATE, yyvsp[-3].l, 
@@ -4858,14 +4863,14 @@ case 160:
     ;
     break;}
 case 161:
-#line 2181 "Gmsh.y"
+#line 2186 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 162:
-#line 2186 "Gmsh.y"
+#line 2191 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShapes(TRANSLATE_ROTATE, yyvsp[-3].l, 
@@ -4875,7 +4880,7 @@ case 162:
     ;
     break;}
 case 163:
-#line 2196 "Gmsh.y"
+#line 2201 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_POINT, (int)yyvsp[-4].d, 
@@ -4884,7 +4889,7 @@ case 163:
     ;
     break;}
 case 164:
-#line 2203 "Gmsh.y"
+#line 2208 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_SEGM_LINE, (int)yyvsp[-4].d, 
@@ -4893,7 +4898,7 @@ case 164:
     ;
     break;}
 case 165:
-#line 2210 "Gmsh.y"
+#line 2215 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_SURF_PLAN, (int)yyvsp[-4].d, 
@@ -4902,7 +4907,7 @@ case 165:
     ;
     break;}
 case 166:
-#line 2217 "Gmsh.y"
+#line 2222 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_POINT, (int)yyvsp[-8].d, 
@@ -4911,7 +4916,7 @@ case 166:
     ;
     break;}
 case 167:
-#line 2224 "Gmsh.y"
+#line 2229 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_SEGM_LINE, (int)yyvsp[-8].d, 
@@ -4920,7 +4925,7 @@ case 167:
     ;
     break;}
 case 168:
-#line 2231 "Gmsh.y"
+#line 2236 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_SURF_PLAN, (int)yyvsp[-8].d, 
@@ -4929,7 +4934,7 @@ case 168:
     ;
     break;}
 case 169:
-#line 2238 "Gmsh.y"
+#line 2243 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_POINT, (int)yyvsp[-10].d, 
@@ -4938,7 +4943,7 @@ case 169:
     ;
     break;}
 case 170:
-#line 2245 "Gmsh.y"
+#line 2250 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_SEGM_LINE, (int)yyvsp[-10].d, 
@@ -4947,7 +4952,7 @@ case 170:
     ;
     break;}
 case 171:
-#line 2252 "Gmsh.y"
+#line 2257 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_SURF_PLAN, (int)yyvsp[-10].d, 
@@ -4956,14 +4961,14 @@ case 171:
     ;
     break;}
 case 172:
-#line 2259 "Gmsh.y"
+#line 2264 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 173:
-#line 2264 "Gmsh.y"
+#line 2269 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_POINT, (int)yyvsp[-8].d, 
@@ -4972,14 +4977,14 @@ case 173:
     ;
     break;}
 case 174:
-#line 2271 "Gmsh.y"
+#line 2276 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 175:
-#line 2276 "Gmsh.y"
+#line 2281 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_SEGM_LINE, (int)yyvsp[-8].d, 
@@ -4988,14 +4993,14 @@ case 175:
     ;
     break;}
 case 176:
-#line 2283 "Gmsh.y"
+#line 2288 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 177:
-#line 2288 "Gmsh.y"
+#line 2293 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE, MSH_SURF_PLAN, (int)yyvsp[-8].d, 
@@ -5004,14 +5009,14 @@ case 177:
     ;
     break;}
 case 178:
-#line 2295 "Gmsh.y"
+#line 2300 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 179:
-#line 2300 "Gmsh.y"
+#line 2305 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_POINT, (int)yyvsp[-12].d, 
@@ -5020,14 +5025,14 @@ case 179:
     ;
     break;}
 case 180:
-#line 2307 "Gmsh.y"
+#line 2312 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 181:
-#line 2312 "Gmsh.y"
+#line 2317 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_SEGM_LINE, (int)yyvsp[-12].d, 
@@ -5036,14 +5041,14 @@ case 181:
     ;
     break;}
 case 182:
-#line 2319 "Gmsh.y"
+#line 2324 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 183:
-#line 2324 "Gmsh.y"
+#line 2329 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(ROTATE, MSH_SURF_PLAN, (int)yyvsp[-12].d, 
@@ -5052,14 +5057,14 @@ case 183:
     ;
     break;}
 case 184:
-#line 2331 "Gmsh.y"
+#line 2336 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 185:
-#line 2336 "Gmsh.y"
+#line 2341 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_POINT, (int)yyvsp[-14].d, 
@@ -5068,14 +5073,14 @@ case 185:
     ;
     break;}
 case 186:
-#line 2343 "Gmsh.y"
+#line 2348 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 187:
-#line 2348 "Gmsh.y"
+#line 2353 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_SEGM_LINE, (int)yyvsp[-14].d, 
@@ -5084,14 +5089,14 @@ case 187:
     ;
     break;}
 case 188:
-#line 2355 "Gmsh.y"
+#line 2360 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = false;
       extr.mesh.Recombine = false;
     ;
     break;}
 case 189:
-#line 2360 "Gmsh.y"
+#line 2365 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(Shape));
       ExtrudeShape(TRANSLATE_ROTATE, MSH_SURF_PLAN, (int)yyvsp[-14].d, 
@@ -5100,17 +5105,17 @@ case 189:
     ;
     break;}
 case 190:
-#line 2371 "Gmsh.y"
+#line 2376 "Gmsh.y"
 {
     ;
     break;}
 case 191:
-#line 2374 "Gmsh.y"
+#line 2379 "Gmsh.y"
 {
     ;
     break;}
 case 192:
-#line 2380 "Gmsh.y"
+#line 2385 "Gmsh.y"
 {
       extr.mesh.ExtrudeMesh = true;
       extr.mesh.NbLayer = 1;
@@ -5121,7 +5126,7 @@ case 192:
     ;
     break;}
 case 193:
-#line 2389 "Gmsh.y"
+#line 2394 "Gmsh.y"
 {
       double d;
       extr.mesh.ExtrudeMesh = true;
@@ -5145,7 +5150,7 @@ case 193:
     ;
     break;}
 case 194:
-#line 2411 "Gmsh.y"
+#line 2416 "Gmsh.y"
 {
       yymsg(WARNING, "Explicit region numbers in layers are deprecated");
       double d;
@@ -5171,13 +5176,13 @@ case 194:
     ;
     break;}
 case 195:
-#line 2435 "Gmsh.y"
+#line 2440 "Gmsh.y"
 {
       extr.mesh.Recombine = true;
     ;
     break;}
 case 196:
-#line 2444 "Gmsh.y"
+#line 2449 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[-3].l); i++){
 	double d;
@@ -5197,7 +5202,7 @@ case 196:
     ;
     break;}
 case 197:
-#line 2462 "Gmsh.y"
+#line 2467 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[-6].l); i++){
 	double d;
@@ -5217,7 +5222,7 @@ case 197:
     ;
     break;}
 case 198:
-#line 2480 "Gmsh.y"
+#line 2485 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[-6].l); i++){
 	double d;
@@ -5237,7 +5242,7 @@ case 198:
     ;
     break;}
 case 199:
-#line 2498 "Gmsh.y"
+#line 2503 "Gmsh.y"
 {
       Surface *s = FindSurface((int)yyvsp[-4].d);
       if(!s)
@@ -5268,7 +5273,7 @@ case 199:
     ;
     break;}
 case 200:
-#line 2527 "Gmsh.y"
+#line 2532 "Gmsh.y"
 {
       Surface *s = FindSurface((int)yyvsp[-5].d);
       if(!s)
@@ -5305,14 +5310,14 @@ case 200:
     ;
     break;}
 case 201:
-#line 2562 "Gmsh.y"
+#line 2567 "Gmsh.y"
 {
       yymsg(WARNING, "Elliptic Surface is deprecated: use Transfinite instead (with smoothing)");
       List_Delete(yyvsp[-1].l);
     ;
     break;}
 case 202:
-#line 2567 "Gmsh.y"
+#line 2572 "Gmsh.y"
 {
       Volume *v = FindVolume((int)yyvsp[-4].d);
       if(!v)
@@ -5341,7 +5346,7 @@ case 202:
     ;
     break;}
 case 203:
-#line 2594 "Gmsh.y"
+#line 2599 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[-3].l); i++){
 	double d;
@@ -5357,7 +5362,7 @@ case 203:
     ;
     break;}
 case 204:
-#line 2608 "Gmsh.y"
+#line 2613 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[-1].l); i++){
 	double d;
@@ -5372,7 +5377,7 @@ case 204:
     ;
     break;}
 case 205:
-#line 2627 "Gmsh.y"
+#line 2632 "Gmsh.y"
 { 
       Surface *s = FindSurface((int)yyvsp[-2].d);
       if(s)
@@ -5380,7 +5385,7 @@ case 205:
     ;
     break;}
 case 206:
-#line 2633 "Gmsh.y"
+#line 2638 "Gmsh.y"
 {
       Surface *s = FindSurface((int)yyvsp[-2].d);
       if(s)
@@ -5388,55 +5393,55 @@ case 206:
     ;
     break;}
 case 207:
-#line 2639 "Gmsh.y"
+#line 2644 "Gmsh.y"
 {
     ;
     break;}
 case 208:
-#line 2642 "Gmsh.y"
+#line 2647 "Gmsh.y"
 {
     ;
     break;}
 case 209:
-#line 2651 "Gmsh.y"
+#line 2656 "Gmsh.y"
 { 
       ReplaceAllDuplicates();
     ;
     break;}
 case 210:
-#line 2660 "Gmsh.y"
+#line 2665 "Gmsh.y"
 { yyval.d = yyvsp[0].d;           ;
     break;}
 case 211:
-#line 2661 "Gmsh.y"
+#line 2666 "Gmsh.y"
 { yyval.d = yyvsp[-1].d;           ;
     break;}
 case 212:
-#line 2662 "Gmsh.y"
+#line 2667 "Gmsh.y"
 { yyval.d = -yyvsp[0].d;          ;
     break;}
 case 213:
-#line 2663 "Gmsh.y"
+#line 2668 "Gmsh.y"
 { yyval.d = yyvsp[0].d;           ;
     break;}
 case 214:
-#line 2664 "Gmsh.y"
+#line 2669 "Gmsh.y"
 { yyval.d = !yyvsp[0].d;          ;
     break;}
 case 215:
-#line 2665 "Gmsh.y"
+#line 2670 "Gmsh.y"
 { yyval.d = yyvsp[-2].d - yyvsp[0].d;      ;
     break;}
 case 216:
-#line 2666 "Gmsh.y"
+#line 2671 "Gmsh.y"
 { yyval.d = yyvsp[-2].d + yyvsp[0].d;      ;
     break;}
 case 217:
-#line 2667 "Gmsh.y"
+#line 2672 "Gmsh.y"
 { yyval.d = yyvsp[-2].d * yyvsp[0].d;      ;
     break;}
 case 218:
-#line 2669 "Gmsh.y"
+#line 2674 "Gmsh.y"
 { 
       if(!yyvsp[0].d)
 	yymsg(GERROR, "Division by zero in '%g / %g'", yyvsp[-2].d, yyvsp[0].d);
@@ -5445,247 +5450,247 @@ case 218:
     ;
     break;}
 case 219:
-#line 2675 "Gmsh.y"
+#line 2680 "Gmsh.y"
 { yyval.d = (int)yyvsp[-2].d % (int)yyvsp[0].d;  ;
     break;}
 case 220:
-#line 2676 "Gmsh.y"
+#line 2681 "Gmsh.y"
 { yyval.d = pow(yyvsp[-2].d, yyvsp[0].d);  ;
     break;}
 case 221:
-#line 2677 "Gmsh.y"
+#line 2682 "Gmsh.y"
 { yyval.d = yyvsp[-2].d < yyvsp[0].d;      ;
     break;}
 case 222:
-#line 2678 "Gmsh.y"
+#line 2683 "Gmsh.y"
 { yyval.d = yyvsp[-2].d > yyvsp[0].d;      ;
     break;}
 case 223:
-#line 2679 "Gmsh.y"
+#line 2684 "Gmsh.y"
 { yyval.d = yyvsp[-2].d <= yyvsp[0].d;     ;
     break;}
 case 224:
-#line 2680 "Gmsh.y"
+#line 2685 "Gmsh.y"
 { yyval.d = yyvsp[-2].d >= yyvsp[0].d;     ;
     break;}
 case 225:
-#line 2681 "Gmsh.y"
+#line 2686 "Gmsh.y"
 { yyval.d = yyvsp[-2].d == yyvsp[0].d;     ;
     break;}
 case 226:
-#line 2682 "Gmsh.y"
+#line 2687 "Gmsh.y"
 { yyval.d = yyvsp[-2].d != yyvsp[0].d;     ;
     break;}
 case 227:
-#line 2683 "Gmsh.y"
+#line 2688 "Gmsh.y"
 { yyval.d = yyvsp[-2].d && yyvsp[0].d;     ;
     break;}
 case 228:
-#line 2684 "Gmsh.y"
+#line 2689 "Gmsh.y"
 { yyval.d = yyvsp[-2].d || yyvsp[0].d;     ;
     break;}
 case 229:
-#line 2685 "Gmsh.y"
+#line 2690 "Gmsh.y"
 { yyval.d = yyvsp[-4].d? yyvsp[-2].d : yyvsp[0].d;  ;
     break;}
 case 230:
-#line 2686 "Gmsh.y"
+#line 2691 "Gmsh.y"
 { yyval.d = exp(yyvsp[-1].d);      ;
     break;}
 case 231:
-#line 2687 "Gmsh.y"
+#line 2692 "Gmsh.y"
 { yyval.d = log(yyvsp[-1].d);      ;
     break;}
 case 232:
-#line 2688 "Gmsh.y"
+#line 2693 "Gmsh.y"
 { yyval.d = log10(yyvsp[-1].d);    ;
     break;}
 case 233:
-#line 2689 "Gmsh.y"
+#line 2694 "Gmsh.y"
 { yyval.d = sqrt(yyvsp[-1].d);     ;
     break;}
 case 234:
-#line 2690 "Gmsh.y"
+#line 2695 "Gmsh.y"
 { yyval.d = sin(yyvsp[-1].d);      ;
     break;}
 case 235:
-#line 2691 "Gmsh.y"
+#line 2696 "Gmsh.y"
 { yyval.d = asin(yyvsp[-1].d);     ;
     break;}
 case 236:
-#line 2692 "Gmsh.y"
+#line 2697 "Gmsh.y"
 { yyval.d = cos(yyvsp[-1].d);      ;
     break;}
 case 237:
-#line 2693 "Gmsh.y"
+#line 2698 "Gmsh.y"
 { yyval.d = acos(yyvsp[-1].d);     ;
     break;}
 case 238:
-#line 2694 "Gmsh.y"
+#line 2699 "Gmsh.y"
 { yyval.d = tan(yyvsp[-1].d);      ;
     break;}
 case 239:
-#line 2695 "Gmsh.y"
+#line 2700 "Gmsh.y"
 { yyval.d = atan(yyvsp[-1].d);     ;
     break;}
 case 240:
-#line 2696 "Gmsh.y"
+#line 2701 "Gmsh.y"
 { yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d);;
     break;}
 case 241:
-#line 2697 "Gmsh.y"
+#line 2702 "Gmsh.y"
 { yyval.d = sinh(yyvsp[-1].d);     ;
     break;}
 case 242:
-#line 2698 "Gmsh.y"
+#line 2703 "Gmsh.y"
 { yyval.d = cosh(yyvsp[-1].d);     ;
     break;}
 case 243:
-#line 2699 "Gmsh.y"
+#line 2704 "Gmsh.y"
 { yyval.d = tanh(yyvsp[-1].d);     ;
     break;}
 case 244:
-#line 2700 "Gmsh.y"
+#line 2705 "Gmsh.y"
 { yyval.d = fabs(yyvsp[-1].d);     ;
     break;}
 case 245:
-#line 2701 "Gmsh.y"
+#line 2706 "Gmsh.y"
 { yyval.d = floor(yyvsp[-1].d);    ;
     break;}
 case 246:
-#line 2702 "Gmsh.y"
+#line 2707 "Gmsh.y"
 { yyval.d = ceil(yyvsp[-1].d);     ;
     break;}
 case 247:
-#line 2703 "Gmsh.y"
+#line 2708 "Gmsh.y"
 { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ;
     break;}
 case 248:
-#line 2704 "Gmsh.y"
+#line 2709 "Gmsh.y"
 { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ;
     break;}
 case 249:
-#line 2705 "Gmsh.y"
+#line 2710 "Gmsh.y"
 { yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ;
     break;}
 case 250:
-#line 2706 "Gmsh.y"
+#line 2711 "Gmsh.y"
 { yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ;
     break;}
 case 251:
-#line 2708 "Gmsh.y"
+#line 2713 "Gmsh.y"
 { yyval.d = exp(yyvsp[-1].d);      ;
     break;}
 case 252:
-#line 2709 "Gmsh.y"
+#line 2714 "Gmsh.y"
 { yyval.d = log(yyvsp[-1].d);      ;
     break;}
 case 253:
-#line 2710 "Gmsh.y"
+#line 2715 "Gmsh.y"
 { yyval.d = log10(yyvsp[-1].d);    ;
     break;}
 case 254:
-#line 2711 "Gmsh.y"
+#line 2716 "Gmsh.y"
 { yyval.d = sqrt(yyvsp[-1].d);     ;
     break;}
 case 255:
-#line 2712 "Gmsh.y"
+#line 2717 "Gmsh.y"
 { yyval.d = sin(yyvsp[-1].d);      ;
     break;}
 case 256:
-#line 2713 "Gmsh.y"
+#line 2718 "Gmsh.y"
 { yyval.d = asin(yyvsp[-1].d);     ;
     break;}
 case 257:
-#line 2714 "Gmsh.y"
+#line 2719 "Gmsh.y"
 { yyval.d = cos(yyvsp[-1].d);      ;
     break;}
 case 258:
-#line 2715 "Gmsh.y"
+#line 2720 "Gmsh.y"
 { yyval.d = acos(yyvsp[-1].d);     ;
     break;}
 case 259:
-#line 2716 "Gmsh.y"
+#line 2721 "Gmsh.y"
 { yyval.d = tan(yyvsp[-1].d);      ;
     break;}
 case 260:
-#line 2717 "Gmsh.y"
+#line 2722 "Gmsh.y"
 { yyval.d = atan(yyvsp[-1].d);     ;
     break;}
 case 261:
-#line 2718 "Gmsh.y"
+#line 2723 "Gmsh.y"
 { yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d);;
     break;}
 case 262:
-#line 2719 "Gmsh.y"
+#line 2724 "Gmsh.y"
 { yyval.d = sinh(yyvsp[-1].d);     ;
     break;}
 case 263:
-#line 2720 "Gmsh.y"
+#line 2725 "Gmsh.y"
 { yyval.d = cosh(yyvsp[-1].d);     ;
     break;}
 case 264:
-#line 2721 "Gmsh.y"
+#line 2726 "Gmsh.y"
 { yyval.d = tanh(yyvsp[-1].d);     ;
     break;}
 case 265:
-#line 2722 "Gmsh.y"
+#line 2727 "Gmsh.y"
 { yyval.d = fabs(yyvsp[-1].d);     ;
     break;}
 case 266:
-#line 2723 "Gmsh.y"
+#line 2728 "Gmsh.y"
 { yyval.d = floor(yyvsp[-1].d);    ;
     break;}
 case 267:
-#line 2724 "Gmsh.y"
+#line 2729 "Gmsh.y"
 { yyval.d = ceil(yyvsp[-1].d);     ;
     break;}
 case 268:
-#line 2725 "Gmsh.y"
+#line 2730 "Gmsh.y"
 { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ;
     break;}
 case 269:
-#line 2726 "Gmsh.y"
+#line 2731 "Gmsh.y"
 { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ;
     break;}
 case 270:
-#line 2727 "Gmsh.y"
+#line 2732 "Gmsh.y"
 { yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ;
     break;}
 case 271:
-#line 2728 "Gmsh.y"
+#line 2733 "Gmsh.y"
 { yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ;
     break;}
 case 272:
-#line 2737 "Gmsh.y"
+#line 2742 "Gmsh.y"
 { yyval.d = yyvsp[0].d; ;
     break;}
 case 273:
-#line 2738 "Gmsh.y"
+#line 2743 "Gmsh.y"
 { yyval.d = 3.141592653589793; ;
     break;}
 case 274:
-#line 2739 "Gmsh.y"
+#line 2744 "Gmsh.y"
 { yyval.d = ParUtil::Instance()->rank(); ;
     break;}
 case 275:
-#line 2740 "Gmsh.y"
+#line 2745 "Gmsh.y"
 { yyval.d = ParUtil::Instance()->size(); ;
     break;}
 case 276:
-#line 2741 "Gmsh.y"
+#line 2746 "Gmsh.y"
 { yyval.d = Get_GmshMajorVersion(); ;
     break;}
 case 277:
-#line 2742 "Gmsh.y"
+#line 2747 "Gmsh.y"
 { yyval.d = Get_GmshMinorVersion(); ;
     break;}
 case 278:
-#line 2743 "Gmsh.y"
+#line 2748 "Gmsh.y"
 { yyval.d = Get_GmshPatchVersion(); ;
     break;}
 case 279:
-#line 2748 "Gmsh.y"
+#line 2753 "Gmsh.y"
 {
       Symbol TheSymbol;
       TheSymbol.Name = yyvsp[0].c;
@@ -5700,7 +5705,7 @@ case 279:
     ;
     break;}
 case 280:
-#line 2764 "Gmsh.y"
+#line 2769 "Gmsh.y"
 {
       char tmpstring[1024];
       sprintf(tmpstring, "%s_%d", yyvsp[-4].c, (int)yyvsp[-1].d) ;
@@ -5717,7 +5722,7 @@ case 280:
     ;
     break;}
 case 281:
-#line 2779 "Gmsh.y"
+#line 2784 "Gmsh.y"
 {
       Symbol TheSymbol;
       TheSymbol.Name = yyvsp[-3].c;
@@ -5739,7 +5744,7 @@ case 281:
     ;
     break;}
 case 282:
-#line 2799 "Gmsh.y"
+#line 2804 "Gmsh.y"
 {
       Symbol TheSymbol;
       TheSymbol.Name = yyvsp[-2].c;
@@ -5755,7 +5760,7 @@ case 282:
     ;
     break;}
 case 283:
-#line 2813 "Gmsh.y"
+#line 2818 "Gmsh.y"
 {
       Symbol TheSymbol;
       TheSymbol.Name = yyvsp[-1].c;
@@ -5770,7 +5775,7 @@ case 283:
     ;
     break;}
 case 284:
-#line 2826 "Gmsh.y"
+#line 2831 "Gmsh.y"
 {
       Symbol TheSymbol;
       TheSymbol.Name = yyvsp[-4].c;
@@ -5792,7 +5797,7 @@ case 284:
     ;
     break;}
 case 285:
-#line 2849 "Gmsh.y"
+#line 2854 "Gmsh.y"
 {
       double (*pNumOpt)(int num, int action, double value);
       StringXNumber *pNumCat;
@@ -5812,7 +5817,7 @@ case 285:
     ;
     break;}
 case 286:
-#line 2867 "Gmsh.y"
+#line 2872 "Gmsh.y"
 {
       double (*pNumOpt)(int num, int action, double value);
       StringXNumber *pNumCat;
@@ -5832,7 +5837,7 @@ case 286:
     ;
     break;}
 case 287:
-#line 2885 "Gmsh.y"
+#line 2890 "Gmsh.y"
 {
       double (*pNumOpt)(int num, int action, double value);
       StringXNumber *pNumCat;
@@ -5852,7 +5857,7 @@ case 287:
     ;
     break;}
 case 288:
-#line 2903 "Gmsh.y"
+#line 2908 "Gmsh.y"
 {
       double (*pNumOpt)(int num, int action, double value);
       StringXNumber *pNumCat;
@@ -5872,107 +5877,107 @@ case 288:
     ;
     break;}
 case 289:
-#line 2921 "Gmsh.y"
+#line 2926 "Gmsh.y"
 { 
       yyval.d = GetValue(yyvsp[-3].c, yyvsp[-1].d);
       Free(yyvsp[-3].c);
     ;
     break;}
 case 290:
-#line 2929 "Gmsh.y"
+#line 2934 "Gmsh.y"
 {
       memcpy(yyval.v, yyvsp[0].v, 5*sizeof(double));
     ;
     break;}
 case 291:
-#line 2933 "Gmsh.y"
+#line 2938 "Gmsh.y"
 {
       for(int i = 0; i < 5; i++) yyval.v[i] = -yyvsp[0].v[i];
     ;
     break;}
 case 292:
-#line 2937 "Gmsh.y"
+#line 2942 "Gmsh.y"
 { 
       for(int i = 0; i < 5; i++) yyval.v[i] = yyvsp[0].v[i];
     ;
     break;}
 case 293:
-#line 2941 "Gmsh.y"
+#line 2946 "Gmsh.y"
 { 
       for(int i = 0; i < 5; i++) yyval.v[i] = yyvsp[-2].v[i] - yyvsp[0].v[i];
     ;
     break;}
 case 294:
-#line 2945 "Gmsh.y"
+#line 2950 "Gmsh.y"
 {
       for(int i = 0; i < 5; i++) yyval.v[i] = yyvsp[-2].v[i] + yyvsp[0].v[i];
     ;
     break;}
 case 295:
-#line 2952 "Gmsh.y"
+#line 2957 "Gmsh.y"
 { 
       yyval.v[0] = yyvsp[-9].d;  yyval.v[1] = yyvsp[-7].d;  yyval.v[2] = yyvsp[-5].d;  yyval.v[3] = yyvsp[-3].d; yyval.v[4] = yyvsp[-1].d;
     ;
     break;}
 case 296:
-#line 2956 "Gmsh.y"
+#line 2961 "Gmsh.y"
 { 
       yyval.v[0] = yyvsp[-7].d;  yyval.v[1] = yyvsp[-5].d;  yyval.v[2] = yyvsp[-3].d;  yyval.v[3] = yyvsp[-1].d; yyval.v[4] = 1.0;
     ;
     break;}
 case 297:
-#line 2960 "Gmsh.y"
+#line 2965 "Gmsh.y"
 {
       yyval.v[0] = yyvsp[-5].d;  yyval.v[1] = yyvsp[-3].d;  yyval.v[2] = yyvsp[-1].d;  yyval.v[3] = 0.0; yyval.v[4] = 1.0;
     ;
     break;}
 case 298:
-#line 2964 "Gmsh.y"
+#line 2969 "Gmsh.y"
 {
       yyval.v[0] = yyvsp[-5].d;  yyval.v[1] = yyvsp[-3].d;  yyval.v[2] = yyvsp[-1].d;  yyval.v[3] = 0.0; yyval.v[4] = 1.0;
     ;
     break;}
 case 299:
-#line 2971 "Gmsh.y"
+#line 2976 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(List_T*));
       List_Add(yyval.l, &(yyvsp[0].l));
     ;
     break;}
 case 300:
-#line 2976 "Gmsh.y"
+#line 2981 "Gmsh.y"
 {
       List_Add(yyval.l, &(yyvsp[0].l));
     ;
     break;}
 case 301:
-#line 2984 "Gmsh.y"
+#line 2989 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       List_Add(yyval.l, &(yyvsp[0].d));
     ;
     break;}
 case 302:
-#line 2989 "Gmsh.y"
+#line 2994 "Gmsh.y"
 {
       yyval.l = yyvsp[0].l;
     ;
     break;}
 case 303:
-#line 2993 "Gmsh.y"
+#line 2998 "Gmsh.y"
 {
       // creates an empty list
       yyval.l = List_Create(2, 1, sizeof(double));
     ;
     break;}
 case 304:
-#line 2998 "Gmsh.y"
+#line 3003 "Gmsh.y"
 {
       yyval.l = yyvsp[-1].l;
     ;
     break;}
 case 305:
-#line 3002 "Gmsh.y"
+#line 3007 "Gmsh.y"
 {
       yyval.l = yyvsp[-1].l;
       double *pd;
@@ -5983,7 +5988,7 @@ case 305:
     ;
     break;}
 case 306:
-#line 3014 "Gmsh.y"
+#line 3019 "Gmsh.y"
 { 
       yyval.l = List_Create(2, 1, sizeof(double)); 
       for(double d = yyvsp[-2].d; (yyvsp[-2].d < yyvsp[0].d) ? (d <= yyvsp[0].d) : (d >= yyvsp[0].d); (yyvsp[-2].d < yyvsp[0].d) ? (d += 1.) : (d -= 1.)) 
@@ -5991,7 +5996,7 @@ case 306:
     ;
     break;}
 case 307:
-#line 3020 "Gmsh.y"
+#line 3025 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double)); 
       if(!yyvsp[0].d || (yyvsp[-4].d < yyvsp[-2].d && yyvsp[0].d < 0) || (yyvsp[-4].d > yyvsp[-2].d && yyvsp[0].d > 0)){
@@ -6004,7 +6009,7 @@ case 307:
    ;
     break;}
 case 308:
-#line 3031 "Gmsh.y"
+#line 3036 "Gmsh.y"
 {
       // Returns the coordinates of a point and fills a list with it.
       // This allows to ensure e.g. that relative point positions are
@@ -6026,7 +6031,7 @@ case 308:
     ;
     break;}
 case 309:
-#line 3051 "Gmsh.y"
+#line 3056 "Gmsh.y"
 {
       yyval.l = List_Create(List_Nbr(yyvsp[0].l), 1, sizeof(double));
       for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){
@@ -6038,7 +6043,7 @@ case 309:
     ;
     break;}
 case 310:
-#line 3061 "Gmsh.y"
+#line 3066 "Gmsh.y"
 {
       yyval.l = List_Create(List_Nbr(yyvsp[0].l), 1, sizeof(double));
       for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){
@@ -6050,7 +6055,7 @@ case 310:
     ;
     break;}
 case 311:
-#line 3071 "Gmsh.y"
+#line 3076 "Gmsh.y"
 {
       yyval.l = List_Create(List_Nbr(yyvsp[0].l), 1, sizeof(double));
       for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){
@@ -6062,7 +6067,7 @@ case 311:
     ;
     break;}
 case 312:
-#line 3081 "Gmsh.y"
+#line 3086 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       Symbol TheSymbol;
@@ -6081,7 +6086,7 @@ case 312:
     ;
     break;}
 case 313:
-#line 3098 "Gmsh.y"
+#line 3103 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       Symbol TheSymbol;
@@ -6102,7 +6107,7 @@ case 313:
     ;
     break;}
 case 314:
-#line 3117 "Gmsh.y"
+#line 3122 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       Symbol TheSymbol;
@@ -6128,7 +6133,7 @@ case 314:
     ;
     break;}
 case 315:
-#line 3141 "Gmsh.y"
+#line 3146 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       Symbol TheSymbol;
@@ -6156,26 +6161,26 @@ case 315:
     ;
     break;}
 case 316:
-#line 3170 "Gmsh.y"
+#line 3175 "Gmsh.y"
 {
       yyval.l = List_Create(2, 1, sizeof(double));
       List_Add(yyval.l, &(yyvsp[0].d));
     ;
     break;}
 case 317:
-#line 3175 "Gmsh.y"
+#line 3180 "Gmsh.y"
 {
       yyval.l = yyvsp[0].l;
     ;
     break;}
 case 318:
-#line 3179 "Gmsh.y"
+#line 3184 "Gmsh.y"
 {
       List_Add(yyval.l, &(yyvsp[0].d));
     ;
     break;}
 case 319:
-#line 3183 "Gmsh.y"
+#line 3188 "Gmsh.y"
 {
       for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){
 	double d;
@@ -6186,19 +6191,19 @@ case 319:
     ;
     break;}
 case 320:
-#line 3196 "Gmsh.y"
+#line 3201 "Gmsh.y"
 {
       yyval.u = CTX.PACK_COLOR((int)yyvsp[-7].d, (int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d);
     ;
     break;}
 case 321:
-#line 3200 "Gmsh.y"
+#line 3205 "Gmsh.y"
 {
       yyval.u = CTX.PACK_COLOR((int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d, 255);
     ;
     break;}
 case 322:
-#line 3212 "Gmsh.y"
+#line 3217 "Gmsh.y"
 {
       int flag;
       yyval.u = Get_ColorForString(ColorString, -1, yyvsp[0].c, &flag);
@@ -6207,7 +6212,7 @@ case 322:
     ;
     break;}
 case 323:
-#line 3219 "Gmsh.y"
+#line 3224 "Gmsh.y"
 {
       unsigned int (*pColOpt)(int num, int action, unsigned int value);
       StringXColor *pColCat;
@@ -6228,13 +6233,13 @@ case 323:
     ;
     break;}
 case 324:
-#line 3241 "Gmsh.y"
+#line 3246 "Gmsh.y"
 {
       yyval.l = yyvsp[-1].l;
     ;
     break;}
 case 325:
-#line 3245 "Gmsh.y"
+#line 3250 "Gmsh.y"
 {
       yyval.l = List_Create(256, 10, sizeof(unsigned int));
       GmshColorTable *ct = Get_ColorTable((int)yyvsp[-3].d);
@@ -6248,26 +6253,26 @@ case 325:
     ;
     break;}
 case 326:
-#line 3260 "Gmsh.y"
+#line 3265 "Gmsh.y"
 {
       yyval.l = List_Create(256, 10, sizeof(unsigned int));
       List_Add(yyval.l, &(yyvsp[0].u));
     ;
     break;}
 case 327:
-#line 3265 "Gmsh.y"
+#line 3270 "Gmsh.y"
 {
       List_Add(yyval.l, &(yyvsp[0].u));
     ;
     break;}
 case 328:
-#line 3272 "Gmsh.y"
+#line 3277 "Gmsh.y"
 {
       yyval.c = yyvsp[0].c;
     ;
     break;}
 case 329:
-#line 3276 "Gmsh.y"
+#line 3281 "Gmsh.y"
 {
       yyval.c = (char *)Malloc(32*sizeof(char));
       time_t now;
@@ -6277,7 +6282,7 @@ case 329:
     ;
     break;}
 case 330:
-#line 3284 "Gmsh.y"
+#line 3289 "Gmsh.y"
 {
       yyval.c = (char *)Malloc((strlen(yyvsp[-3].c)+strlen(yyvsp[-1].c)+1)*sizeof(char));
       strcpy(yyval.c, yyvsp[-3].c);
@@ -6287,7 +6292,7 @@ case 330:
     ;
     break;}
 case 331:
-#line 3292 "Gmsh.y"
+#line 3297 "Gmsh.y"
 {
       yyval.c = (char *)Malloc((strlen(yyvsp[-1].c)+1)*sizeof(char));
       int i;
@@ -6303,7 +6308,7 @@ case 331:
     ;
     break;}
 case 332:
-#line 3306 "Gmsh.y"
+#line 3311 "Gmsh.y"
 {
       yyval.c = (char *)Malloc((strlen(yyvsp[-1].c)+1)*sizeof(char));
       int i;
@@ -6319,13 +6324,13 @@ case 332:
     ;
     break;}
 case 333:
-#line 3320 "Gmsh.y"
+#line 3325 "Gmsh.y"
 {
       yyval.c = yyvsp[-1].c;
     ;
     break;}
 case 334:
-#line 3324 "Gmsh.y"
+#line 3329 "Gmsh.y"
 {
       char tmpstring[1024];
       int i = PrintListOfDouble(yyvsp[-3].c, yyvsp[-1].l, tmpstring);
@@ -6346,7 +6351,7 @@ case 334:
     ;
     break;}
 case 335:
-#line 3343 "Gmsh.y"
+#line 3348 "Gmsh.y"
 { 
       char* (*pStrOpt)(int num, int action, char *value);
       StringXString *pStrCat;
@@ -6370,7 +6375,7 @@ case 335:
     ;
     break;}
 case 336:
-#line 3365 "Gmsh.y"
+#line 3370 "Gmsh.y"
 { 
       char* (*pStrOpt)(int num, int action, char *value);
       StringXString *pStrCat;
@@ -6615,7 +6620,7 @@ yyerrhandle:
     }
   return 1;
 }
-#line 3388 "Gmsh.y"
+#line 3393 "Gmsh.y"
 
 
 void DeleteSymbol(void *a, void *b){
diff --git a/Parser/Gmsh.y b/Parser/Gmsh.y
index 03388aeb1861f12d8a76921751abf8f5440801b8..210d471f57e89c56c2ee04c776dd4179fdc02eb3 100644
--- a/Parser/Gmsh.y
+++ b/Parser/Gmsh.y
@@ -1,5 +1,5 @@
 %{
-// $Id: Gmsh.y,v 1.261 2007-02-12 08:36:13 geuzaine Exp $
+// $Id: Gmsh.y,v 1.262 2007-02-13 07:51:48 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
@@ -1850,6 +1850,10 @@ Command :
       }
       else if(!strcmp($1, "Print")){
 #if defined(HAVE_FLTK)
+	// make sure we have the latest data from THEM in GModel
+	// (fixes bug where we would have no geometry in the picture if
+	// the print command is in the same file as the geometry)
+	GMODEL->importTHEM();
 	char tmpstring[1024];
 	FixRelativePath($2, tmpstring);
 	CreateOutputFile(tmpstring, CTX.print.format);
@@ -1857,6 +1861,7 @@ Command :
       }
       else if(!strcmp($1, "Save")){
 #if defined(HAVE_FLTK)
+	GMODEL->importTHEM();
 	char tmpstring[1024];
 	FixRelativePath($2, tmpstring);
 	CreateOutputFile(tmpstring, CTX.mesh.format);
diff --git a/Parser/Gmsh.yy.cpp b/Parser/Gmsh.yy.cpp
index 8fc20c5619e0d3bd55d8c44a67371dba89771f79..f4f439863fde7cf0eb81d205a8a6cba2088f38d6 100644
--- a/Parser/Gmsh.yy.cpp
+++ b/Parser/Gmsh.yy.cpp
@@ -2,7 +2,7 @@
 /* A lexical scanner generated by flex */
 
 /* Scanner skeleton version:
- * $Header: /cvsroot/gmsh/Parser/Gmsh.yy.cpp,v 1.303 2007-02-12 08:36:13 geuzaine Exp $
+ * $Header: /cvsroot/gmsh/Parser/Gmsh.yy.cpp,v 1.304 2007-02-13 07:51:48 geuzaine Exp $
  */
 
 #define FLEX_SCANNER
@@ -720,7 +720,7 @@ char *yytext;
 #line 1 "Gmsh.l"
 #define INITIAL 0
 #line 2 "Gmsh.l"
-// $Id: Gmsh.yy.cpp,v 1.303 2007-02-12 08:36:13 geuzaine Exp $
+// $Id: Gmsh.yy.cpp,v 1.304 2007-02-13 07:51:48 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
diff --git a/doc/VERSIONS b/doc/VERSIONS
index 1a9a7a4af018f17549d5a0f662238e44b2c0c11d..dc4ad8478a369cc504ffe69e036f5f9954dd1098 100644
--- a/doc/VERSIONS
+++ b/doc/VERSIONS
@@ -1,6 +1,7 @@
-$Id: VERSIONS,v 1.375 2007-02-12 08:36:14 geuzaine Exp $
+$Id: VERSIONS,v 1.376 2007-02-13 07:51:48 geuzaine Exp $
 
 since 2.0: volumes can now be defined from external CAD surfaces;
+fixed various small bugs.
 
 2.0 (February 5, 2007): new geometry and mesh databases, with support
 for STEP and IGES import via OpenCascade; complete rewrite of geometry
diff --git a/doc/texinfo/gmsh.texi b/doc/texinfo/gmsh.texi
index e0d624cbef75807136481670e46b39f1a7d820ae..2b3996fc31a1ada0ba4d4d5eabd94a12845121f6 100644
--- a/doc/texinfo/gmsh.texi
+++ b/doc/texinfo/gmsh.texi
@@ -1,5 +1,5 @@
 \input texinfo.tex @c -*-texinfo-*-
-@c $Id: gmsh.texi,v 1.228 2007-02-05 08:59:31 geuzaine Exp $
+@c $Id: gmsh.texi,v 1.229 2007-02-13 07:51:48 geuzaine Exp $
 @c
 @c Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 @c
@@ -1354,7 +1354,7 @@ is shut down. This permits for example to automatically remember the size
 and location of the windows or which fonts to use. Other options can be
 saved in a per-user ``option'' file (@code{General.OptionsFileName}),
 automatically loaded by Gmsh every time it starts up, by using the
-`Tools->Options->Save' menu.
+`Tools->Options->Save as defaults' menu.
 
 @c All the opt_XXX.texi files are generated automatically with `gmsh -doc'
 
@@ -2661,7 +2661,7 @@ specified in the ASCII input files. All available options, with their
 current values, can be saved into a file by selecting `File->Save As->Gmsh
 options', or simply viewed by pressing the `?' button in the status bar. To
 save the current options as your default preferences for all future Gmsh
-sessions, use the `Tools->Options->Save' button.
+sessions, use the `Tools->Options->Save as defaults' button.
 
 @c -------------------------------------------------------------------------
 @c Non-interactive mode
@@ -3975,10 +3975,10 @@ your @code{.emacs} file: @code{(setq auto-mode-alist (append '(("\\.geo$"
 Define common geometrical objects and options in separate files, reusable in
 all your problem definition structures.
 @item
-Save your preferred options with `Tools->Options->Save'. To reset default
-options, erase the @code{General.OptionsFileName} (usually
-@file{.gmsh-options} in your home directory) or use the `Restore default
-options' button in `Tools->Options->General->Output'.
+Save your preferred options with `Tools->Options->Save as defaults'. To
+reset the default options, erase the @code{General.OptionsFileName}
+(usually @file{.gmsh-options} in your home directory) or use the
+`Restore default options' button in `Tools->Options->General->Output'.
 @item
 In the graphical user interface: