|
Howdy,here...
Just to clarify what's happening... there are a few things going on
a) The \ character has a special meaning in C and in many things that
are based on C, including Unix shells. It's the "escape" character, and
it tells the system to treat the next character literally, so that the
next character doesn't have a special meaning.
b) Traditionally, file systems were designed to use / (foreslash, not
backslash) as the separator between filename and directory name.
However, when MS-DOS was devised, the folks that created it were worried
about being a lawsuit if they copied the other predominant operating
systems (Unix and CP/M) too closely, so they changed a bunch of things
to make it look different. One of the things they changed was they used
backslash instead of foreslash for filenames. Therefore, operating
systems that evolved from DOS, such as Microsoft Windows, use the
backslash instead.
c) You can see the conflict. C based tools use backslash as a special
character, but it's a directory separator in Windows!
d) In i5/OS they used Unix as the model for the IFS. They used
foreslashes as separators. However, due to the large number of Windows
folks out there, the CL commands for the IFS all accept backslashes as
well as foreslashes. The CL commands will translate the backslashes to
foreslashes before calling the underlying APIs that they use to do the
work -- the point is -- CL commands like WRKLNK, CPY, REN, RMVLNK, etc,
allow backslashes while the IFS APIs do not.
e) RPG does not treat backslashes as special characters. The HSSF tools
(under the covers) use the IFS APIs. So if you call your file
"\\QDLS\BLAH\BLAH" it will not recognize that you are trying to refer to
directories -- it'll include the whole thing, including the slashes, as
part of a single file name.
f) When you try to use WRKLNK to delete it, it doesn't work because
WRKLNK is a CL command, and it translates the slashes, and therefore
looks for directories instead of files!
g) When you try to use QShell, which is a C-based tool, the backslashes
have a special meaning. So if you do rm \\SOMETHING it will atually try
to delete \SOMETHING instead. Why? Because \ tells QShell to take the
subsequent character literally. So, in \\, the first slash tells QShell
to take the next charactter literally. The next character is \. So you
end up with \SOMETHING. You could work around this by doubling up yourfile, I
slashes, i.e. "rm \\\\SOMETHING". This will result in it trying to
delete an object named "\\SOMETHING". It's very much like when we
try to put single quotes in a string in RPG -- you have to double them
up. Hope that makes sense.
h) Another way to solve the problem in QShell would've been by using
wildcards instead of the slashes...
i) The EDTF command solved the problem because it doesn't use the CL
commands to delete the files, it calls the APIs. Not sure why EDTF
works differently than WRKLNK, exactly.. I can only guess that it was
written by a different programmer who did things a little differently.
j) You could've also solved the problem by calling the unlink() API
yourself. Since, again, RPG doesn't treat \ specially, and since the
unlink() API doesn't recognize backslashes as directory separators, it
would've worked.
callp unlink('\\WHATEVER\whatever\whatever')
k) Another consideration which isn't directly related, but might be
interesting... Typically when you specify two directory separators
consecutively in a pathname, the IFS will treat them as if you had only
given one separator. For example, the following two API calls delete
the same object, since the double slash is treated the same way as a
single slash:
unlink('//QDLS/WHATEVER/WHATEVER/example.txt');
unlink('/QDLS/WHATEVER/WHATEVER/example.txt');
This did not apply to your situation, however, since you had specified
backslashes instead of foreslashes, and backslashes weren't considered
directory separators by the tools that created your file, so when you
doubled up the filename, it took it literally.
Anyway -- I realize that you already solved the dilemna at hand, I just
wrote your message to help you understand what was happening.
MKirkpatrick@xxxxxxxxxxxxxxxxx wrote:
This is very odd. While testing my RPG pgm (HSSF) to create a XLS
filescrewed up the file name. I called the file:
\\QNTC\WDSERVER2\FLASH\ORTHOFLASH\flash_test.xls Yes, that is the
isname, slashes and all.
Now I cannot delete this file. I have used WRKLNK Opt 4 and the error
size. I'Object not found'. Opt 8 , though, show attributes, including a
notIPLed the system and tried again with the same results. I have also
tried using iNav ->File System and the error is 'The file, ...., was
listfound.'--
Any suggestions? Thanks.
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing
To post a message email: MIDRANGE-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/midrange-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.