Filing and Operation System
- Filing:
-
sd-inq-file-status
sd-inq-file-size
sd-change-file-permission
sd-inq-temp-dir
sd-inq-install-dir
sd-gen-unique-filename
sd-set-current-working-directory
sd-get-current-working-directory
sd-with-current-working-directory
sd-search-file
sd-move-file
sd-copy-file
sd-make-directory
sd-directory-p
sd-browse-for-folder
Customization Support
functions
- Operating System:
- sd-sys-exec
sd-sys-background-job
sd-sys-getenv
sd-inq-platform
sd-osdm64-p
sd-inq-username
sd-inq-user-profiledir-pathname
sd-inq-common-profiledir-pathname
sd-convert-filename-to-platform
sd-convert-filename-from-platform
SD-INQ-FILE-STATUS [function]
(sd-inq-file-status filename status)
- Description:
- Checks whether the file given in filename exists, is readable
or writable.
- Parameters:
-
- filename {STRING} - File to check.
- status {KEYWORD}
-
Specifies which status of the file should be checked. One of the
following keywords is allowed:
- :existence
- :read-access
- :write-access
- Return value:
-
- t - if status was set to
- :existence and the file exists,
:read-access and the file is readable,
:write-access and the file is writable.
- nil - Otherwise, or if the file is not regular. Use
sd-inq-error-obj to get
more information.
- Example:
-
(if (sd-inq-file-status "c:/temp/foo" :existence)
(unless (sd-inq-file-status "/c:/temp/foo" :read-access)
(sd-display-error "File \"c:/temp/foo\" is not readable."))
(sd-display-error (sd-inq-error-obj)))
SD-INQ-FILE-SIZE [function]
(sd-inq-file-size filename)
- Description:
- Returns the size of the file given in filename.
- Parameters:
-
- filename {STRING} - File to inquire.
- Return value:
-
- number - size of file
- -1 - file does not exist
SD-CHANGE-FILE-PERMISSION [function]
(sd-change-file-permission file mode)
- Description:
- Changes the access permissions of the given file.
- Parameters:
-
- file {STRING} - the file whoms permissions should be
changed
- mode {OCTAL NUMBER}
- New mode of file. The mode has to be passed in the form
#oNNN where NNN indicates the numeric mask as
described for the UNIX command chmod (see 'man chmod' for more
information). For instance a mode of #o644 assigns
rw rights for the user, r rights for the group and
r rights for other to the file.
- Return value:
-
- t - success
- nil - failure
- Example:
-
(sd-change-file-permission "C:/users/mike/part.pkg" #o440)
SD-INQ-TEMP-DIR [function]
(sd-inq-temp-dir)
- Description:
-
Looks up the path of a temporary directory. The following order is used
to retrieve a suitable directory:
- shell variable METMPDIR (if set and directory exists)
- shell variable TMP (if set, no check whether directory
exists!)
- shell variable TEMP (if set, no check whether directory
exists!)
- Windows temp directory
- "." = current directory (fallback, should never be
returned)
- Return value:
-
- directory {STRING} - full path to a directory which can be
used as a temporary directory.
- nil - failure
- Example:
-
(sd-inq-temp-dir)
=> "C:/Documents and Settings/joeengineer/Local Settings/Temp/"
SD-INQ-INSTALL-DIR [function]
(sd-inq-install-dir)
- Description:
- Returns the installation directory of Creo Elements/Direct
Modeling.
- Return value:
-
- directory {STRING} - full path to the Creo Elements/Direct
Modeling installation directory
- Example:
-
(sd-inq-install-dir)
=> "C:/Program Files/PTC/Creo Elements/Direct Modeling 20.3.5.0
SD-GEN-UNIQUE-FILENAME [function]
(sd-gen-unique-filename file-or-directory :extension extension-string-including-delimiter)
- Description:
- Returns a unique filename in the same directory as the passed
file-or-directory.
- Parameters:
-
- file-or-directory {STRING}
- Directory or filename which is used to locate a unique filename. A
directory name should end with "/".
- :extension {STRING, default NIL}
- An extension string which will be appended to the filename during
generation.
- Return value:
-
- filename {STRING} - name of a unique filename
- nil - failure
- Example:
-
(sd-gen-unique-filename "c:/temp/")
=> "c:/temp/2rs4sqt1or61f892952"
SD-SET-CURRENT-WORKING-DIRECTORY [function]
(sd-set-current-working-directory directory)
- Description:
- Changes the current working directory to directory.
Note: Changes are not reflected in a recorder file.
- Parameters:
-
- directory {STRING} - new current directory name
- Return value:
-
- t - success
- nil - failure (error object contains more
information)
SD-GET-CURRENT-WORKING-DIRECTORY [function]
(sd-get-current-working-directory)
- Description:
- Returns the name of the current working directory.
- Parameters:
- Return value:
-
- directory {STRING} - name of the current working
directory
- Example:
-
(sd-get-current-working-directory)
=> "c:/temp"
SD-WITH-CURRENT-WORKING-DIRECTORY [macro]
(sd-with-current-working-directory directory form(s) ...)
- Description:
-
Macro performs the following steps:
- Remember current working directory
- Set current working directory to directory
- Evaluate form(s)
- Restore current working directory
- Parameters:
-
- directory {STRING} - temporary current directory name
- form {LISP form}
- a form which will be evaluated with the current working directory
set to directory
- Return value:
-
- t - success
- nil - failure
- Example:
-
(sd-with-current-working-directory "c:/temp"
(delete-file "a.lsp")
(delete-file "b.lsp")
(delete-file "cde.lsp"))
SD-SEARCH-FILE [function]
(sd-search-file filename)
- Description:
- Tries to locate file with name filename according to Creo
Elements/Direct Modeling's search directories.
- Parameters:
-
- filename {STRING} - name of the file to be searched
- Return value:
-
- filename-with-path {STRING}
- Full filename including path of filename if file could be
located according to Creo Elements/Direct Modeling's search
directories.
- nil - file could not be found
SD-MOVE-FILE [function]
(sd-move-file source destination)
- Description:
- Moving file source to file destination is used to rename
a file within a directory or to relocate a file within a file system or
across different file systems.
- Parameters:
-
- source {STRING} - file to be moved with or without full or
relative path
- destination {STRING} - name of the moved file at
destination with or without full or relative path
- Return value:
-
- t - file successfully moved
- nil - failure
SD-COPY-FILE [function]
(sd-copy-file source destination)
- Description:
- Copies file source to file destination.
- Parameters:
-
- source {STRING} - file to be copied with or without full or
relative path
- destination {STRING} - name of the copied file at
destination with or without full or relative path
- Return value:
-
- t - file successfully copied
- nil - failure
SD-MAKE-DIRECTORY [function]
(sd-make-directory dir &optional mode)
- Description:
- Creates the directory with name dir and optional mode.
If mode is not given, the directory will be created with the users
default umask (see UNIX man pages for more information on umask, i.e. 'man
umask').
- Parameters:
-
- dir {STRING}
- Name of the directory to be created with or without full or
relative path. Please note that intermediate missing directories will
not be created automatically. This function will fail if you try to do
so.
- mode {OCTAL NUMBER (optional)}
- Mode of the directory to be created. The mode has to be passed in
the form #oNNN where NNN indicates the numeric mask
as described for the UNIX command umask. For instance a mode of
#o755 assigns rwx rights for the user, rx
rights for the group and rx rights for other to the new
directory.
- Return value:
-
- t - success
- nil - failure
- Example:
-
(sd-make-directory "c:/temp/transfer" #o770)
SD-DIRECTORY-P [function]
(sd-directory-p directory)
- Description:
- Checks whether directory is an existing directory or not.
- Parameters:
-
- directory {STRING} - name of the directory to be
checked
- Return value:
-
- t - directory exists
- nil - directory does not exist
SD-SYS-EXEC [function]
(sd-sys-exec command)
- Description:
- Forks an operating system shell and executes command in that
shell. Returns the operating system return value of the command.
Note: If you want to pass a filename (pathname) as argument to this
function you have to convert the filename to the platform specific
notation using the function sd-convert-filename-to-platform.
- Parameters:
-
- command {STRING} - the operating system command to
execute
- Return value:
-
- return-code {FIXNUM}
- the value returned by the command to the OS shell
SD-SYS-BACKGROUND-JOB [function]
(sd-sys-background-job command)
- Description:
- Forks an operating system shell and executes command in that
shell as background job.
Note: If you want to pass a filename (pathname) as argument to this
function you have to convert the filename to the platform specific
notation using the function sd-convert-filename-to-platform.
- Parameters:
-
- command {STRING} - the operating system command to
execute
- Return value:
-
- t - always
SD-SYS-GETENV [function]
(sd-sys-getenv shell-var-name)
- Description:
- Gets the value of the specified shell environment variable from the
operating system shell that Creo Elements/Direct Modeling was started
from.
- Parameters:
-
- shell-var-name {STRING} - the name of the shell
variable
- Return value:
-
- value {STRING} - the value of the shell variable
- Example:
-
;; Get the name of the user's home directory
(setq home-directory (sd-sys-getenv "HOME"))
SD-INQ-PLATFORM [function]
(sd-inq-platform)
- Description:
- Returns information about the platform Creo Elements/Direct Modeling
is currently running on.
- Parameters:
- Return value:
-
- multiple values: <OS> <OS revision>
- The first returned value is :nt indicating the
type of operating system.
The second value is a string indicating the revision of the operating
system.
- nil - otherwise
- Example:
-
(multiple-value-bind (os rev) (sd-inq-platform)
(format t "~%OS: ~S rev: ~S" os rev))
=> OS: :NT rev: "6.1" = Windows 7
SD-OSDM64-P [function]
(sd-osdm64-p)
- Description:
- This function returns T if the executable is the 64 bit
version of Creo Elements/Direct Modeling.
- Parameters:
- Return value:
-
- t - 64 bit version of Creo Elements/Direct Modeling
- nil - 32 bit version of Creo Elements/Direct Modeling
SD-INQ-USERNAME [function]
(sd-inq-username)
- Description:
- Returns the current user name.
- Parameters:
- Return value:
-
- username {STRING} - the name of the user
- Example:
-
(sd-inq-username) => "Joe Engineer"
SD-INQ-USER-PROFILEDIR-PATHNAME [function]
(sd-inq-user-profiledir-pathname)
- Description:
- Returns the profile directory of the current user.
- Parameters:
- Return value:
-
- pathname {STRING} - the user's profile directory
- Example:
-
(namestring (sd-inq-user-profiledir-pathname)) =>
"C:/Documents and Settings/joeengineer/Application Data/PTC/Creo Elements Direct Modeling 20.3.5.0/"
SD-INQ-COMMON-PROFILEDIR-PATHNAME [function]
(sd-inq-common-profiledir-pathname)
- Description:
- Returns the common profile directory for all users.
- Parameters:
- Return value:
-
- pathname {STRING} - the profile directory for all
users
- Example:
-
(namestring (sd-inq-common-profiledir-pathname)) =>
"C:/ProgramData/PTC/Creo Elements Direct Modeling 20.3.5.0/"
SD-CONVERT-FILENAME-TO-PLATFORM [function]
(sd-convert-filename-to-platform filename)
- Description:
- Converts a UNIX specific notation of a filename to a filename which
can be used on the current platform. On Windows the filename is converted
to a PC specific filename.
This function is necessary if you want to pass a file to an external
application e.g. via sd-sys-exec.
Note: The PC specific "\" will be escaped with an
additional "\" in the result string.
- Parameters:
-
- filename {STRING} - the filename to convert
- Return value:
-
- filename - the converted filename
- Examples:
-
(sd-convert-filename-to-platform "c:/temp/example.lsp")
=> "c:\\temp\\example.lsp"
SD-CONVERT-FILENAME-FROM-PLATFORM [function]
(sd-convert-filename-from-platform filename)
- Description:
- Converts a platform specific notation of a filename to a UNIX conform
filename which can be used within Creo Elements/Direct Modeling. All
occurences of "\" within a filename are converted to
"/".
This function is necessary e.g. if you inquire the value of an environment
variable via sd-sys-getenv which represents a
filename.
- Parameters:
-
- filename {STRING} - the filename to convert
- Return value:
-
- filename - the converted filename
- Examples:
-
(sd-convert-filename-from-platform "c:\\temp\\example.lsp")
=> "c:/temp/example.lsp"
© 2023 Parametric
Technology GmbH
(a subsidiary of PTC Inc.), All Rights Reserved |