diff --git a/Fltk/GUI.cpp b/Fltk/GUI.cpp
index 9854bd847b1f5b825d355d9b810680f8353940c0..e187a55e2c431faf2915d0be74e9c2dc1e7d9c0a 100644
--- a/Fltk/GUI.cpp
+++ b/Fltk/GUI.cpp
@@ -1,4 +1,4 @@
-// $Id: GUI.cpp,v 1.583 2006-12-05 20:24:09 geuzaine Exp $
+// $Id: GUI.cpp,v 1.584 2006-12-12 01:39:15 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
@@ -568,6 +568,10 @@ int GUI::global_shortcuts(int event)
     quit_selection = 1;
     return 0;   // trick: do as if we didn't use it
   }
+  else if(Fl::test_shortcut('-')) {
+    invert_selection = 1;
+    return 0;   // trick: do as if we didn't use it
+  }
   else if(Fl::test_shortcut(FL_Escape) ||
 	  Fl::test_shortcut(FL_META + FL_Escape) ||
 	  Fl::test_shortcut(FL_SHIFT + FL_Escape) ||
@@ -851,7 +855,8 @@ GUI::GUI(int argc, char **argv)
 
   // initialize selection bits
   selection = ENT_NONE;
-  try_selection = quit_selection = end_selection = undo_selection = 0;
+  try_selection = quit_selection = end_selection = 0;
+  undo_selection = invert_selection = 0;
   for(int i = 0; i < 4; i++) try_selection_xywh[i] = 0;
 
   // set X display
diff --git a/Fltk/GUI.h b/Fltk/GUI.h
index 78499526c2d96ae2d791d2a9c9fde634f01b34fa..2306e381da7fa8734305701eba02e895102a063c 100644
--- a/Fltk/GUI.h
+++ b/Fltk/GUI.h
@@ -322,7 +322,8 @@ public:
   void reset_clip_browser();
   void update_manip_window(int force=0);
   void reset_external_view_list();
-  int  selection, try_selection, quit_selection, end_selection, undo_selection;
+  int  selection, try_selection, quit_selection, end_selection;
+  int  undo_selection, invert_selection;
   int  try_selection_xywh[4];
 };
 
diff --git a/Fltk/Opengl.cpp b/Fltk/Opengl.cpp
index a9dc5c38bebd1d5ff7c40e4c678b5cd5d439cc0c..4ef2db1d3268275ce0fa2995d0852f9cc2d3d933 100644
--- a/Fltk/Opengl.cpp
+++ b/Fltk/Opengl.cpp
@@ -1,4 +1,4 @@
-// $Id: Opengl.cpp,v 1.71 2006-11-27 22:22:10 geuzaine Exp $
+// $Id: Opengl.cpp,v 1.72 2006-12-12 01:39:15 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
@@ -205,6 +205,7 @@ char SelectEntity(int type,
   WID->quit_selection = 0;
   WID->end_selection = 0;
   WID->undo_selection = 0;
+  WID->invert_selection = 0;
 
   while(1) {
     vertices.clear();
diff --git a/Geo/GModelIO_Fourier.cpp b/Geo/GModelIO_Fourier.cpp
index dc34de80bfe2805ecbcd904b7f5a4c3247726b46..7ff9057d92f9f8aac541f5888cb78c25e04acf14 100644
--- a/Geo/GModelIO_Fourier.cpp
+++ b/Geo/GModelIO_Fourier.cpp
@@ -90,8 +90,8 @@ public:
 	double u = i/(double)(M - 1);
 	double v = j/(double)(N - 1);
 	GPoint p = gf->point(u, v);
-	double pou;
-	FM->GetPou(gf->tag(), u, v, pou);
+	double pou=1;
+	//FM->GetPou(gf->tag(), u, v, pou);
 	gf->mesh_vertices.push_back
 	  (new MDataFaceVertex<double>(p.x(), p.y(), p.z(), gf, u, v, pou));
       }
@@ -102,7 +102,7 @@ public:
 					 gf->mesh_vertices[(i + 1) * N + j],
 					 gf->mesh_vertices[(i + 1) * N + (j + 1)],
 					 gf->mesh_vertices[i * N + (j + 1)]);
-	if(FM->GetOrientation(gf->tag()) < 0) q->revert();
+	//if(FM->GetOrientation(gf->tag()) < 0) q->revert();
 	gf->quadrangles.push_back(q);
       }
     }
@@ -139,8 +139,8 @@ public:
 	double allPou = 0.;
 	for(unsigned int i = 0; i < param.size(); i++){
 	  double u2 = param[i].second[0], v2 = param[i].second[1];
-	  double pou2;
-	  FM->GetPou(param[i].first->tag(), u2, v2, pou2);
+	  double pou2=1;
+	  //FM->GetPou(param[i].first->tag(), u2, v2, pou2);
 	  allPou += pou2;
 	}
 	if(v->getData()){
diff --git a/Mesh/meshGFace.cpp b/Mesh/meshGFace.cpp
index 5c57a060acecaf1295ff3475c9af299a6011de8e..c5e809b17339b9315318e4d9309044b20b1a24d9 100644
--- a/Mesh/meshGFace.cpp
+++ b/Mesh/meshGFace.cpp
@@ -1,4 +1,4 @@
-// $Id: meshGFace.cpp,v 1.39 2006-12-11 20:12:33 remacle Exp $
+// $Id: meshGFace.cpp,v 1.40 2006-12-12 01:39:15 geuzaine Exp $
 //
 // Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
 //
@@ -1347,9 +1347,9 @@ bool gmsh2DMeshGeneratorPeriodic ( GFace *gf )
   // delete the mesh
     char name[245];
    sprintf(name,"param%d.pos",gf->tag());
-    outputScalarField(m->triangles, name,1);
+   //outputScalarField(m->triangles, name,1);
     sprintf(name,"real%d.pos",gf->tag());
-    outputScalarField(m->triangles, name,0);
+    //outputScalarField(m->triangles, name,0);
   
   delete m; 
   return true;
diff --git a/benchmarks/2d/coin.geo b/benchmarks/2d/coin.geo
new file mode 100644
index 0000000000000000000000000000000000000000..0f596c122bd81a1c51469df227fdb5c1dfbba785
--- /dev/null
+++ b/benchmarks/2d/coin.geo
@@ -0,0 +1,25 @@
+lc = 0.1;
+
+a = 1.0;
+b = 1.0;
+h = 1.0;
+
+refine = 0.0001;
+
+Point(1) = {0, 0, 0, lc*refine};
+Point(2) = {a, 0, 0, lc} ;
+Point(3) = {0, b, 0, lc} ;
+Point(4) = {a, -h, 0, lc} ;
+Point(5) = {-h, b, 0, lc} ;
+Point(6) = {-h, -h, 0, lc} ;
+
+Line(1) = {1,3} ;
+Line(2) = {3,5} ;
+Line(3) = {5,6} ;
+Line(4) = {6,4} ;
+Line(5) = {4,2} ;
+Line(6) = {2,1} ;
+
+Line Loop(1) = {1,2,3,4,5,6} ;
+Plane Surface(1) = {1};
+
diff --git a/doc/TODO b/doc/TODO
index 38f4ac46e560febd1354b899c216d8ad5faaef6d..c52385f5d8f1884e89880d7895e964715b0763ce 100644
--- a/doc/TODO
+++ b/doc/TODO
@@ -1,4 +1,8 @@
-$Id: TODO,v 1.32 2006-12-03 22:11:46 geuzaine Exp $
+$Id: TODO,v 1.33 2006-12-12 01:39:15 geuzaine Exp $
+
+********************************************************************
+
+introduce Right/Left/Alternate for extruded meshes
 
 ********************************************************************
 
@@ -19,6 +23,11 @@ boundary contains quads
 
 ********************************************************************
 
+physical groups->add->line/surface: pressing '-' after/while selecting 
+a surface should add it with reverse orientation?
+
+********************************************************************
+
 fill transfinite_vertices in meshGFaceExtrude so that we can use
 extruded+recombined surfaces to create Transfinite Volumes?