-
Notifications
You must be signed in to change notification settings - Fork 12
Link.Create
- namespace name of, or reference to a namespace
- directory name of a file system directory
- A matrix of messages if linking was successful, else a vector containing an error message.
-
flatten (default off) Do not create sub-namespaces
flatten will load all items into the root of the linked namespace, without creating any sub-namespaces, even if the source code is arranged into sub-directories. This is typically used in for old applications which are in the process of being divided into modules.
Note that if flatten is set, new items need special treatment:
- If a function or operator is renamed in the editor, the new item will be placed in the same folder as the original item.
- If a new item is created, it will be placed in the root of the linked directory.
- It is also possible to use the beforeWrite setting to add application-specific logic to determine the file name to be used.
-
caseCode (default off) Adds a suffix to file names on write
If your application contains items with names that differ only in case (for example
Debug
andDEBUG
), and your file system is case-insensitive (for example, under Microsoft Windows), then enabling caseCode will cause a suffix to be added to file names, containing an octal encoding of the location of uppercase letters in the name.For example, with caseCode on, two functions named
Debug
andDEBUG
will be written to files namedDebug-1.aplf
andDEBUG-37.aplf
.Note: you will probably want to enable forceFilenames if you enable caseCode.
-
forceExtensions (default off) force correct extensions
If enabled, file extensions will be renamed when an item is defined in the workspace from an external file, so that the file extension accurately reflecte the type of the item according to typeExtensions.
-
forceFilenames (default off) force correct filenames
If enabled, file names will be adjusted so that they match the item name, when an item is defined in the workspace from an external file, so that the file extension accurately reflects the name of the item.
Note that by default, although Link will always create files with the same name as items added to the active workspace, it will not insist that file names match item names when importing items from a directory. Unless forceFilenames is set, Link will write updates to the same file that an item was loaded from, even though the file name does not match the item name.
-
source {ns|dir|both}
Whether to consider the ns or dir as the source. Defaults to
both
, but must be specified if- The namespace is
#
- Both sides are non-empty
- The
flatten
option is set Note: "both" will first copy from ns to dir, and then the other way
- watch {none|ns|dir|both}
Specifies which sides of the link to watch for changes (and synchronise). Defaults to
both
where supported, elsens
.
Watching a "dir" (or "both") is currently only supported under Microsoft Windows, but cross-platform support is planned - The namespace is
-
beforeWrite
ns.hookname
name of function to call before writing to fileYou can override default Link behaviour by nominating a function to be called before Link writes to an external source file. This allows you to support custom data formats used by your application.
Your function will be called with a nested right argument containing the following elements:
- Filename that Link expects to use
- The source code that Link intends to write
- The item name
- The old name, if this write is due to a rename
- Reference to the namespace containing the item
- Name class of the item (with decimal fraction)
- Reference to a namespace containing link options for the active link.
- Boolean: Is this call a file name request?
Your callback function should return:
-
0
The beforeWrite function has completed all necessary actions. Link should not update any files. -
1
The beforeWrite function wishes to "pass" on this write: Link should proceed as planned. - If (args[8]=1) the call was a file name request and the callback function should return a suggested file name to use.
-
beforeRead
ns.hookname
name of function to call before before reading a fileIf you specify a beforeRead function, it will be called before Link processes a change to an extenal source file. Your function will be called with the following arguments:
- Arguments
- Name of the file that was changed
- Name of the directory containing the file that was changed
- The namespace that Link has identified as the target, based on the directory name
- Reference to a namespace containing link options for the active link.
- Boolean: Is this call an item name request?
Your callback function should return:
-
0
The beforeWrite function has completed all necessary actions. Link should not update any files. -
1
The beforeWrite function wishes to "pass" on this write: Link should proceed as planned. - If (args[5]=1) the call was a file name request and the callback function should return a suggested file name to use.
- Arguments
-
codeExtensions File extensions that are expected to contain APL code
When reacting to changes in a watching a directory the system will attempt to bring code into the active workspace if the changed file has one of the listed extensions.
- The default is
'aplf' 'aplo' 'apln' 'aplc' 'apli' 'dyalog' 'apl' 'mipage'
Note that customExtensions can add to this list if beforeRead and beforeWrite are used to add handlers for custom file formats.
- The default is
-
customExtensions Specifies additional file extensions handled by beforeRead functions
If you have specified a beforeRead handler function, and your code supports the use of custom file extensions to store source data in application-specific formats, you need to set customExtensions so that Link does not ignore changes to these file types.
- default is
''
- no custom extensions
- default is
-
typeExtensions Specify the file extensions to use for each name class
The typeExtensions table is a two-column matrix with numeric name class numbers in the first column and corresponding file extensions in the second column, specifying the file extension that should be used when creating a new file to store the source code for an item of a specific class.
Note that the forceExtensions switch can be used to correct all extensions on existing files when a link is created.
The default is:
Type extension 2 apla 3 aplf 4 aplo 9.1 apln 9.4 aplc 9.5 apli
Quick links: Introduction Installation Wiki home Email us