File: __pl_matstr.m

package info (click to toggle)
plplot 5.3.1-4
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 26,248 kB
  • ctags: 11,687
  • sloc: ansic: 86,045; xml: 17,249; sh: 12,400; tcl: 8,113; cpp: 6,824; perl: 4,383; python: 3,915; makefile: 2,899; java: 2,788; fortran: 290; sed: 5; awk: 1
file content (46 lines) | stat: -rw-r--r-- 1,327 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
## Copyright (C) 1998-2003  Joao Cardoso.
## Copyright (C) 2004  Rafael Laboissiere
## 
## 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.
##
## This file is part of plplot_octave.

## out = __pl_matstr(mat, str, n)
##
## set mat(n,:) = str, no matter the size of mat or str.

function out = __pl_matstr(mat, str, n)

  ## Octave damned string arrays are defective!

  if (isstr(str) & isstr(mat) & rows(str) == 1)
    if (isempty(mat))
      out(n,:) = str;
    else
      out = [mat; str];
      [nn sz] = size(out); ## add str at the end
      if (n < nn)
	out(n,:) = out(nn,:);
	out(nn,:) = "";
      elseif (n > nn)
	out(n+1,:) = out(nn,:);
	out(nn,:) = "";
      endif
    endif
    old_dofi = warn_fortran_indexing;
    warn_fortran_indexing = 0;
    out(toascii (out) == 0) = " ";
    warn_fortran_indexing = old_dofi;
  else
    help __pl_matstr
  endif

endfunction