Skip to content
Snippets Groups Projects
CommandLine.cpp 36.3 KiB
Newer Older
Christophe Geuzaine's avatar
Christophe Geuzaine committed
// Gmsh - Copyright (C) 1997-2013 C. Geuzaine, J.-F. Remacle
Christophe Geuzaine's avatar
Christophe Geuzaine committed
// See the LICENSE.txt file for license information. Please report all
Christophe Geuzaine's avatar
Christophe Geuzaine committed
// bugs and problems to the public mailing list <gmsh@geuz.org>.
#include <string>
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#include <string.h>
Claudine Bon's avatar
Claudine Bon committed
#include <stdlib.h>
#include "GmshConfig.h"
#include "GmshDefines.h"
#include "GmshVersion.h"
#include "GmshMessage.h"
#include "OpenFile.h"
#include "CommandLine.h"
#include "Context.h"
#include "Options.h"
#include "GModel.h"
#include "CreateFile.h"
#include "OS.h"
#if (FL_MAJOR_VERSION == 1) && (FL_MINOR_VERSION >= 3)
#if defined(HAVE_POST)
int GetGmshMajorVersion(){ return GMSH_MAJOR_VERSION; }
int GetGmshMinorVersion(){ return GMSH_MINOR_VERSION; }
int GetGmshPatchVersion(){ return GMSH_PATCH_VERSION; }
const char *GetGmshExtraVersion(){ return GMSH_EXTRA_VERSION; }
const char *GetGmshVersion(){ return GMSH_VERSION; }
const char *GetGmshBuildDate(){ return GMSH_DATE; }
const char *GetGmshBuildHost(){ return GMSH_HOST; }
const char *GetGmshPackager(){ return GMSH_PACKAGER; }
const char *GetGmshBuildOS(){ return GMSH_OS; }
const char *GetGmshShortLicense(){ return GMSH_SHORT_LICENSE; }
const char *GetGmshBuildOptions(){ return GMSH_CONFIG_OPTIONS; }
Christophe Geuzaine's avatar
Christophe Geuzaine committed
std::vector<std::string> GetUsage(const std::string &name)
Christophe Geuzaine's avatar
pp  
Christophe Geuzaine committed
  // If you make changes in this routine, please also change the texinfo
  // documentation (doc/texinfo/gmsh.texi) and the man page (doc/gmsh.1)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  std::vector<std::string> s;
  s.push_back("Usage: " + name + " [options] [files]");
  s.push_back("Geometry options:");
  s.push_back("  -0                    Output unrolled geometry, then exit");
  s.push_back("  -tol float            Set geometrical tolerance");
  s.push_back("  -match                Match geometries and meshes");
  s.push_back("Mesh options:");
  s.push_back("  -1, -2, -3            Perform 1D, 2D or 3D mesh generation, then exit");
  s.push_back("  -format string        Select output mesh format (auto (default), msh, msh1, msh2,");
  s.push_back("                          unv, vrml, ply2, stl, mesh, bdf, cgns, p3d, diff, med, ...)");
  s.push_back("  -refine               Perform uniform mesh refinement, then exit");
  s.push_back("  -part int             Partition after batch mesh generation");
  s.push_back("  -partWeight <tri|quad|tet|prism|hex> int");
  s.push_back("                          Weight of a triangle/quad/etc. during partitioning");
  s.push_back("  -renumber             Renumber the mesh elements after batch mesh generation");
  s.push_back("  -saveall              Save all elements (discard physical group definitions)");
  s.push_back("  -o file               Specify output file name");
  s.push_back("  -bin                  Use binary format when available");
  s.push_back("  -parametric           Save vertices with their parametric coordinates");
  s.push_back("  -numsubedges          Set the number of subdivisions when displaying high order elements");
  s.push_back("  -algo string          Select mesh algorithm (meshadapt, del2d, front2d, delquad, ");
  s.push_back("                          del3d, front3d, mmg3d)");
  s.push_back("  -smooth int           Set number of mesh smoothing steps");
  s.push_back("  -order int            Set mesh order (1, ..., 5)");
  s.push_back("  -hoOptimize           Optimize high order meshes");
  s.push_back("  -hoMindisto float     Minimum quality for high-order elements before optimization (0.0->1.0)");
  s.push_back("  -hoNLayers int        Number of high order element layers to optimize");
  s.push_back("  -hoElasticity float   Poisson ration for the elasticity analogy (-1.0 < nu < 0.5)");
  s.push_back("  -optimize[_netgen]    Optimize quality of tetrahedral elements");
  s.push_back("  -optimize_lloyd       Optimize 2D meshes using Lloyd algorithm");
  s.push_back("  -clscale float        Set global mesh element size scaling factor");
  s.push_back("  -clmin float          Set minimum mesh element size");
  s.push_back("  -clmax float          Set maximum mesh element size");
  s.push_back("  -anisoMax float       Set maximum anisotropy (only used in bamg for now)");
  s.push_back("  -smoothRatio float    Set smoothing ration between mesh sizes at nodes of a same edge");
  s.push_back("                          (only used in bamg)");
  s.push_back("  -clcurv               Automatically compute element sizes from curvatures");
  s.push_back("  -epslc1d              Set the accuracy of the evaluation of the LCFIELD for 1D mesh");
  s.push_back("  -swapangle            Set the threshold angle (in degree) between two adjacent faces");
  s.push_back("                          below which a swap is allowed");
  s.push_back("  -rand float           Set random perturbation factor");
  s.push_back("  -bgm file             Load background mesh from file");
  s.push_back("  -check                Perform various consistency checks on mesh");
  s.push_back("  -mpass int            Do several passes on the mesh for complex backround fields");
  s.push_back("  -ignorePartBound      Ignore partitions boundaries");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
#if defined(HAVE_FLTK)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  s.push_back("Post-processing options:");
  s.push_back("  -link int             Select link mode between views (0, 1, 2, 3, 4)");
  s.push_back("  -combine              Combine views having identical names into multi-time-step views");
  s.push_back("Display options:");
  s.push_back("  -n                    Hide all meshes and post-processing views on startup");
  s.push_back("  -nodb                 Disable double buffering");
  s.push_back("  -fontsize int         Specify the font size for the GUI");
  s.push_back("  -theme string         Specify FLTK GUI theme");
  s.push_back("  -display string       Specify display");
  s.push_back("  -camera               Use camera mode view;");
  s.push_back("  -stereo               OpenGL quad-buffered stereo rendering (requires special graphic card)");
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  s.push_back("Other options:");
  s.push_back("  -                     Parse input files, then exit");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
#if defined(HAVE_FLTK)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  s.push_back("  -a, -g, -m, -s, -p    Start in automatic, geometry, mesh, solver or post-processing mode");
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  s.push_back("  -pid                  Print process id on stdout");
  s.push_back("  -listen               Always listen to incoming connection requests");
  s.push_back("  -watch pattern        Pattern of files to merge as they become available");
  s.push_back("  -v int                Set verbosity level");
  s.push_back("  -nopopup              Don't popup dialog windows in scripts");
  s.push_back("  -string \"string\"      Parse option string at startup");
  s.push_back("  -option file          Parse option file at startup");
  s.push_back("  -convert files        Convert files into latest binary formats, then exit");
  s.push_back("  -vmsh float           Select msh file version");
  s.push_back("  -version              Show version number");
  s.push_back("  -info                 Show detailed version information");
  s.push_back("  -help                 Show this message");
  return s;
}

std::vector<std::pair<std::string, std::string> > GetShortcutsUsage(const std::string &ctrl)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
{
  std::string cc = ctrl;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#if defined(__APPLE__)
  if(cc.empty()) cc = "Cmd+";
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#else
  if(cc.empty()) cc = "Ctrl+";
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#endif
  typedef std::pair<std::string, std::string> mp;
  std::vector<mp> s;
  s.push_back(mp("Left arrow",     "Go to previous time step"));
  s.push_back(mp("Right arrow",    "Go to next time step"));
  s.push_back(mp("Up arrow",       "Make previous view visible"));
  s.push_back(mp("Down arrow",     "Make next view visible"));
  s.push_back(mp("0",              "Reload project file"));
  s.push_back(mp("1 or F1",        "Mesh lines"));
  s.push_back(mp("2 or F2",        "Mesh surfaces"));
  s.push_back(mp("3 or F3",        "Mesh volumes"));
  s.push_back(mp("Escape",         "Cancel lasso zoom/selection, toggle mouse selection ON/OFF"));
  s.push_back(mp("g",              "Go to geometry module"));
  s.push_back(mp("m",              "Go to mesh module"));
  s.push_back(mp("p",              "Go to post-processing module"));
  s.push_back(mp("s",              "Go to solver module"));
  s.push_back(mp("Shift+a",        "Bring all windows to front"));
  s.push_back(mp("Shift+g",        "Show geometry options"));
  s.push_back(mp("Shift+m",        "Show mesh options"));
  s.push_back(mp("Shift+o",        "Show general options"));
  s.push_back(mp("Shift+p",        "Show post-processing options"));
  s.push_back(mp("Shift+s",        "Show solver options"));
  s.push_back(mp("Shift+u",        "Show post-processing view plugins"));
  s.push_back(mp("Shift+w",        "Show post-processing view options"));
  s.push_back(mp("Shift+Escape",   "Enable full mouse selection"));
  s.push_back(mp(cc + "i",         "Show statistics window"));
  s.push_back(mp(cc + "d",         "Attach/detach menu"));
  s.push_back(mp(cc + "l",         "Show message console"));
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#if defined(__APPLE__)
  s.push_back(mp(cc + "m",         "Minimize window"));
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#endif
  s.push_back(mp(cc + "n",         "Create new project file"));
  s.push_back(mp(cc + "o",         "Open project file"));
  s.push_back(mp(cc + "q",         "Quit"));
  s.push_back(mp(cc + "r",         "Rename project file"));
  s.push_back(mp(cc + "s",         "Save file as"));
  s.push_back(mp("Shift+" + cc + "c", "Show clipping plane window"));
  s.push_back(mp("Shift+" + cc + "m", "Show manipulator window"));
  s.push_back(mp("Shift+" + cc + "n", "Show option window"));
  s.push_back(mp("Shift+" + cc + "o", "Merge file(s)"));
  s.push_back(mp("Shift+" + cc + "s", "Save mesh in default format"));
  s.push_back(mp("Shift+" + cc + "u", "Show plugin window"));
  s.push_back(mp("Shift+" + cc + "v", "Show visibility window"));
  s.push_back(mp("Alt+a",          "Loop through axes modes"));
  s.push_back(mp("Alt+b",          "Hide/show bounding boxes"));
  s.push_back(mp("Alt+c",          "Loop through predefined color schemes"));
  s.push_back(mp("Alt+e",          "Hide/Show element outlines for visible post-pro views"));
  s.push_back(mp("Alt+f",          "Change redraw mode (fast/full)"));
  s.push_back(mp("Alt+h",          "Hide/show all post-processing views"));
  s.push_back(mp("Alt+i",          "Hide/show all post-processing view scales"));
  s.push_back(mp("Alt+l",          "Hide/show geometry lines"));
  s.push_back(mp("Alt+m",          "Toggle visibility of all mesh entities"));
  s.push_back(mp("Alt+n",          "Hide/show all post-processing view annotations"));
  s.push_back(mp("Alt+o",          "Change projection mode (orthographic/perspective)"));
  s.push_back(mp("Alt+p",          "Hide/show geometry points"));
  s.push_back(mp("Alt+r",          "Loop through range modes for visible post-pro views"));
  s.push_back(mp("Alt+s",          "Hide/show geometry surfaces"));
  s.push_back(mp("Alt+t",          "Loop through interval modes for visible post-pro views"));
  s.push_back(mp("Alt+v",          "Hide/show geometry volumes"));
  s.push_back(mp("Alt+w",          "Enable/disable all lighting"));
  s.push_back(mp("Alt+x",          "Set X view"));
  s.push_back(mp("Alt+y",          "Set Y view"));
  s.push_back(mp("Alt+z",          "Set Z view"));
  s.push_back(mp("Alt+Shift+a",    "Hide/show small axes"));
  s.push_back(mp("Alt+Shift+b",    "Hide/show mesh volume faces"));
  s.push_back(mp("Alt+Shift+d",    "Hide/show mesh surface faces"));
  s.push_back(mp("Alt+Shift+l",    "Hide/show mesh lines"));
  s.push_back(mp("Alt+Shift+o",    "Adjust projection parameters"));
  s.push_back(mp("Alt+Shift+p",    "Hide/show mesh points"));
  s.push_back(mp("Alt+Shift+s",    "Hide/show mesh surface edges"));
  s.push_back(mp("Alt+Shift+v",    "Hide/show mesh volume edges"));
  s.push_back(mp("Alt+Shift+w",    "Reverse all mesh normals"));
  s.push_back(mp("Alt+Shift+x",    "Set -X view"));
  s.push_back(mp("Alt+Shift+y",    "Set -Y view"));
  s.push_back(mp("Alt+Shift+z",    "Set -Z view"));
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  return s;
}

std::vector<std::pair<std::string, std::string> > GetMouseUsage()
Christophe Geuzaine's avatar
Christophe Geuzaine committed
{
  typedef std::pair<std::string, std::string> mp;
  std::vector<mp> s;
  s.push_back(mp("Move", "- Highlight the entity under the mouse pointer and display its properties"));
  s.push_back(mp("",     "- Resize a lasso zoom or a lasso (un)selection"));
  s.push_back(mp("Left button", "- Rotate"));
  s.push_back(mp("",            "- Select an entity"));
  s.push_back(mp("",            "- Accept a lasso zoom or a lasso selection"));
  s.push_back(mp("Ctrl+Left button", "Start a lasso zoom or a lasso (un)selection"));
  s.push_back(mp("Middle button", "- Zoom"));
  s.push_back(mp("",              "- Unselect an entity"));
  s.push_back(mp("",              "- Accept a lasso zoom or a lasso unselection"));
  s.push_back(mp("Ctrl+Middle button", "Orthogonalize display"));
  s.push_back(mp("Right button", "- Pan"));
  s.push_back(mp("",             "- Cancel a lasso zoom or a lasso (un)selection"));
  s.push_back(mp("",             "- Pop-up menu on post-processing view button"));
  s.push_back(mp("Ctrl+Right button", "Reset to default viewpoint"));
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  return s;
}

void PrintUsage(const std::string &name)
{
  std::vector<std::string> s = GetUsage(name);
  for(unsigned int i = 0; i < s.size(); i++)
    Msg::Direct("%s", s[i].c_str());
void GetOptions(int argc, char *argv[])
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
{
  int terminal = CTX::instance()->terminal;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
  CTX::instance()->terminal = 1;
#if defined(HAVE_PARSER)
  if(argc && argv){
    // parse session and option file (if argc/argv is not provided skip this
    // step: this is usually what is expected when using Gmsh as a library)
    ParseFile(CTX::instance()->homeDir + CTX::instance()->sessionFileName, true);
    ParseFile(CTX::instance()->homeDir + CTX::instance()->optionsFileName, true);
  }
#endif
Francois Henrotte's avatar
Francois Henrotte committed
  if(argc) Msg::SetExecutableName(argv[0]);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
  int i = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
  while(i < argc) {

    if(argv[i][0] == '-') {

      if(!strcmp(argv[i] + 1, "")) {
        CTX::instance()->batch = -99;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "onelab")) {
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        if(argv[i] && argv[i + 1] && argv[i + 1][0] != '-'){
          Msg::InitializeOnelab(argv[i], argv[i + 1]);
          i += 2;
        }
        else if(argv[i]){
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          Msg::InitializeOnelab(argv[i]);
          Msg::Fatal("Missing client name and/or address of OneLab server");
      else if(!strcmp(argv[i] + 1, "lol")) {
        if(argv[i] && argv[i + 1] && argv[i + 1][0] != '-'){
          Msg::LoadOnelabClient(argv[i], argv[i + 1]);
          i += 2;
        }
        else
          Msg::Fatal("Missing client name and/or address of OneLab server");
      else if(!strcmp(argv[i] + 1, "socket")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          Msg::InitializeOnelab("GmshRemote", argv[i++]);
          Msg::Fatal("Missing string");
        CTX::instance()->batch = -3;
      else if(!strcmp(argv[i] + 1, "check")) {
        CTX::instance()->batch = -2;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "0")) {
        CTX::instance()->batch = -1;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "1")) {
        CTX::instance()->batch = 1;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "2")) {
        CTX::instance()->batch = 2;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "3")) {
        CTX::instance()->batch = 3;
      else if(!strcmp(argv[i] + 1, "4")) {
        CTX::instance()->batch = 4;
      else if(!strcmp(argv[i] + 1, "refine")) {
        CTX::instance()->batch = 5;
      else if(!strcmp(argv[i] + 1, "renumber")) {
        CTX::instance()->batchAfterMesh = 1;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        CTX::instance()->partitionOptions.renumber = 1;
Stefen Guzik's avatar
Stefen Guzik committed
      else if(!strcmp(argv[i] + 1, "part")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]){
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          CTX::instance()->batchAfterMesh = 1 ;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          opt_mesh_partition_num(0, GMSH_SET, atoi(argv[i++]));
        }
        else
          Msg::Fatal("Missing number");
      else if (!strcmp(argv[i] + 1,"partWeight")) {
        i++;
        bool check = true;
        opt_mesh_partition_partitioner(0, GMSH_SET, 2); // Metis partitioner
        opt_mesh_partition_metis_algorithm(0, GMSH_SET, 3); // partGraphKWay w/ weights
        while (check) {
          if (argv[i]) {
            if (!strcmp(argv[i],"triangle")) {
              i++;
              opt_mesh_partition_tri_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else if (!strcmp(argv[i],"quad")) {
              i++;
              opt_mesh_partition_qua_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else if (!strcmp(argv[i],"tet")) {
              i++;
              opt_mesh_partition_tet_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else if (!strcmp(argv[i],"prism")) {
              i++;
              opt_mesh_partition_pri_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else if (!strcmp(argv[i],"pyramid")) {
              i++;
              opt_mesh_partition_pyr_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else if (!strcmp(argv[i],"hex")) {
              i++;
              opt_mesh_partition_hex_weight(0,GMSH_SET,atoi(argv[i]));
            }
            else check = false;
            i++;
          }
          else check = false;
        }
      }
      else if(!strcmp(argv[i] + 1, "new")) {
        CTX::instance()->files.push_back("-new");
Stefen Guzik's avatar
Stefen Guzik committed
        i++;
      }
      else if(!strcmp(argv[i] + 1, "pid")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        fprintf(stdout, "%d\n", GetProcessId());
        fflush(stdout);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "a")) {
        CTX::instance()->initialContext = 0;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "g")) {
        CTX::instance()->initialContext = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "m")) {
        CTX::instance()->initialContext = 2;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "s")) {
        CTX::instance()->initialContext = 3;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "p")) {
        CTX::instance()->initialContext = 4;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "saveall")) {
        CTX::instance()->mesh.saveAll = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      else if(!strcmp(argv[i] + 1, "switch_tags")) {
        CTX::instance()->mesh.switchElementTags = 1;
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "optimize")) {
        CTX::instance()->mesh.optimize = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
      else if(!strcmp(argv[i] + 1, "bunin")) {
        i++;
        if(argv[i])
          CTX::instance()->mesh.bunin = atoi(argv[i++]);
        else
          Msg::Fatal("Missing cavity size in bunin optimization");
      }
      else if(!strcmp(argv[i] + 1, "optimize_netgen")) {
        CTX::instance()->mesh.optimizeNetgen = 1;
      else if(!strcmp(argv[i] + 1, "hoOptimize")) {
        i++;
        opt_mesh_smooth_internal_edges(0, GMSH_SET, 1);
      }
      else if(!strcmp(argv[i] + 1, "hoMindisto")) {
          opt_mesh_ho_mindisto(0, GMSH_SET, atof(argv[i++]));
        else
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "hoElasticity")) {
        i++;
        if(argv[i])
          opt_mesh_ho_poisson(0, GMSH_SET, atof(argv[i++]));
        else
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "hoNlayers")) {
        i++;
        if(argv[i])
          opt_mesh_ho_nlayers(0, GMSH_SET, atoi(argv[i++]));
        else
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "optimize_lloyd")) {
        i++;
        if(argv[i])
          CTX::instance()->mesh.optimizeLloyd = atoi(argv[i++]);
        else
          Msg::Fatal("Missing number of lloyd iterations");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "nopopup")) {
        CTX::instance()->noPopup = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "watch")) {
        i++;
        if(argv[i]){
          std::string tmp = argv[i++];
          if(tmp.size() > 2 && tmp[0] == '"' && tmp[tmp.size() - 1] == '"')
            CTX::instance()->watchFilePattern = tmp.substr(1, tmp.size() - 2);
          else
            CTX::instance()->watchFilePattern = tmp;
        }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        else
          Msg::Fatal("Missing string");
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "string")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          ParseString(argv[i++]);
          Msg::Fatal("Missing string");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "option")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          ParseFile(argv[i++], true);
          Msg::Fatal("Missing file name");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "o")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->outputFileName = argv[i++];
          Msg::Fatal("Missing file name");
      else if(!strcmp(argv[i] + 1, "anisoMax")) {
        i++;
        if(argv[i])
          CTX::instance()->mesh.anisoMax = atof(argv[i++]);
        else
          Msg::Fatal("Missing anisotropy ratio");
      }
      else if(!strcmp(argv[i] + 1, "smoothRatio")) {
        i++;
        if(argv[i])
          CTX::instance()->mesh.smoothRatio = atof(argv[i++]);
        else
          Msg::Fatal("Missing smooth ratio");
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "bgm")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->bgmFileName = argv[i++];
        else
          Msg::Fatal("Missing file name");
      else if(!strcmp(argv[i] + 1, "nw")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->numWindows = atoi(argv[i++]);
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "nt")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->numTiles = atoi(argv[i++]);
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "vmsh")) {
        i++;
        if(argv[i]){
          CTX::instance()->mesh.mshFileVersion = atof(argv[i++]);
        }
        else
          Msg::Fatal("Missing number");
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "convert")) {
        i++;
        CTX::instance()->batch = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        while(i < argc) {
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          std::string fileName = std::string(argv[i]) + "_new";
#if defined(HAVE_POST)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          unsigned int n = PView::list.size();
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          OpenProject(argv[i]);
#if defined(HAVE_POST)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          // convert post-processing views to latest binary format
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          for(unsigned int j = n; j < PView::list.size(); j++)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
            PView::list[j]->write(fileName, 1, (j == n) ? false : true);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          // convert mesh to latest binary format
          if(GModel::current()->getMeshStatus() > 0){
            CTX::instance()->mesh.mshFileVersion = 2.0;
            CTX::instance()->mesh.binary = 1;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
            CreateOutputFile(fileName, FORMAT_MSH);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          }
          i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "tol")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->geom.tolerance = atof(argv[i++]);
          Msg::Fatal("Missing number");
        CTX::instance()->geom.matchGeomAndMesh = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "scale")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->geom.scalingFactor = atof(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "meshscale")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->mesh.scalingFactor = atof(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "rand")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->mesh.randFactor = atof(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "clscale")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.lcFactor = atof(argv[i++]);
          if(CTX::instance()->mesh.lcFactor <= 0.0)
            Msg::Fatal("Mesh element size factor must be > 0");
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "clmin")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.lcMin = atof(argv[i++]);
          if(CTX::instance()->mesh.lcMin <= 0.0)
            Msg::Fatal("Minimum length size must be > 0");
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "clmax")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.lcMax = atof(argv[i++]);
          if(CTX::instance()->mesh.lcMax <= 0.0)
            Msg::Fatal("Maximum length size must be > 0");
      else if(!strcmp(argv[i] + 1, "mpass")) {
        i++;
        if(argv[i]) {
          CTX::instance()->mesh.multiplePasses = atoi(argv[i++]);
          if(CTX::instance()->mesh.multiplePasses <= 0)
            Msg::Fatal("Number of Mesh Passes must be > 0");
        }
        else
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "ignorePartBound")) {
        i++;
        opt_mesh_ignore_part_bound(0, GMSH_SET, 1);
      }
      else if(!strcmp(argv[i] + 1, "edgelmin")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.toleranceEdgeLength = atof(argv[i++]);
          if(CTX::instance()->mesh.toleranceEdgeLength <= 0.0)
            Msg::Fatal("Tolerance for model edge length must be > 0 (here %g)",
                       CTX::instance()->mesh.toleranceEdgeLength);
        }
        else
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "epslc1d")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.lcIntegrationPrecision = atof(argv[i++]);
          if(CTX::instance()->mesh.lcIntegrationPrecision <= 0.0)
            Msg::Fatal("Integration accuracy must be > 0");
          Msg::Fatal("Missing number");
      }
      else if(!strcmp(argv[i] + 1, "swapangle")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          CTX::instance()->mesh.allowSwapEdgeAngle = atof(argv[i++]);
          if(CTX::instance()->mesh.allowSwapEdgeAngle <= 0.0)
            Msg::Fatal("Threshold angle for edge swap must be > 0");
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "clcurv")) {
        CTX::instance()->mesh.lcFromCurvature = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
      else if(!strcmp(argv[i] + 1, "clcurviso")) {
        CTX::instance()->mesh.lcFromCurvature = 2;
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "smooth")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->mesh.nbSmoothing = atoi(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "order") || !strcmp(argv[i] + 1, "degree")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          opt_mesh_order(0, GMSH_SET, atof(argv[i++]));
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "numsubedges")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          opt_mesh_num_sub_edges(0, GMSH_SET, atof(argv[i++]));
        else
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "statreport")) {
        i++;
        CTX::instance()->createAppendMeshStatReport = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->meshStatReportFileName = argv[i++];
          Msg::Fatal("Missing argument");
      }
      else if(!strcmp(argv[i] + 1, "append_statreport")) {
        i++;
        CTX::instance()->createAppendMeshStatReport = 2;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->meshStatReportFileName = argv[i++];
          Msg::Fatal("Missing argument");
      else if(!strcmp(argv[i] + 1, "bin")) {
        i++;
        CTX::instance()->mesh.binary = 1;
      else if(!strcmp(argv[i] + 1, "parametric")) {
        i++;
        CTX::instance()->mesh.saveParametric = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "algo")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i]) {
          if(!strncmp(argv[i], "auto", 4))
            CTX::instance()->mesh.algo2d = ALGO_2D_AUTO;
          else if(!strncmp(argv[i], "meshadapt", 9) || !strncmp(argv[i], "iso", 3))
            CTX::instance()->mesh.algo2d = ALGO_2D_MESHADAPT;
          else if(!strncmp(argv[i], "bds", 3))
            CTX::instance()->mesh.algo2d = ALGO_2D_MESHADAPT_OLD;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
          else if(!strncmp(argv[i], "del2d", 5) || !strncmp(argv[i], "tri", 3))
            CTX::instance()->mesh.algo2d = ALGO_2D_DELAUNAY;
          else if(!strncmp(argv[i], "delquad", 5))
            CTX::instance()->mesh.algo2d = ALGO_2D_FRONTAL_QUAD;
          else if(!strncmp(argv[i], "pack", 4))
            CTX::instance()->mesh.algo2d = ALGO_2D_PACK_PRLGRMS;
          else if(!strncmp(argv[i], "front2d", 7) || !strncmp(argv[i], "frontal", 7))
            CTX::instance()->mesh.algo2d = ALGO_2D_FRONTAL;
          else if(!strncmp(argv[i], "bamg",4))
            CTX::instance()->mesh.algo2d = ALGO_2D_BAMG;
          else if(!strncmp(argv[i], "del3d", 5) || !strncmp(argv[i], "tetgen", 6))
          else if(!strncmp(argv[i], "front3d", 7) || !strncmp(argv[i], "netgen", 6))
            CTX::instance()->mesh.algo3d = ALGO_3D_FRONTAL;
          else if(!strncmp(argv[i], "mmg3d", 5))
            CTX::instance()->mesh.algo3d = ALGO_3D_MMG3D;
          else if(!strncmp(argv[i], "delfr3d", 7))
            CTX::instance()->mesh.algo3d = ALGO_3D_FRONTAL_DEL;
          else if(!strncmp(argv[i], "delhex3d", 8))
            CTX::instance()->mesh.algo3d = ALGO_3D_FRONTAL_HEX;
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          else if(!strncmp(argv[i], "rtree3d", 9))
            CTX::instance()->mesh.algo3d = ALGO_3D_RTREE;
            Msg::Fatal("Unknown mesh algorithm");
          Msg::Fatal("Missing algorithm");
Christophe Geuzaine's avatar
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "format") || !strcmp(argv[i] + 1, "f")) {
        i++;
        if(argv[i]) {
          if(!strcmp(argv[i], "auto")){
            CTX::instance()->mesh.fileFormat = FORMAT_AUTO;
          }
          else if(!strcmp(argv[i], "msh1")){
            CTX::instance()->mesh.fileFormat = FORMAT_MSH;
            CTX::instance()->mesh.mshFileVersion = 1.0;
          }
          else if(!strcmp(argv[i], "msh2")){
            CTX::instance()->mesh.fileFormat = FORMAT_MSH;
            CTX::instance()->mesh.mshFileVersion = 2.0;
          }
          else if(!strcmp(argv[i], "msh3")){
            CTX::instance()->mesh.fileFormat = FORMAT_MSH;
            CTX::instance()->mesh.mshFileVersion = 3.0;
          }
          else{
            int format = GetFileFormatFromExtension(std::string(".") + argv[i]);
            if(format < 0){
              Msg::Error("Unknown mesh format `%s', using `msh' instead", argv[i]);
              format = FORMAT_MSH;
            }
            CTX::instance()->mesh.fileFormat = format;
          }
Christophe Geuzaine's avatar
Christophe Geuzaine committed
          i++;
        }
        else
          Msg::Fatal("Missing format");
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "listen")) {
        CTX::instance()->solver.listen = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "version") || !strcmp(argv[i] + 1, "-version")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        fprintf(stderr, "%s\n", GMSH_VERSION);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "info") || !strcmp(argv[i] + 1, "-info")) {
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        fprintf(stderr, "Version          : %s\n", GMSH_VERSION);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
#if defined(HAVE_FLTK)
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        fprintf(stderr, "GUI toolkit      : FLTK %d.%d.%d\n", FL_MAJOR_VERSION,
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
                FL_MINOR_VERSION, FL_PATCH_VERSION);
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        fprintf(stderr, "GUI toolkit      : none\n");
Christophe Geuzaine's avatar
Christophe Geuzaine committed
#if defined(HAVE_PETSC)
#if defined(PETSC_USE_COMPLEX)
        fprintf(stderr, "PETSc arithmetic : Complex\n");
#else
        fprintf(stderr, "PETSc arithmetic : Real\n");
#endif
#endif
        fprintf(stderr, "License          : %s\n", GMSH_SHORT_LICENSE);
        fprintf(stderr, "Build OS         : %s\n", GMSH_OS);
        fprintf(stderr, "Build options    :%s\n", GMSH_CONFIG_OPTIONS);
        fprintf(stderr, "Build date       : %s\n", GMSH_DATE);
        fprintf(stderr, "Build host       : %s\n", GMSH_HOST);
        fprintf(stderr, "Packager         : %s\n", GMSH_PACKAGER);
        fprintf(stderr, "Web site         : http://www.geuz.org/gmsh/\n");
        fprintf(stderr, "Mailing list     : gmsh@geuz.org\n");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "help") || !strcmp(argv[i] + 1, "-help")) {
        fprintf(stderr, "Gmsh, a 3D mesh generator with pre- and post-processing facilities\n");
Christophe Geuzaine's avatar
Christophe Geuzaine committed
        fprintf(stderr, "Copyright (C) 1997-2013 Christophe Geuzaine and Jean-Francois Remacle\n");
        PrintUsage(argv[0]);
Christophe Geuzaine's avatar
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "v") || !strcmp(argv[i] + 1, "verbose")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          Msg::SetVerbosity(atoi(argv[i++]));
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
#if defined(HAVE_FLTK)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "term")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "dual")) {
        CTX::instance()->mesh.dual = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      else if(!strcmp(argv[i] + 1, "voronoi")) {
        CTX::instance()->mesh.voronoi = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "noview")) {
        opt_view_visible(0, GMSH_SET, 0);
        i++;
      else if(!strcmp(argv[i] + 1, "nomesh")) {
        opt_mesh_points(0, GMSH_SET, 0.);
        opt_mesh_lines(0, GMSH_SET, 0.);
        opt_mesh_surfaces_edges(0, GMSH_SET, 0.);
        opt_mesh_surfaces_faces(0, GMSH_SET, 0.);
        opt_mesh_volumes_edges(0, GMSH_SET, 0.);
        opt_mesh_volumes_faces(0, GMSH_SET, 0.);
        i++;
      }
      else if(!strcmp(argv[i] + 1, "n")) {
        opt_view_visible(0, GMSH_SET, 0);
        opt_mesh_points(0, GMSH_SET, 0.);
        opt_mesh_lines(0, GMSH_SET, 0.);
        opt_mesh_surfaces_edges(0, GMSH_SET, 0.);
        opt_mesh_surfaces_faces(0, GMSH_SET, 0.);
        opt_mesh_volumes_edges(0, GMSH_SET, 0.);
        opt_mesh_volumes_faces(0, GMSH_SET, 0.);
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "link")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->post.link = atoi(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "smoothview")) {
        CTX::instance()->post.smooth = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "combine")) {
        CTX::instance()->post.combineTime = 1;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "nodb")) {
        CTX::instance()->db = 0;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
      else if(!strcmp(argv[i] + 1, "camera")) {
        CTX::instance()->camera = 1;
        i++;
      }
      else if(!strcmp(argv[i] + 1, "stereo")) {
        CTX::instance()->camera = 1;
	CTX::instance()->stereo = 1;
        i++;
      }
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "fontsize")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->fontSize = atoi(argv[i++]);
          Msg::Fatal("Missing number");
      else if(!strcmp(argv[i] + 1, "deltafontsize")) {
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->deltaFontSize = atoi(argv[i++]);
          Msg::Fatal("Missing number");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "theme") || !strcmp(argv[i] + 1, "scheme")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->guiTheme = argv[i++];
          Msg::Fatal("Missing argument");
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strcmp(argv[i] + 1, "display")) {
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        if(argv[i])
          CTX::instance()->display = argv[i++];
          Msg::Fatal("Missing argument");
      else if(!strcmp(argv[i] + 1, "showCompounds")) {
        CTX::instance()->geom.hideCompounds = 0;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
#endif
#if defined(__APPLE__)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      else if(!strncmp(argv[i] + 1, "psn", 3)) {
        // the Mac Finder launches programs with a special command line argument
        // of the form -psn_XXX: just ignore it silently (and don't exit!)
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
        i++;
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
      }
#endif
      else {
        Msg::Error("Unknown option '%s'", argv[i]);
        PrintUsage(argv[0]);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
    }
      CTX::instance()->files.push_back(argv[i++]);
  if(CTX::instance()->files.empty()){
    std::string base = (getenv("PWD") ? "" : CTX::instance()->homeDir);
    GModel::current()->setFileName(base + CTX::instance()->defaultFileName);
Christophe Geuzaine's avatar
 
Christophe Geuzaine committed
  else
    GModel::current()->setFileName(CTX::instance()->files[0]);
  CTX::instance()->terminal = terminal;