Chris@10: c Copyright (c) 2003, 2007-11 Matteo Frigo Chris@10: c Copyright (c) 2003, 2007-11 Massachusetts Institute of Technology Chris@10: c Chris@10: c This program is free software; you can redistribute it and/or modify Chris@10: c it under the terms of the GNU General Public License as published by Chris@10: c the Free Software Foundation; either version 2 of the License, or Chris@10: c (at your option) any later version. Chris@10: c Chris@10: c This program is distributed in the hope that it will be useful, Chris@10: c but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@10: c MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@10: c GNU General Public License for more details. Chris@10: c Chris@10: c You should have received a copy of the GNU General Public License Chris@10: c along with this program; if not, write to the Free Software Chris@10: c Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA Chris@10: c Chris@10: cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc Chris@10: c Chris@10: c This is an example implementation of Fortran wisdom export/import Chris@10: c to/from a Fortran unit (file), exploiting the generic Chris@10: c dfftw_export_wisdom/dfftw_import_wisdom functions. Chris@10: c Chris@10: c We cannot compile this file into the FFTW library itself, lest all Chris@10: c FFTW-calling programs be required to link to the Fortran I/O Chris@10: c libraries. Chris@10: c Chris@10: cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc Chris@10: Chris@10: c Strictly speaking, the '$' format specifier, which allows us to Chris@10: c write a character without a trailing newline, is not standard F77. Chris@10: c However, it seems to be a nearly universal extension. Chris@10: subroutine write_char(c, iunit) Chris@10: character c Chris@10: integer iunit Chris@10: write(iunit,321) c Chris@10: 321 format(a,$) Chris@10: end Chris@10: Chris@10: subroutine export_wisdom_to_file(iunit) Chris@10: integer iunit Chris@10: external write_char Chris@10: call dfftw_export_wisdom(write_char, iunit) Chris@10: end Chris@10: Chris@10: c Fortran 77 does not have any portable way to read an arbitrary Chris@10: c file one character at a time. The best alternative seems to be to Chris@10: c read a whole line into a buffer, since for fftw-exported wisdom we Chris@10: c can bound the line length. (If the file contains longer lines, Chris@10: c then the lines will be truncated and the wisdom import should Chris@10: c simply fail.) Ugh. Chris@10: subroutine read_char(ic, iunit) Chris@10: integer ic Chris@10: integer iunit Chris@10: character*256 buf Chris@10: save buf Chris@10: integer ibuf Chris@10: data ibuf/257/ Chris@10: save ibuf Chris@10: if (ibuf .lt. 257) then Chris@10: ic = ichar(buf(ibuf:ibuf)) Chris@10: ibuf = ibuf + 1 Chris@10: return Chris@10: endif Chris@10: read(iunit,123,end=666) buf Chris@10: ic = ichar(buf(1:1)) Chris@10: ibuf = 2 Chris@10: return Chris@10: 666 ic = -1 Chris@10: ibuf = 257 Chris@10: 123 format(a256) Chris@10: end Chris@10: Chris@10: subroutine import_wisdom_from_file(isuccess, iunit) Chris@10: integer isuccess Chris@10: integer iunit Chris@10: external read_char Chris@10: call dfftw_import_wisdom(isuccess, read_char, iunit) Chris@10: end