Skip to content
Snippets Groups Projects
Select Git revision
  • 98d786cc759f65e1e4efc7084abe2ea1f322133a
  • master default
  • cgnsUnstructured
  • partitioning
  • poppler
  • HighOrderBLCurving
  • gmsh_3_0_4
  • gmsh_3_0_3
  • gmsh_3_0_2
  • gmsh_3_0_1
  • gmsh_3_0_0
  • gmsh_2_16_0
  • gmsh_2_15_0
  • gmsh_2_14_1
  • gmsh_2_14_0
  • gmsh_2_13_2
  • gmsh_2_13_1
  • gmsh_2_12_0
  • gmsh_2_11_0
  • gmsh_2_10_1
  • gmsh_2_10_0
  • gmsh_2_9_3
  • gmsh_2_9_2
  • gmsh_2_9_1
  • gmsh_2_9_0
  • gmsh_2_8_6
26 results

3D_Extrude.cpp

Blame
  • Forked from gmsh / gmsh
    Source project has a limited visibility.
    3D_Extrude.cpp 31.58 KiB
    // $Id: 3D_Extrude.cpp,v 1.88 2005-05-17 22:03:18 geuzaine Exp $
    //
    // Copyright (C) 1997-2005 C. Geuzaine, J.-F. Remacle
    //
    // This program is free software; you can redistribute it and/or modify
    // it under the terms of the GNU General Public License as published by
    // the Free Software Foundation; either version 2 of the License, or
    // (at your option) any later version.
    //
    // This program is distributed in the hope that it will be useful,
    // but WITHOUT ANY WARRANTY; without even the implied warranty of
    // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    // GNU General Public License for more details.
    //
    // You should have received a copy of the GNU General Public License
    // along with this program; if not, write to the Free Software
    // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
    // USA.
    // 
    // Please report all bugs and problems to <gmsh@geuz.org>.
    
    #include "Gmsh.h"
    #include "Numeric.h"
    #include "Geo.h"
    #include "CAD.h"
    #include "Mesh.h"
    #include "Context.h"
    #include "Create.h"
    
    extern Context_T CTX;
    extern Mesh *THEM;
    
    static int DIM, NUM;            // current dimension of parent entity
    static int BAD_TETS;
    static Tree_T *Tree_Ares = NULL, *Tree_Swaps = NULL;
    static Curve *THEC = NULL;
    static Surface *THES = NULL;
    static Volume *THEV = NULL;
    static ExtrudeParams *ep;
    
    // Point_Bound and Vertex_Bound contain the points and vertices on the
    // "boundaries". We cannot check for duplicates in THEM->Points and
    // THEM->Vertices directly since the comparison function for these
    // trees are on the point/vertex numbers, not the position.
    static Tree_T *Point_Bound = NULL, *Vertex_Bound = NULL;
    
    typedef struct
    {
      int Dim, Num;
      List_T *List;
    }
    nxl;
    
    static int compnxl(const void *a, const void *b)
    {
      int val;
      nxl *q = (nxl *) a, *w = (nxl *) b;
    
      if((val = q->Dim - w->Dim) != 0)
        return val;
      return q->Num - w->Num;
    }
    
    List_T *getnxl(Vertex * v, Curve * c)
    {
      nxl NXL;
      NXL.Dim = 1;
      NXL.Num = abs(c->Num);
      nxl *NXLP = (nxl *) List_PQuery(v->Extruded_Points, &NXL, compnxl);
      if(NXLP)