Welcome to StartX, A very simple utility to allow you to call the CreateProcess API from the command line.
History |
Copyright |
Installation Requirements |
Usage |
Contacting the Author |
V1.0 (29 January 2003)
3 July 2004
V1.01 (20 August 2004)
V1.02 (20 December 2004)
V1.03 (19 August 2005)
V1.04 (17 July 2006)
V1.05 (8 February 2008)
V1.06 (11 November 2008)
V1.07 (22 May 2016)
V1.08 (5 June 2016)
[autorun]
open=StartX.exe /MAX "wordpad.exe readme.txt"
icon=youricon.ico
Parameter | Description |
"title" | Title to display in window title bar. |
path | Starting directory |
MIN | Start window minimized |
MAX | Start window maximized |
HIDE | Start window hidden |
NOUI | Suppresses any UI which StartX displays in response to runtime errors. This is helpful when StartX is being called by another process and we want to avoid displaying any UI which requires a user to click a button to close the message displayed. |
SEPARATE | Start 16-bit Windows program in separate memory space |
SHARED | Start 16-bit Windows program in shared memory space |
PP | Prompts for credentials if the program is to be run under another user account. |
user | The account under which to run the program. |
password | The password to use when logging in using the account "user" |
domain | The NT domain to log into when using the account "user" |
desktop | Name of the desktop only or the name of both the desktop and window station to run the program on. A backslash in the string indicates that the string includes both desktop and window station names. If /K is not specified, the program inherits the desktop and window station of the StartX program. If no value for desktop is specified but /K is used, then the process does not inherit the desktop and window station of its parent process; instead, the system determines if a new desktop and window station need to be created. If the impersonated user already has a desktop, the system will use the existing desktop. |
x,y | Specifies the x and y offset, in pixels, of the upper left corner of a window if a new window is created. The offset is from the upper left corner of the screen. For GUI processes, the specified position is used the first time the new process calls CreateWindow to create an overlapped window if the y parameter of CreateWindow is CW_USEDEFAULT. |
cx1, cy2 | Specifies the width and height, in pixels, of the window if a new window is created. For GUI processes, this is used only the first time the new process calls CreateWindow to create an overlapped window if the nWidth parameter of CreateWindow is CW_USEDEFAULT. |
cx2, cy2 | For console processes, if a new console window is created, specifies the screen buffer width and height in character columns. |
FR | Specifies that initial text of red color if a new console window is created in a console application |
FG | Specifies that initial text of green color if a new console window is created in a console application |
FB | Specifies that initial text of blue color if a new console window is created in a console application |
BR | Specifies the initial background color of red color if a new console window is created in a console application |
BG | Specifies the initial background color of green color if a new console window is created in a console application |
BB | Specifies the initial background color of blue color if a new console window is created in a console application |
FS | Indicates that the process should be run in full-screen mode, rather than in windowed mode. |
LP | Used in conjunction with the /Uuser parameter. Log on, then load the user's profile. Loading the profile can be time-consuming, so it is best to use this value only if you must access the user's profile information |
LNCO | Used in conjunction with the /Uuser parameter. Log on, but use the specified credentials on the network only. The new process uses the same token as the caller, but the system creates a new logon session within LSA, and the process uses the specified credentials as the default credentials. This value can be used to create a process that uses a different set of credentials locally than it does remotely. This is useful in inter-domain scenarios where there is no trust relationship. |
LOW | Start application in the IDLE priority class |
NORMAL | Start application in the NORMAL priority class |
HIGH | Start application in the HIGH priority class |
REALTIME | Start application in the REALTIME priority class |
ABOVENORMAL | Start application in the ABOVENORMAL priority class |
BELOWNORMAL | Start application in the BELOWNORMAL priority class |
WAIT | Start application and wait for it to terminate |
B | Start application without creating a new window. |
RETURNERROR | Returns the error code of the remote process when it exits. Setting this implies /WAIT |
AFFINITYx | The value "x" will be passed to the function SetProcessAffinityMask. So for example if you wanted to limit the new process to only run on the 2nd and 3rd CPU of a computer then you would use the command line "/AFFINITY6". i.e. 0x2 & 0x4. Probably the most common value you would use for this would be "/AFFINITY1" which would limit the process to run on the first CPU only. Please note that the value you provide on the command line should be decimal and not hexadecimal. |
NODEx | The value "x" specifies the preferred Non-Uniform Memory Architecture (NUMA) node as a decimal integer. This uses the GetNumaNodeProcessorMaskEx API which is available on Windows 7, Windows Server 2008 R2 or later only |
PREVENTPINNING | Sets the STARTF_PREVENTPINNING flag for the newly created process. |
TITLEISAPPID | Sets the STARTF_TITLEISAPPID flag for the newly created process. |
TITLEISLINKNAME | Sets the STARTF_TITLEISLINKNAME flag for the newly created process. |
UNTRUSTEDSOURCE | Sets the STARTF_UNTRUSTEDSOURCE flag for the newly created process. |
command / program parameters | This is the actual command line to use. Please note that the full command line should be enclosed in quotes. |
CSIDL_ADMINTOOLS (0x0030)
The file system directory that is used to store administrative tools for an
individual user.
CSIDL_ALTSTARTUP (0x001d)
The file system directory that corresponds to the user's nonlocalized Startup
program group.
CSIDL_APPDATA (0x001a)
The file system directory that serves as a common repository for
application-specific data.
CSIDL_BITBUCKET (0x000a)
The virtual folder containing the objects in the user's Recycle Bin.
CSIDL_CDBURN_AREA (0x003b)
The file system directory acting as a staging area for files waiting
to be written to CD.
CSIDL_COMMON_ADMINTOOLS (0x002f)
The file system directory containing administrative tools for all
users of the computer.
CSIDL_COMMON_ALTSTARTUP (0x001e)
The file system directory that corresponds to the nonlocalized Startup program
group for all users.
CSIDL_COMMON_APPDATA (0x0023)
The file system directory containing application data for all users.
CSIDL_COMMON_DESKTOPDIRECTORY (0x0019)
The file system directory that contains files and folders that appear on the
desktop for all users.
CSIDL_COMMON_DOCUMENTS (0x002e)
The file system directory that contains documents that are common to all users.
CSIDL_COMMON_FAVORITES (0x001f)
The file system directory that serves as a common repository for favorite items
common to all users.
CSIDL_COMMON_MUSIC (0x0035)
The file system directory that serves as a repository for music
files common to all users.
CDIDL_COMMON_OEM_LINKS (0x003a)
The file system directory that
contains links to all users OEM specific apps.
CSIDL_COMMON_PICTURES (0x0036)
The file system directory that serves as a repository for image
files common to all users.
CSIDL_COMMON_PROGRAMS (0x0017)
The file system directory that contains the directories for the common program
groups that appear on the Start menu for all users.
CSIDL_COMMON_STARTMENU (0x0016)
The file system directory that contains the programs and folders that appear
on the Start menu for all users.
CSIDL_COMMON_STARTUP (0x0018)
The file system directory that contains the programs that appear in the Startup
folder for all users.
CSIDL_COMMON_TEMPLATES (0x002d)
The file system directory that contains the templates that are available to
all users.
CSIDL_COMMON_VIDEO (0x0037)
The file system directory that serves as a repository for video
files common to all users.
CSIDL_COMPUTERSNEARME (0x003d)
The folder representing other computers in your workgroup.
CSIDL_CONNECTIONS (0x0031)
The virtual folder representing Network Connections, containing network and
dial-up connections.
CSIDL_CONTROLS (0x0003)
The virtual folder containing icons for the Control Panel applications.
CSIDL_COOKIES (0x0021)
The file system directory that serves as a common repository for Internet cookies.
CSIDL_DESKTOP (0x0000)
The virtual folder representing the Windows desktop, the root of the namespace.
CSIDL_DESKTOPDIRECTORY (0x0010)
The file system directory used to physically store file objects on the desktop
(not to be confused with the desktop folder itself).
CSIDL_DRIVES (0x0011)
The virtual folder representing My Computer, containing everything on the local
computer: storage devices, printers, and Control Panel.
CSIDL_FAVORITES (0x0006)
The file system directory that serves as a common repository for the user's
favorite items.
CSIDL_FONTS (0x0014)
A virtual folder containing fonts. A typical path is C:\Windows\Fonts.
CSIDL_HISTORY (0x0022)
The file system directory that serves as a common repository for Internet history
items.
CSIDL_INTERNET (0x0001)
A viritual folder for Internet Explorer (icon on desktop).
CSIDL_INTERNET_CACHE (0x0020)
The file system directory that serves as a common repository for
temporary Internet files.
CSIDL_LOCAL_APPDATA (0x001c)
The file system directory that serves as a data repository for
local (nonroaming) applications.
CSIDL_MYDOCUMENTS (0x000c)
The virtual folder representing the My Documents desktop item.
CSIDL_MYMUSIC (0x000d)
The file system directory that serves as a common repository for music files.
CSIDL_MYPICTURES (0x0027)
The file system directory that serves as a common repository for image
files.
CSIDL_MYVIDEO (0x000e)
The file system directory that serves as a common repository for
video files.
CSIDL_NETHOOD (0x0013)
A file system directory containing the link objects that may exist in the My
Network Places virtual folder. It is not the same as CSIDL_NETWORK, which represents
the network namespace root.
CSIDL_NETWORK (0x0012)
A virtual folder representing Network Neighborhood, the root of the network
namespace hierarchy.
CSIDL_PERSONAL (0x0005)
The virtual folder representing the My Documents desktop item.
This is equivalent to CSIDL_MYDOCUMENTS.
CSIDL_PRINTERS (0x0004)
The virtual folder containing installed printers.
CSIDL_PRINTHOOD (0x001b)
The file system directory that contains the link objects that can exist in the
Printers virtual folder.
CSIDL_PROFILE (0x0028)
The user's profile folder.
CSIDL_PROGRAM_FILES (0x0026)
The Program Files folder. A typical path is C:\Program Files.
CSIDL_PROGRAM_FILESX86 (0x002a)
The Program files folder for x86
binaries on x64 versions of Windows typically C:\Program Files (x86)
CSIDL_PROGRAM_FILES_COMMON (0x002b)
A folder for components that are shared across applications. A typical path
is C:\Program Files\Common.
CSIDL_PROGRAM_FILES_COMMONX86 (0x002c)
A folder for components that are shared across applications for x86
applications on x64 versions of Windows.
CSIDL_PROGRAMS (0x0002)
The file system directory that contains the user's program groups (which are
themselves file system directories).
CSIDL_RECENT (0x0008)
The file system directory that contains shortcuts to the user's most
recently used documents.
CSIDL_RESOURCES (0x0038)
The file system directory that contains resource data.
CSIDL_RESOURCES_LOCALIZED (0x0039)
The file system directory that
contains localized resource data.
CSIDL_SENDTO (0x0009)
The file system directory that contains Send To menu items.
CSIDL_STARTMENU (0x000b)
The file system directory containing Start menu items.
CSIDL_STARTUP (0x0007)
The file system directory that corresponds to the user's Startup program group.
CSIDL_SYSTEM (0x0025)
The Windows System folder. A typical path is C:\Windows\System32.
CSIDL_SYSTEMX86 (0x0029)
The Windows System folder for x86 components on x64 versions of Windows.
CSIDL_TEMPLATES (0x0015)
The file system directory that serves as a common repository for document templates.
CSIDL_WINDOWS (0x0024)
The Windows directory or SYSROOT. This corresponds to the %windir%
or %SYSTEMROOT% environment variables. A typical path is C:\Windows.
CSIDL_FLAG_CREATE (0x8000)
Combine with another CSIDL to force the creation of the associated folder if
it does not exist.
CSIDL_FLAG_DONT_UNEXPAND (0x2000)
Combine with another CSIDL constant to ensure expansion of environment variables.
CSIDL_FLAG_DONT_VERIFY (0x4000)
Combine with another CSIDL constant, except for CSIDL_FLAG_CREATE, to return
an unverified folder path.
PJ Naughter
Email: pjna@naughter.com
Web: http://www.naughter.com
5 June 2016