|
Last change
on this file since 2638 was
11,
checked in by aslmd, 15 years ago
|
|
spiga@svn-planeto:ajoute le modele meso-echelle martien
|
|
File size:
943 bytes
|
| Line | |
|---|
| 1 | !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! |
|---|
| 2 | ! Name: despace |
|---|
| 3 | ! |
|---|
| 4 | ! Purpose: Remove all space and tab characters from a string, thus compressing |
|---|
| 5 | ! the string to the left. |
|---|
| 6 | !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! |
|---|
| 7 | subroutine despace(string) |
|---|
| 8 | |
|---|
| 9 | implicit none |
|---|
| 10 | |
|---|
| 11 | ! Arguments |
|---|
| 12 | character (len=*) :: string |
|---|
| 13 | |
|---|
| 14 | ! Local variables |
|---|
| 15 | integer :: i, j, length, iquoted |
|---|
| 16 | |
|---|
| 17 | length = len(string) |
|---|
| 18 | |
|---|
| 19 | iquoted = 0 |
|---|
| 20 | j = 1 |
|---|
| 21 | do i=1,length |
|---|
| 22 | ! Check for a quote mark |
|---|
| 23 | if (string(i:i) == '"' .or. string(i:i) == '''') iquoted = mod(iquoted+1,2) |
|---|
| 24 | |
|---|
| 25 | ! Check for non-space, non-tab character, or if we are inside quoted text |
|---|
| 26 | if ((string(i:i) /= ' ' .and. string(i:i) /= achar(9)) .or. iquoted == 1) then |
|---|
| 27 | string(j:j) = string(i:i) |
|---|
| 28 | j = j + 1 |
|---|
| 29 | end if |
|---|
| 30 | end do |
|---|
| 31 | |
|---|
| 32 | do i=j,length |
|---|
| 33 | string(i:i) = ' ' |
|---|
| 34 | end do |
|---|
| 35 | |
|---|
| 36 | end subroutine despace |
|---|
Note: See
TracBrowser
for help on using the repository browser.