Skip to content

Original Windows File Manager (winfile) with enhancements

License

Notifications You must be signed in to change notification settings

osfree-project/winfile

 
 

Repository files navigation

icon Windows File Manager (WinFile)

The Windows File Manager lives again and runs as a native x86 and x64 desktop app on all currently supported version of Windows, including Windows 10. I welcome your thoughts, comments and suggestions.

There are two primary versions of the source code in the master branch:

  1. original_plus tag: refers to the source for WinFile as of Windows NT4 with minimal changes so that it compiles with Visual Studio and runs on current Windows.

  2. current master: contains my personal changes/additions to WinFile.

I will consider bugs fixes and suggestions for minor changes to the master branch. Feel free to create a pull request or post issues as you see fit.

I will not be changing the original_plus sources nor creating other branches for other purposes. You are welcome to do that on your own.

Download The App

If you are running Windows 10, you can download the app from the store

Get it from Microsoft

If you just want to download the WinFile application without worrying about compiling from the source code, we have a number of pre-compiled versions available.

Please select the version which you would like to download.

To see more release binaries, including of older versions, see the releases page.

History

The Windows File manager was originally released with Windows 3.0 in the early 1990s. You can read more about the history at https://en.wikipedia.org/wiki/File_Manager_(Windows).

What it looks like

Winfile

Changes in original_plus

The source code provided here (in the src directory) was copied from the Windows NT 4 source tree in November 2007. The tag named original_plus contains a very limited set of modifications from the original sources to enable WinFile.exe to run on current Windows. The most significant changes are:

  1. converted to Visual Studio solution; works on VS 2015 and 2017
  2. compiles and runs on 64-bit Windows (e.g., GetWindowLong -> GetWindowLongPtr, LONG -> LPARAM)
  3. added a few header files which were stored elsewhere in the NT source tree (e.g., wfext.h)
  4. deleted some unused files (e.g., winfile.def)
  5. converted 64-bit arithmetic from internal libraries to C
  6. converted internal shell APIs to public APIs (the primary reason the old version would not run)

The help directory contains both winfile.hlp and winfile.chm. Winfile.hlp was in the NT4 source tree, but does not work on Windows 10 any more. Winfile.chm was copied from a regular installation of Windows 98 and works on Windows 10. As is, WinFile.exe tries to launch winfile.hlp which fails.

To create your own local branch referring to this release, run git checkout -b <your branch> original_plus.

Changes in master v10.0 after original_plus

The master branch contains changes I have made since 2007. The changes have been solely determined by my needs and personal use. Some of the changes have limitations that fit the way I use the tool. For example, the path index which supports the new goto command only contains information for the c: drive.

I have also not redesigned or restructured WinFile in any significant way.

Version v10.0 represents the entire set of changes from Nov. 2007 until this OSS project was created. For changes post v10.0, see the commit and release history.

In summary, v10.0 has the following changes/new features compared to original_plus:

  1. OLE drag/drop support
  2. control characters (e.g., ctrl+C) map to current shortcut (e.g., ctrl+C -> copy and copy path to clipboard) instead of changing drives. Change drives now via CTRL + ALT + letter
  3. cut (ctrl+X) followed by paste (ctrl+V) translates into a file move as one would expect
  4. left and right arrows in the tree view expand and collapse folders like in the Explorer
  5. added context menus in both panes
  6. improved the means by which icons are displayed for files
  7. F12 runs notepad or notepad++ on the selected file. Configure via Winfile.ini[Settings]EditorPath
  8. moved the ini file location to %AppData%\Roaming\Microsoft\WinFile
  9. File.Search can include a date which limits the files returned to those after the date provided; the output is also sorted by the date instead of by the name
  10. File.Search includes an option as to whether to include sub-directories
  11. ctrl+K starts a command shell (ConEmu if installed) in the current directory; shift+ctrl+K starts an elevated command shell (cmd.exe only)
  12. File.Goto (ctrl+G) enables one to type a few words of a path and get a list of directories; selecting one changes to that directory. Default = c:\. Configure via Winfile.ini[Settings]CachedPath
  13. UI shows reparse points (e.g., Junction Points and Symbolic Links) as such with little icons.
  14. added simple forward / back navigation (probably needs to be improved)
  15. View command has a new option to sort by date forward (oldest on top); normal date sorting is newest on top; Icon in tool-bar available
  16. CTRL + ENTER executes associated files as administrator
  17. Symbolic Link directories/files and can be created by pressing CTRL + SHIFT during drag and drop of directories/files
  18. Hardlinks and Junctions and can be created by pressing CTRL + SHIFT + ALT during drag and drop of directories/files
  19. The delimiters for splitting words for the GotoCache can be configured via Winfile.ini[Settings]GotoCachePunctuation. The default is - _.
  20. The scroll behavior of the treeview on expand can be configured via Winfile.ini[Settings]ScrollOnExpand. The default is to scroll.
  21. Can handle paths up to 1024 characters with Windows10 >= 1607. Set HKLM\SYSTEM\CurrentControlSet\Control\FileSystem\LongPathsEnabled=1 as admin.
  22. Japanese localisation with full-width katakanas
  23. Create files with suffix '- Copy', when copying with (ctrl+C) -> (ctrl+V) in the same dir, or drag-copy with mouse onto empty space in same dir.

You can read the code for more details.

Contributing

Contributor License Agreement

As mentioned above, this project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.

When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.

What Makes a Good Pull Request for WinFile?

If you are interested in contributing and/or suggesting changes to the actual application, you might find it helpful to read this post first.

License

Copyright (c) Microsoft Corporation. All rights reserved.

Licensed under the MIT License.

About

Original Windows File Manager (winfile) with enhancements

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 86.8%
  • C++ 13.1%
  • Makefile 0.1%