view inst/import_ufl_Problem.m @ 152:1dbe146bff03

Update license to gpl v3
author gedeone-octave <marcovass89@hotmail.it>
date Wed, 11 Sep 2013 09:26:22 +0200
parents f2193e825ad7
children 262c9d7bda1c
line wrap: on
line source

## Copyright (C) 2013 Marco Vassallo <gedeone-octave@users.sourceforge.net>
##
## 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 3 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, see <http://www.gnu.org/licenses/>.

## -*- texinfo -*-
## @deftypefn {Function File} {} = import_ufl_Problem (myproblem)
## This function take as input the name of the .ufl file where 
## the Variational Problem is defined and import it inside Octave.
## It expect that a ilinearForm and a LinearForm are defined inside the .ufl file.
## @seealso{FunctionSpace, BilinearForm, LinearForm} 
## @end deftypefn

function import_ufl_Problem (var_prob)

  if nargin != 1
    error ("import_ufl_Problem: wrong number of input parameters.");
  elseif ! ischar (var_prob)
    error ("import_ufl_Problem: first argument is not a valid string");
  endif

  n = length (mfilename ("fullpath")) - length (mfilename());
  path = strtrunc(mfilename ("fullpath"), n);

  private = fullfile (path, "private/");
  output = generate_fs (var_prob);
  output += generate_rhs (var_prob);
  output += generate_lhs (var_prob);
  output += generate_makefile (var_prob, private);
  if output != 0
    error ("Compilation failed");
  else
    [output, textfile] = system (sprintf ("make -f Makefile_%s all", var_prob));
    if output != 0
      display (text);
      error ("Compilation failed");
    endif
    [output, textfile] = system (sprintf ("make -f Makefile_%s clean", var_prob));
    if output != 0
      display (text);
      error ("Compilation failed");
    endif
  endif

endfunction