The MASM Forum

Miscellaneous => The Orphanage => Topic started by: Magnum on August 23, 2013, 05:10:30 AM

Title: lfn to 8.3 names
Post by: Magnum on August 23, 2013, 05:10:30 AM
> One of my compilers is 16 bit, so I am stuck with 8 character names for a 16 bit compiler.
>
> Is there a way to convert a long file name to the 8.3 format ?
>
> I tried using dir /x, but it does not show short file names.
>
> Andy
>

The %%~s and %~s at the cmd prompt work most of the time.  There is a bug that makes it fail however.

for %a in (*.*) do @echo %~sa

The above is not reliable.

Assembly, batch, or script ideas are welcome.

Andy
Title: Re: lfn to 8.3 names
Post by: jj2007 on August 23, 2013, 05:38:53 AM
GetShortPathName (http://msdn.microsoft.com/en-us/library/windows/desktop/aa364989%28v=vs.85%29.aspx)
Title: Re: lfn to 8.3 names
Post by: nidud on August 23, 2013, 05:57:19 AM
deleted
Title: Re: lfn to 8.3 names
Post by: FORTRANS on August 23, 2013, 05:59:25 AM
Hi,

   From a command line "DIR /X" gives you the 8.3 file name that
windows generates.  See "DIR /?" for a better explanation.

21-04-13  11:56a        <DIR>          MYDOCU~1        My Documents

   It works for me.  It should work for you.

Cheers,

Steve N.
Title: Re: lfn to 8.3 names
Post by: Magnum on August 23, 2013, 06:53:23 AM
dir /X

Directory of C:\MASM32\SOURCE

08/22/2013  03:52 PM    <DIR>                       .
08/22/2013  03:52 PM    <DIR>                       ..
08/21/2013  06:59 AM               142              .directory
08/21/2013  06:27 AM           975,858              AdwCleaner.exe
08/04/2013  09:50 PM               767              backup2Toshiba.bat
08/22/2013  06:50 AM             2,297              BAK.BAT
08/22/2013  06:50 AM            11,508              bats.zip
08/22/2013  06:50 AM               252              blank.asm
08/19/2013  05:00 PM             2,560              blank.exe
08/19/2013  12:26 AM            15,947 BOOKMA~1.ZIP bookmarks.zip
07/23/2013  04:41 PM           650,240              ClearPastItems_Keep.msi
07/29/2013  04:04 PM               194              Clear_Tmp.bat
08/21/2013  08:26 PM         2,359,350              ConstantGuard.bmp
08/20/2013  09:57 AM             8,649              DialIn.asm
08/21/2013  12:25 PM    <DIR>                       Downloads
08/20/2013  10:35 AM            98,650              download_flash_and_video-1.37-fx+sm.xpi
Title: Re: lfn to 8.3 names
Post by: FORTRANS on August 23, 2013, 07:17:51 AM
Hi,

   Cute.  I have not seen that.  What kind of file system do you
Have?

21-04-13  11:56a        <DIR>          DOWNLO~1        Downloads

   Does the attached directory program fail identically?  Or does
it show something different?

Regards,

Steve

Title: Re: lfn to 8.3 names
Post by: Magnum on August 23, 2013, 08:06:38 AM


Microsoft Windows XP [Version 5.1.2600]

Looks like an 8.3 name in there.  :t

File display program.

File          Size    Date   Time
FIRELA~1.RTF  4187 18 Aug 13 23:52  ³ TDCONFIG.TDW   691 19 Aug 13 17:01

Title: Re: lfn to 8.3 names
Post by: Magnum on August 23, 2013, 08:10:42 AM
Quote from: nidud on August 23, 2013, 05:57:19 AM
you could use a list file

list -r -y -xd -s makeit.bat \masm32\*.asm "tasm %f\n"

makeit.bat:

tasm \masm32\datetime\demo\WORLDT~1.ASM
tasm \masm32\datetime\COPYDA~1.ASM
tasm \masm32\datetime\CURREN~1.ASM
tasm \masm32\datetime\CURREN~2.ASM
tasm \masm32\datetime\CURREN~3.ASM
tasm \masm32\datetime\DateAdd.asm
...


I am trying to figure out what you have.

I would like to name my tasm 16 bit code using LFNs.

Then assemble and link them.

So I would need to convert LFN .asm files to 8.3 names to assemble and link, then delete the 8.3 file names.

Andy
Title: Re: lfn to 8.3 names
Post by: nidud on August 23, 2013, 08:27:52 AM
deleted
Title: Re: lfn to 8.3 names
Post by: nidud on August 23, 2013, 08:36:11 AM
deleted
Title: Re: lfn to 8.3 names
Post by: nidud on August 23, 2013, 09:11:43 AM
deleted
Title: Re: lfn to 8.3 names
Post by: dedndave on August 23, 2013, 12:56:06 PM
in a batch, you can use %~s

for example, %1 refers to the first command line parameter
so, create a batch file, test.bat...
@echo off

set tempstr=%~s1
echo %tempstr%


then, if you type at the prompt...
C:\Documents and Settings\Dave\Desktop => test c:\0longpathaaaa\longfilename.txt
c:\0LONGP~1\LONGFI~1.TXT


%~fs is similar, used with batch FOR loops
Title: Re: lfn to 8.3 names
Post by: FORTRANS on August 23, 2013, 10:01:11 PM
Quote from: Magnum on August 23, 2013, 08:06:38 AM

Looks like an 8.3 name in there.  :t

File display program.

File          Size    Date   Time

Hi,

   Yeah.  Sorry, I assume that ANSI.SYS is loaded.  Anyway, you
seem to have have access to the 8.3 names.

Steve


Title: Re: lfn to 8.3 names
Post by: Adamanteus on August 24, 2013, 05:35:48 AM
Quote from: Magnum on August 23, 2013, 08:10:42 AM

I am trying to figure out what you have.

I would like to name my tasm 16 bit code using LFNs.

Then assemble and link them.

So I would need to convert LFN .asm files to 8.3 names to assemble and link, then delete the 8.3 file names.

Andy

The filenames with tilda's not works with prog tools under DOS - so, I'm renaming files from long to short filenames and back, using /r option of clef (http://www.amslook.com/util), and copying new versions to both sides when makes it.
Title: Re: lfn to 8.3 names
Post by: Magnum on August 24, 2013, 06:56:08 AM
Thanks.

I used Google translate but I can not find out how to download it.

The font is yellow on white.
Title: Re: lfn to 8.3 names
Post by: Antariy on August 24, 2013, 08:15:57 AM
Quote from: FORTRANS on August 23, 2013, 07:17:51 AM
Hi,

   Cute.  I have not seen that.  What kind of file system do you
Have?

21-04-13  11:56a        <DIR>          DOWNLO~1        Downloads


There's a feature that allows to disable creation of short filenames on NTFS, so the strange behaviour is possible when for some files there's short filename, but for some other files - there's no short filename, because they were created after that the mentioned feature was enabled.

It's NtfsDisable8dot3NameCreation value in the HKLM\System\CurrentControlSet\Control\FileSystem
If it's set to 1, then short filenames do not created.
Title: Re: lfn to 8.3 names
Post by: FORTRANS on August 24, 2013, 09:17:33 PM
Quote from: Antariy on August 24, 2013, 08:15:57 AM
There's a feature that allows to disable creation of short filenames on NTFS, so the strange behaviour is possible when for some files there's short filename, but for some other files - there's no short filename, because they were created after that the mentioned feature was enabled.

It's NtfsDisable8dot3NameCreation value in the HKLM\System\CurrentControlSet\Control\FileSystem
If it's set to 1, then short filenames do not created.

Hi,

   Thank you.  I had not heard of that feature.  What then happens
with the MS-DOS Int 21H 4EH Find File function?

Regards,

Steve N.
Title: Re: lfn to 8.3 names
Post by: Gunther on August 25, 2013, 02:27:08 AM
Hi nidud,

just one question: What kind of Norton Commander Clone do you use?

Gunther
Title: Re: lfn to 8.3 names
Post by: nidud on August 25, 2013, 02:48:18 AM
deleted
Title: Re: lfn to 8.3 names
Post by: Magnum on August 25, 2013, 06:42:39 AM
Quote from: Antariy on August 24, 2013, 08:15:57 AM
Quote from: FORTRANS on August 23, 2013, 07:17:51 AM
Hi,

   Cute.  I have not seen that.  What kind of file system do you
Have?

21-04-13  11:56a        <DIR>          DOWNLO~1        Downloads

I originally had short file names turned off for performance reasons.

Andy


There's a feature that allows to disable creation of short filenames on NTFS, so the strange behaviour is possible when for some files there's short filename, but for some other files - there's no short filename, because they were created after that the mentioned feature was enabled.

It's NtfsDisable8dot3NameCreation value in the HKLM\System\CurrentControlSet\Control\FileSystem
If it's set to 1, then short filenames do not created.
Title: Re: lfn to 8.3 names
Post by: Antariy on August 25, 2013, 05:45:41 PM
Quote from: FORTRANS on August 24, 2013, 09:17:33 PM
Quote from: Antariy on August 24, 2013, 08:15:57 AM
There's a feature that allows to disable creation of short filenames on NTFS, so the strange behaviour is possible when for some files there's short filename, but for some other files - there's no short filename, because they were created after that the mentioned feature was enabled.

It's NtfsDisable8dot3NameCreation value in the HKLM\System\CurrentControlSet\Control\FileSystem
If it's set to 1, then short filenames do not created.

Hi,

   Thank you.  I had not heard of that feature.  What then happens
with the MS-DOS Int 21H 4EH Find File function?

Regards,

Steve N.


Hi Steve, I don't know really, don't tested it with such layout. This feature, as far as I can get, was designed for a systems that serve some intensive disk-access tasks, for example, with creation of multiple small files - filling an additional field with short file name to the file system table will decrease performance a bit, so, for server systems that do not run 16 bit programs it's suitable to turn short file names off and don't have properly working DOS functions. But maybe in this case NTVDM will convert long file name to short file name on the fly - using the standard filesystem rules - not checked this.



BTW, in the same key as I mentioned in previous post, it will be useful for any machine, not only servers, to create (if there is no such value) and to set the next values:

NtfsDisableLastAccessUpdate - type DWORD, set to 1 - this disables "last access" field updating each time anyone accesses the file. For example, when one opens a folder with a bunch of files - the explorer accesses to these files, and system updates last access time field. This takes much of time, especially on traditional HDDs. Having enabled the feature you may avoid such things - for example, folders with many files will open faster. The "Date modified" field will still work.

NtfsMftZoneReservation - type DWORD, better to set it to 4, but one may choose smaller value, down to 1 - this will preallocate space for MFT, so the filesystem will work faster and MFT will be fragmented less.



Just as fun: having enabled the Win31FileSystem (DWORD type, set to 1 to enable) it's possible to force Windows to create files ONLY with 8.3 filenames.
Title: Re: lfn to 8.3 names
Post by: FORTRANS on August 25, 2013, 10:44:08 PM
Quote from: Magnum on August 25, 2013, 06:42:39 AM
I originally had short file names turned off for performance reasons.

Hi Andy,

   I would not think that you could notice any difference.  Did
you run any tests?  It seems an odd place to try for a change
in performance for a user system.

Quote from: Antariy on August 25, 2013, 05:45:41 PM
Just as fun: having enabled the Win31FileSystem (DWORD type, set to 1 to enable) it's possible to force Windows to create files ONLY with 8.3 filenames.

Hi Alex,

   Well, that does sound like fun.  On someone else's computer
perhaps.  Is there an easy introduction to this subject?  While
this topic does sound rather interesting, it also sounds like a bit
of desperation to think one would need to try and use any of it.

Cheers,

Steve N.
Title: Re: lfn to 8.3 names
Post by: Magnum on August 25, 2013, 11:05:55 PM
I have used many of these listed here.

http://technet.microsoft.com/en-us/library/cc751051.aspx


Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\AutoChkTimeOut]
@="1000"

[code]
Windows Registry Editor Version 5.00

[HKEY_CURRENT_USER\Control Panel\Desktop]
"ActiveWndTrkTimeout"=dword:00000000
"AutoEndTasks"="0"
"CaretWidth"=dword:00000001
"CoolSwitch"="1"
"CoolSwitchColumns"="7"
"CoolSwitchRows"="3"
"CursorBlinkRate"="530"
"DragFullWindows"="0"
"DragHeight"="4"
"DragWidth"="4"
"FontSmoothing"="0"
"FontSmoothingOrientation"=dword:00000001
"FontSmoothingType"=dword:00000001
"ForegroundFlashCount"=dword:00000003
"ForegroundLockTimeout"=dword:00030d40
"GridGranularity"="0"
"HungAppTimeout"="1000"
"LowPowerActive"="0"
"LowPowerTimeOut"="0"
"MenuShowDelay"="0"
"PaintDesktopVersion"=dword:00000000
"PowerOffActive"="0"
"PowerOffTimeOut"="0"
"ScreenSaverIsSecure"="0"
"ScreenSaveTimeOut"="600"
"ScreenSaveActive"="0"
"TileWallpaper"="0"
"UserPreferencesMask"=hex:90,12,01,80
"WaitToKillAppTimeout"="5000"
"Wallpaper"=""
"WallpaperStyle"="2"
"OriginalWallpaper"=""
"WheelScrollLines"="3"
"Pattern Upgrade"="TRUE"

[HKEY_CURRENT_USER\Control Panel\Desktop\WindowMetrics]
"BorderWidth"="-15"
"CaptionFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,bc,02,00,00,\
  00,00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"CaptionHeight"="-270"
"CaptionWidth"="-270"
"IconFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,90,01,00,00,00,\
  00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"IconSpacing"="-1125"
"IconTitleWrap"="1"
"IconVerticalspacing"="-1125"
"MenuFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,90,01,00,00,00,\
  00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"MenuHeight"="-270"
"MenuWidth"="-270"
"MessageFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,90,01,00,00,\
  00,00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"ScrollHeight"="-240"
"ScrollWidth"="-240"
"Shell Icon BPP"="16"
"SmCaptionFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,bc,02,00,\
  00,00,00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"SmCaptionHeight"="-225"
"SmCaptionWidth"="-180"
"StatusFont"=hex:f5,ff,ff,ff,00,00,00,00,00,00,00,00,00,00,00,00,90,01,00,00,\
  00,00,00,01,00,00,00,00,54,00,61,00,68,00,6f,00,6d,00,61,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,\
  00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00
"AppliedDPI"=dword:00000060
"Shell Icon Size"="32"
"MinAnimate"="0"



[/code]
Title: Re: lfn to 8.3 names
Post by: Antariy on August 25, 2013, 11:20:08 PM
Quote from: FORTRANS on August 25, 2013, 10:44:08 PM
Hi Alex,

   Well, that does sound like fun.  On someone else's computer
perhaps.  Is there an easy introduction to this subject?  While
this topic does sound rather interesting, it also sounds like a bit
of desperation to think one would need to try and use any of it.

Cheers,

Steve N.


Steve, I don't know really where there's easy introduction into this subject. I'm not a "Microsoft sertified professional" or such :greensml: My advices are based on the experience and/or on features that sometimes AFAIK not even [very well] documented by Microsoft - the source of the info was not very "official". Maybe their site has something on this, or they published something on a papeer, I don't know.

As for the variables I provided, well, NtfsDisableLastAccessUpdate and NtfsMftZoneReservation are the ones I use, and they work as described.

I just noted the ones I decided someone may find useful, but not forcing anyone to use it. Just because that placed in the same key where the variable that disables 8.3 filenames.
Title: Re: lfn to 8.3 names
Post by: Magnum on August 28, 2013, 01:10:24 PM
I believe in being fair.

So that means for me, that means, doing the right thing, no mater what others think.