1
0
mirror of https://github.com/sasjs/core.git synced 2025-12-12 15:04:36 +00:00

Compare commits

..

84 Commits

Author SHA1 Message Date
github-actions
73f8cd8894 chore: updating all.sas 2023-10-17 15:39:42 +00:00
Allan Bowe
2808145302 Merge branch 'main' into bumpfix 2023-10-17 16:39:19 +01:00
Allan
815e5f3e0e chore: avoiding vpn start 2023-10-17 16:37:48 +01:00
Allan Bowe
843d6e5c2d Merge pull request #360 from sasjs/bumpfix
chore: Bumpfix
2023-10-17 16:37:23 +01:00
github-actions
b084f4e84b chore: updating all.sas 2023-10-17 15:37:03 +00:00
Allan Bowe
5b5116070e Merge branch 'main' into bumpfix 2023-10-17 16:36:39 +01:00
github-actions
a2002db838 chore: updating all.sas 2023-10-17 15:36:07 +00:00
Allan
dc6bcdd69e chore: merge msg 2023-10-17 16:34:40 +01:00
Allan
c97dc9a16d chore: commenting vpn due to package issues 2023-10-17 16:32:24 +01:00
github-actions
ef669db622 chore: updating all.sas 2023-10-17 15:15:30 +00:00
Allan Bowe
26499d2058 Merge pull request #359 from sasjs/bumpfix
chore: moving all.sas logic to another action
2023-10-17 16:15:15 +01:00
Allan Bowe
17e5d0f0e0 Merge branch 'main' into bumpfix 2023-10-17 16:15:04 +01:00
github-actions
fc9205e355 chore: updating all.sas 2023-10-17 15:14:17 +00:00
Allan
ce344fc8e2 chore: allow empty commit to avoid workflow error 2023-10-17 16:12:50 +01:00
Allan
40239c53d8 chore: removing utf char from pre-commit hook 2023-10-17 16:07:57 +01:00
Allan
814ecec94f chore: moving all.sas logic to another action 2023-10-17 16:05:32 +01:00
Allan Bowe
934c501fec Merge pull request #358 from sasjs/bumpfix
chore: adding cli dependency
2023-10-17 16:02:13 +01:00
Allan Bowe
091b2e28be Merge branch 'main' into bumpfix 2023-10-17 16:01:58 +01:00
Allan
d8ea29bf8c chore: -g param 2023-10-17 16:00:47 +01:00
Allan
993dec4610 chore: adding cli dependency 2023-10-17 16:00:05 +01:00
Allan Bowe
f905387d66 Merge pull request #357 from sasjs/bumpfix
fix: bumping semantic release and checkout actions to v4
2023-10-17 15:59:25 +01:00
Allan
7512423b04 fix: bumping semantic release and checkout actions to v4 2023-10-17 15:57:29 +01:00
Allan
50e6d416a4 fix: mentioning conv. commits in CONTRIBUTING.md and setting eol=lf in .gitattributes 2023-10-17 15:24:49 +01:00
Allan Bowe
18b6cadce6 Merge pull request #354 from sasjs/all-contributors/add-rudvfaden
fix: add rudvfaden as a contributor for code
2023-10-17 15:04:27 +01:00
Allan Bowe
413743bbe6 Merge branch 'main' into all-contributors/add-rudvfaden 2023-10-17 15:03:36 +01:00
Allan Bowe
fcafb1026e Merge pull request #353 from rudvfaden/main
added authdomain for odbc engine in MM_ASSIGNDIRECTLIB
2023-10-17 15:01:37 +01:00
allcontributors[bot]
b8f24264d4 docs: update .all-contributorsrc [skip ci] 2023-10-17 14:00:19 +00:00
allcontributors[bot]
5eb87a754e docs: update README.md [skip ci] 2023-10-17 14:00:14 +00:00
Rud Faden
3a5fd4bfc5 added .gitattributes 2023-10-17 15:54:27 +02:00
Rud Faden
b7ae9a2737 added backwards compebility 2023-10-17 15:45:44 +02:00
Rud Faden
4057ac4b2e fix lineending CRLF to LF 2023-10-17 14:00:42 +02:00
Rud Faden
fa0a6ab22d run build.py 2023-10-17 13:46:28 +02:00
Rud Faden
2ae7a60be5 added authdomain for odvc engine 2023-10-17 13:33:48 +02:00
Rud Faden
0a24f3ff7b add authdomain for odbc connection 2023-10-17 13:13:03 +02:00
Allan
592f477063 chore(docs): updated readme about non-ascii char recommendations 2023-10-11 22:42:25 +01:00
Allan Bowe
a91db81894 Merge pull request #352 from sasjs/dcissue50
fix: removing UTF 8 char to support LATIN9 environments
2023-10-11 22:18:30 +01:00
Allan
236e7cc4c0 fix: removing UTF 8 char to support LATIN9 environments
Source issue: https://git.datacontroller.io/dc/dc/issues/50
2023-10-11 22:12:19 +01:00
Allan Bowe
2b6882cb9c Merge pull request #351 from sasjs/issue350
feat: adding LogicalServerType option to mm_createstp.sas macro.
2023-10-05 16:09:41 +01:00
Allan
2a3071708a feat: adding LogicalServerType option to mm_createstp.sas macro. Closes #350 2023-10-05 16:06:11 +01:00
Allan Bowe
3890aefccf Merge pull request #349 from sasjs/hlo
feat: extended comment for hlo variable in mdds_sas_cntlout
2023-09-18 16:20:52 +01:00
Allan
f378a5637f feat: extended comment for hlo variable in mdds_sas_cntlout 2023-09-18 16:18:37 +01:00
Allan Bowe
121c692e09 chore: adding @paul-canals toolbox repo
also ordered the repos alphabetically
2023-09-16 11:24:22 +01:00
Allan
759d6bd144 chore: temporarily disabling auto-update due to un-reproducable pipeline issue 2023-08-18 12:30:27 +01:00
Allan
76d248f302 chore: updating main.yml to debug packages rebuild 2023-08-18 11:02:24 +01:00
Allan Bowe
f30e30c024 Merge pull request #348 from sasjs/docfixes
chore: missing doc updates
2023-08-18 08:36:33 +01:00
Allan Bowe
30637b5025 Merge branch 'main' into docfixes 2023-08-18 08:36:21 +01:00
Allan
9f16d090f5 chore: missing doc updates 2023-08-18 08:34:53 +01:00
Allan Bowe
74143bdf29 Merge pull request #347 from sasjs/docfixes
chore: updating documentation
2023-08-18 08:26:45 +01:00
Allan
1c4c9793f6 chore: missed some doxygen in/out tags 2023-08-18 08:25:19 +01:00
Allan
d42fd4ebac chore: updating documentation in preparation for upcoming sasjs snippets feature 2023-08-18 08:20:13 +01:00
Allan Bowe
d39b1be7a8 Merge pull request #346 from sasjs/gh-action0fix
chore(github): fixed token
2023-08-17 12:26:39 +01:00
Yury Shkoda
65d4c7969d chore(github): fixed token 2023-08-08 16:15:13 +03:00
Allan
fa152cb375 chore(docs): removing asterisk in mv_registerclient example 2023-07-26 21:29:02 +01:00
Allan Bowe
91a2d9039b Merge pull request #345 from sasjs/weboutfix
fix: missing param in webout of SASjs Server and Viya
2023-07-24 17:26:21 +01:00
Allan
73f919ffe7 chore: re-instating pipeline 2023-07-24 17:15:41 +01:00
Allan
68c11334df chore: commenting out SASPAC (automated) release pending updated clientId 2023-07-24 17:06:13 +01:00
Allan
3bb83be0c5 fix: missing param in webout of SASjs Server and Viya 2023-07-24 16:59:29 +01:00
Allan
76a20838ec chore: changing order of execution in main.yml to prevent network errors from vpn 2023-07-21 10:01:10 +01:00
Allan Bowe
9eec2e4920 Merge pull request #344 from sasjs/logging
chore: packages release after semantic release
2023-07-21 09:55:40 +01:00
Allan Bowe
bd18d4c32d Merge branch 'main' into logging 2023-07-21 09:55:22 +01:00
Allan
d7763e276f chore: packages release after semantic release 2023-07-21 09:53:54 +01:00
Allan Bowe
7dadcf20f4 Merge pull request #343 from sasjs/logging
fix: increasing logging of mp_chop to 200 records when mdebug is enabled
2023-07-21 00:36:17 +01:00
Allan
a497976eae fix: increasing logging of mp_chop to 200 records when mdebug is enabled
Also updated some program headers to reflect new Data Controller pricing structure.  all.sas regenerated.
2023-07-21 00:34:36 +01:00
Allan
6c64de651d chore: adding VPN and credentials to pipeline 2023-07-14 10:07:44 +01:00
Allan
48c17beb20 chore: using default target in release pipeline 2023-07-14 10:00:43 +01:00
Allan
c46bb92c39 chore: fixing CLI invocation in github action 2023-07-14 09:58:40 +01:00
Allan
1e894bae98 chore: re-instating SASPAC auto-build process 2023-07-14 09:56:07 +01:00
Allan Bowe
461cda45ee Merge pull request #342 from sasjs/issue341
Full Format Deletion
2023-07-14 00:05:29 +01:00
Allan
7b6d34028b fix: updating broken test in ms_runstp.test.sas 2023-07-13 23:35:30 +01:00
Allan
cb05ee2b9a fix: scoped variables in ms_adduser2group.test.sas 2023-07-13 22:10:08 +01:00
Allan
e41b91f495 chore: fixes to failing tests 2023-07-13 21:27:22 +01:00
Allan
d21958cf0b chore: remove cat 2023-07-13 21:02:20 +01:00
Allan
c4b445db77 chore: hook script fix + cat file 2023-07-13 20:47:09 +01:00
Allan
ebe764a7c0 chore: adding refresh token in yaml file 2023-07-13 16:08:29 +01:00
Allan
7bba51a60e chore: switching nodeJS runtime to Hydrogen as Fermium is end of life 2023-07-13 15:39:40 +01:00
Allan
bce810caa0 chore: rebuilding devDependencies 2023-07-13 15:31:21 +01:00
Allan
222161d589 chore: dependency bump to CLI v4.4.1 2023-07-13 14:58:02 +01:00
Allan
70cac82d78 chore: updating yaml command to use npx @sasjs/cli 2023-07-10 20:00:11 +01:00
Allan
6e0b8ae13b chore: updating header info in mp_getformats.sas 2023-07-10 19:54:22 +01:00
Allan
0dc4bbab62 chore: bumping sasjs/cli in devDependencies 2023-07-10 19:51:57 +01:00
Allan
da5244cda9 fix: when all the entries in a format are deleted, then delete the format completely
includes 3 tests (regular delete, delete all but one, delete all and add one)
Closes #341
2023-07-10 19:50:17 +01:00
Allan
724de80d0f chore(docs): updating header info in mf_getfmtlist.sas 2023-07-10 12:14:58 +01:00
Allan Bowe
8de2dd4e7c Merge pull request #340 from sasjs/issue339
fix: avoid error in mp_lockanytable.sas …
2023-06-26 22:05:18 +01:00
Allan
e46165c140 fix: avoid error in mp_lockanytable.sas when unlocking a table that was not locked
This may happen due to the noprint option affecting the sqlobs variable.  Closes #339
2023-06-26 22:02:08 +01:00
160 changed files with 1874 additions and 3086 deletions

View File

@@ -144,8 +144,18 @@
"contributions": [ "contributions": [
"doc" "doc"
] ]
},
{
"login": "rudvfaden",
"name": "Rud Faden",
"avatar_url": "https://avatars.githubusercontent.com/u/2445577?v=4",
"profile": "http://rudvfaden.github.io/",
"contributions": [
"code"
]
} }
], ],
"contributorsPerLine": 7, "contributorsPerLine": 7,
"skipCi": true "skipCi": true,
"commitType": "docs"
} }

View File

@@ -2,7 +2,7 @@
# Ensure lint is passing # Ensure lint is passing
LINT=`sasjs lint` LINT=`sasjs lint`
if [[ "$LINT" != "All matched files use @sasjs/lint code style!" ]]; then if [[ "$LINT" != *"All matched files use @sasjs/lint code style!" ]]; then
echo "$LINT" echo "$LINT"
echo "To commit in spite of these warnings, use the -n parameter." echo "To commit in spite of these warnings, use the -n parameter."
exit 1 exit 1

1
.gitattributes vendored Normal file
View File

@@ -0,0 +1 @@
* text=auto eol=lf

View File

@@ -27,5 +27,6 @@ To contribute:
1. Create your feature branch (`git checkout -b myfeature`) 1. Create your feature branch (`git checkout -b myfeature`)
2. Make your change 2. Make your change
3. Update the `all.sas` file (`python3 build.py`) 3. Update the `all.sas` file (`python3 build.py`)
4. Push and make a PR 4. Commit using a [Conventional Commit](https://www.conventionalcommits.org)
5. Push and make a PR

View File

@@ -13,16 +13,54 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v2 uses: actions/checkout@v4
- name: Semantic Release
uses: cycjimmy/semantic-release-action@v3 - name: Install dependencies
run: |
npm ci
- name: Check code style (aborts if errors found)
run: npx @sasjs/cli lint
- name: Write VPN Files
run: |
echo "$CA_CRT" > .github/vpn/ca.crt
echo "$USER_CRT" > .github/vpn/user.crt
echo "$USER_KEY" > .github/vpn/user.key
echo "$TLS_KEY" > .github/vpn/tls.key
shell: bash
env: env:
GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} CA_CRT: ${{ secrets.CA_CRT}}
USER_CRT: ${{ secrets.USER_CRT }}
USER_KEY: ${{ secrets.USER_KEY }}
TLS_KEY: ${{ secrets.TLS_KEY }}
- name: Install Open VPN
run: |
#sudo apt install apt-transport-https
#sudo wget https://swupdate.openvpn.net/repos/openvpn-repo-pkg-key.pub
#sudo apt-key add openvpn-repo-pkg-key.pub
#sudo wget -O /etc/apt/sources.list.d/openvpn3.list https://swupdate.openvpn.net/community/openvpn3/repos/openvpn3-jammy.list
#sudo apt update
#sudo apt install openvpn3=17~betaUb22042+jammy
- name: Start Open VPN 3
run: |
# openvpn3 session-start --config .github/vpn/config.ovpn
- name: Add credentials
run: |
echo "CLIENT=${{secrets.SAS9_4GL_IO_CLIENT}}"> .env.server
echo "ACCESS_TOKEN=${{secrets.SAS9_4GL_IO_ACCESS_TOKEN}}" >> .env.server
echo "REFRESH_TOKEN=${{secrets.SAS9_4GL_IO_REFRESH_TOKEN}}" >> .env.server
- name: Semantic Release
uses: cycjimmy/semantic-release-action@v4
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }} NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: SAS Packages Release - name: SAS Packages Release
run: | run: |
npx @sasjs/cli compile job -s sasjs/utils/create_sas_package.sas -o sasjsbuild npx @sasjs/cli compile job -s sasjs/utils/create_sas_package.sas -o sasjsbuild -t server
# this part depends on https://github.com/sasjs/server/issues/307 # need long duration token per https://github.com/sasjs/server/issues/307
# sasjs run sasjsbuild/jobs/utils/create_sas_package.sas -t sas9 # npx @sasjs/cli run sasjsbuild/jobs/utils/create_sas_package.sas -t server

32
.github/workflows/notmain.yml vendored Normal file
View File

@@ -0,0 +1,32 @@
# This workflow will run tests using node and then publish a package to GitHub Packages when a release is created
# For more information see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages
name: SASjs Core - Update all.sas
on:
push:
branches-ignore:
- main
jobs:
release:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install dependencies
run: |
npm ci
npm i -g @sasjs/cli@latest
- name: Ensure all.sas is always up to date
run: |
git config user.name github-actions
git config user.email github-actions@github.com
python3 build.py
git add all.sas
git commit -m "chore: updating all.sas" --allow-empty
git push

View File

@@ -12,7 +12,7 @@ jobs:
strategy: strategy:
matrix: matrix:
node-version: [lts/fermium] node-version: [lts/hydrogen]
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
@@ -51,7 +51,7 @@ jobs:
run: npm ci run: npm ci
- name: Check code style (aborts if errors found) - name: Check code style (aborts if errors found)
run: npx sasjs lint run: npx @sasjs/cli lint
- name: Add client - name: Add client
run: echo "CLIENT=${{secrets.SAS9_4GL_IO_CLIENT}}"> .env.server run: echo "CLIENT=${{secrets.SAS9_4GL_IO_CLIENT}}"> .env.server
@@ -59,11 +59,14 @@ jobs:
- name: Add access token - name: Add access token
run: echo "ACCESS_TOKEN=${{secrets.SAS9_4GL_IO_ACCESS_TOKEN}}" >> .env.server run: echo "ACCESS_TOKEN=${{secrets.SAS9_4GL_IO_ACCESS_TOKEN}}" >> .env.server
- name: Add refresh token
run: echo "REFRESH_TOKEN=${{secrets.SAS9_4GL_IO_REFRESH_TOKEN}}" >> .env.server
- name: Build & Deploy Project to SAS server - name: Build & Deploy Project to SAS server
run: npx sasjs cbd -t server run: npx @sasjs/cli cbd -t server
- name: Run all tests - name: Run all tests
run: npx sasjs test -t server run: npx @sasjs/cli test -t server
env: env:
CI: true CI: true
CLIENT: ${{secrets.CLIENT}} CLIENT: ${{secrets.CLIENT}}

1
.gitignore vendored
View File

@@ -13,3 +13,4 @@ mc_*
*.env* *.env*
~ ~

View File

@@ -212,7 +212,8 @@ When contributing to this library, it is therefore important to ensure that all
## General Notes ## General Notes
- All macros should be compatible with SAS versions from support level B and above (so currently 9.2 and later). If an earlier version is not supported, then the macro should say as such in the header documentation, and exit gracefully (eg `%if %sysevalf(&sysver<9.3) %then %return`). - All macros should be compatible with SAS versions from support level B and above (so currently 9.3 and later). If an earlier version is not supported, then the macro should say as such in the header documentation, and exit gracefully.
- It's [best to avoid](https://git.datacontroller.io/dc/dc/issues/50) special / non-ASCII characters for compatibility with the widest variety of SAS installations.
## Breaking Changes ## Breaking Changes
@@ -235,18 +236,19 @@ If you find this library useful, please leave a [star](https://github.com/sasjs/
The following repositories are also worth checking out: The following repositories are also worth checking out:
* [xieliaing/SAS](https://github.com/xieliaing/SAS)
* [SASJedi/sas-macros](https://github.com/SASJedi/sas-macros)
* [chris-swenson/sasmacros](https://github.com/chris-swenson/sasmacros) * [chris-swenson/sasmacros](https://github.com/chris-swenson/sasmacros)
* [greg-wotton/sas-programs](https://github.com/greg-wootton/sas-programs) * [greg-wotton/sas-programs](https://github.com/greg-wootton/sas-programs)
* [KatjaGlassConsulting/SMILE-SmartSASMacros](https://github.com/KatjaGlassConsulting/SMILE-SmartSASMacros) * [KatjaGlassConsulting/SMILE-SmartSASMacros](https://github.com/KatjaGlassConsulting/SMILE-SmartSASMacros)
* [paul-canals/toolbox](https://github.com/paul-canals/toolbox)
* [rogerjdeangelis](https://github.com/rogerjdeangelis) * [rogerjdeangelis](https://github.com/rogerjdeangelis)
* [SASJedi/sas-macros](https://github.com/SASJedi/sas-macros)
* [scottbass/sas](https://github.com/scottbass/SAS) * [scottbass/sas](https://github.com/scottbass/SAS)
* [xieliaing/SAS](https://github.com/xieliaing/SAS)
* [yabwon/sas_packages](https://github.com/yabwon/SAS_PACKAGES) * [yabwon/sas_packages](https://github.com/yabwon/SAS_PACKAGES)
## Contributors ✨ ## Contributors ✨
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --> <!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
[![All Contributors](https://img.shields.io/badge/all_contributors-13-orange.svg?style=flat-square)](#contributors-) [![All Contributors](https://img.shields.io/badge/all_contributors-14-orange.svg?style=flat-square)](#contributors-)
<!-- ALL-CONTRIBUTORS-BADGE:END --> <!-- ALL-CONTRIBUTORS-BADGE:END -->
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)): Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
@@ -271,6 +273,7 @@ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/d
<td align="center" valign="top" width="14.28%"><a href="https://github.com/yabwon"><img src="https://avatars.githubusercontent.com/u/9314894?v=4?s=100" width="100px;" alt="Bart Jablonski"/><br /><sub><b>Bart Jablonski</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=yabwon" title="Code">💻</a></td> <td align="center" valign="top" width="14.28%"><a href="https://github.com/yabwon"><img src="https://avatars.githubusercontent.com/u/9314894?v=4?s=100" width="100px;" alt="Bart Jablonski"/><br /><sub><b>Bart Jablonski</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=yabwon" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://bandism.net/"><img src="https://avatars.githubusercontent.com/u/22633385?v=4?s=100" width="100px;" alt="Ikko Ashimine"/><br /><sub><b>Ikko Ashimine</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=eltociear" title="Code">💻</a></td> <td align="center" valign="top" width="14.28%"><a href="https://bandism.net/"><img src="https://avatars.githubusercontent.com/u/22633385?v=4?s=100" width="100px;" alt="Ikko Ashimine"/><br /><sub><b>Ikko Ashimine</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=eltociear" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/henrik-forsell"><img src="https://avatars.githubusercontent.com/u/109935936?v=4?s=100" width="100px;" alt="Henrik Forsell"/><br /><sub><b>Henrik Forsell</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=henrik-forsell" title="Documentation">📖</a></td> <td align="center" valign="top" width="14.28%"><a href="https://github.com/henrik-forsell"><img src="https://avatars.githubusercontent.com/u/109935936?v=4?s=100" width="100px;" alt="Henrik Forsell"/><br /><sub><b>Henrik Forsell</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=henrik-forsell" title="Documentation">📖</a></td>
<td align="center" valign="top" width="14.28%"><a href="http://rudvfaden.github.io/"><img src="https://avatars.githubusercontent.com/u/2445577?v=4?s=100" width="100px;" alt="Rud Faden"/><br /><sub><b>Rud Faden</b></sub></a><br /><a href="https://github.com/sasjs/core/commits?author=rudvfaden" title="Code">💻</a></td>
</tr> </tr>
</tbody> </tbody>
</table> </table>

1212
all.sas

File diff suppressed because it is too large Load Diff

View File

@@ -3,6 +3,11 @@
@brief Abort, ungracefully @brief Abort, ungracefully
@details Will abort with a straightforward %abort if the condition is true. @details Will abort with a straightforward %abort if the condition is true.
@param [in] mac= (mf_abort.sas) Name of calling macro (is printed to the log)
@param [in] msg= ( ) Additional string to print to the log
@param [in] iftrue= (%str(1=1)) Conditional logic under which to perform the
abort
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mp_abort.sas @li mp_abort.sas

View File

@@ -10,7 +10,7 @@
%mf_deletefile(&sasjswork/myfile.txt) %mf_deletefile(&sasjswork/myfile.txt)
@param filepath Full path to the target file @param [in] file Full path to the target file
@returns The return code from the fdelete() invocation @returns The return code from the fdelete() invocation

View File

@@ -10,7 +10,7 @@
expected results (depending on whether you 'expect' the result to be expected results (depending on whether you 'expect' the result to be
case insensitive in this context!) case insensitive in this context!)
@param libds library.dataset @param [in] libds library.dataset
@return output returns 1 or 0 @return output returns 1 or 0
<h4> Related Macros </h4> <h4> Related Macros </h4>

View File

@@ -4,7 +4,7 @@
@details You can probably do without this macro as it is just a one liner. @details You can probably do without this macro as it is just a one liner.
Mainly it is here as a convenient way to remember the syntax! Mainly it is here as a convenient way to remember the syntax!
@param fref the fileref to detect @param [in] fref the fileref to detect
@return output Returns 1 if found and 0 if not found. Note - it is possible @return output Returns 1 if found and 0 if not found. Note - it is possible
that the fileref is found, but the file does not (yet) exist. If you need that the fileref is found, but the file does not (yet) exist. If you need

View File

@@ -16,7 +16,7 @@
https://github.com/yabwon/SAS_PACKAGES/blob/main/packages/baseplus.md#functionexists-macro https://github.com/yabwon/SAS_PACKAGES/blob/main/packages/baseplus.md#functionexists-macro
). ).
@param [in] name (positional) - function name @param [in] name function name
@author Allan Bowe @author Allan Bowe
**/ **/

View File

@@ -6,8 +6,8 @@
%put %mf_existVarList(sashelp.class, age sex name dummyvar); %put %mf_existVarList(sashelp.class, age sex name dummyvar);
@param libds 2 part dataset or view reference @param [in] libds 2 part dataset or view reference
@param varlist space separated variable names @param [in] varlist space separated variable names
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -31,6 +31,7 @@
%put %mf_getapploc(/some/location/jobs/extract/somejob/); %put %mf_getapploc(/some/location/jobs/extract/somejob/);
%put %mf_getapploc(/some/location/tests/jobs/somejob/); %put %mf_getapploc(/some/location/tests/jobs/somejob/);
@param [in] pgm The _program value from which to extract the appLoc
@author Allan Bowe @author Allan Bowe
**/ **/

View File

@@ -6,8 +6,8 @@
%put Dataset label = %mf_getattrc(sashelp.class,LABEL); %put Dataset label = %mf_getattrc(sashelp.class,LABEL);
%put Member Type = %mf_getattrc(sashelp.class,MTYPE); %put Member Type = %mf_getattrc(sashelp.class,MTYPE);
@param libds library.dataset @param [in] libds library.dataset
@param attr full list in [documentation]( @param [in] attr full list in [documentation](
https://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000147794.htm) https://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000147794.htm)
@return output returns result of the attrc value supplied, or -1 and log @return output returns result of the attrc value supplied, or -1 and log
message if err. message if err.

View File

@@ -6,8 +6,8 @@
%put Number of observations=%mf_getattrn(sashelp.class,NLOBS); %put Number of observations=%mf_getattrn(sashelp.class,NLOBS);
%put Number of variables = %mf_getattrn(sashelp.class,NVARS); %put Number of variables = %mf_getattrn(sashelp.class,NVARS);
@param libds library.dataset @param [in] libds library.dataset
@param attr Common values are NLOBS and NVARS, full list in [documentation]( @param [in] attr Common values are NLOBS and NVARS, full list in [documentation](
http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000212040.htm) http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000212040.htm)
@return output returns result of the attrn value supplied, or -1 and log @return output returns result of the attrn value supplied, or -1 and log
message if err. message if err.

View File

@@ -10,10 +10,9 @@
returns: returns:
> DOLLAR $CHAR W MONNAME DOLLAR $CHAR W MONNAME
> $CHAR BEST DOLLAR $CHAR BEST DOLLAR
> BEST Z $CHAR COMMA PERCENTN BEST Z $CHAR COMMA PERCENTN
@param [in] libds Two part library.dataset reference. @param [in] libds Two part library.dataset reference.

View File

@@ -7,8 +7,9 @@
%put %mf_getkeyvalue(someindex) %put %mf_getkeyvalue(someindex)
@param key Provide a key on which to perform the lookup @param [in] key Provide a key on which to perform the lookup
@param libds= define the target table which holds the parameters @param [in] libds= (work.mp_setkeyvalue) The library.dataset which holds the
parameters
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -12,7 +12,7 @@
@li SASJS @li SASJS
@li BASESAS @li BASESAS
@param switch the param for which to return a platform specific variable @param [in] switch the param for which to return a platform specific variable
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_mval.sas @li mf_mval.sas

View File

@@ -8,7 +8,7 @@
returns: returns:
> dbo > dbo
@param libref Library reference (also accepts a 2 level libds ref). @param [in] libref Library reference (also accepts a 2 level libds ref).
@return output returns the library schema for the FIRST library encountered @return output returns the library schema for the FIRST library encountered

View File

@@ -19,7 +19,7 @@
@param [in] prefix= (mclib) first part of the returned libref. As librefs can @param [in] prefix= (mclib) first part of the returned libref. As librefs can
be as long as 8 characters, a maximum length of 7 characters is premitted be as long as 8 characters, a maximum length of 7 characters is premitted
for this prefix. for this prefix.
@param [in] maxtries= Deprecated parameter. Remains here to ensure a @param [in] maxtries= (1000) Deprecated parameter. Remains here to ensure a
non-breaking change. Will be removed in v5. non-breaking change. Will be removed in v5.
@version 9.2 @version 9.2

View File

@@ -10,7 +10,7 @@
> MCc59c750610321d4c8bf75faadbcd22 > MCc59c750610321d4c8bf75faadbcd22
@param prefix= set a prefix for the new name @param [in] prefix= (MC) Sets a prefix for the new name
@version 9.3 @version 9.3
@author Allan Bowe @author Allan Bowe

View File

@@ -13,8 +13,6 @@
%let user= %mf_getUser(); %let user= %mf_getUser();
%put &user; %put &user;
@param type - do not use, may be deprecated in a future release
@return SYSUSERID (if workspace server) @return SYSUSERID (if workspace server)
@return _METAPERSON (if stored process server) @return _METAPERSON (if stored process server)
@return SYS_COMPUTE_SESSION_OWNER (if Viya compute session) @return SYS_COMPUTE_SESSION_OWNER (if Viya compute session)

View File

@@ -13,9 +13,9 @@
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mp_setkeyvalue.sas @li mp_setkeyvalue.sas
@param libds dataset to query @param [in] libds dataset to query
@param variable the variable which contains the value to return. @param [in] variable the variable which contains the value to return.
@param filter contents of where clause @param [in] filter= (1) contents of where clause
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -25,7 +25,8 @@
@param [in] libds Two part dataset (or view) reference. @param [in] libds Two part dataset (or view) reference.
@param [in] var Variable name for which a format should be returned @param [in] var Variable name for which a format should be returned
@param [in] force=(0) Set to 1 to supply a default if the variable has no format @param [in] force= (0) Set to 1 to supply a default if the variable has no
format
@returns outputs format @returns outputs format
@author Allan Bowe @author Allan Bowe

View File

@@ -18,8 +18,8 @@
8 8
NOTE: Variable renegade does not exist in test NOTE: Variable renegade does not exist in test
@param libds Two part dataset (or view) reference. @param [in] libds Two part dataset (or view) reference.
@param var Variable name for which a length should be returned @param [in] var Variable name for which a length should be returned
@returns outputs length @returns outputs length
@author Allan Bowe @author Allan Bowe

View File

@@ -21,8 +21,8 @@ returns:
> NOTE: Variable renegade does not exist in test > NOTE: Variable renegade does not exist in test
@param libds Two part dataset (or view) reference. @param [in] libds Two part dataset (or view) reference.
@param var Variable name for which a position should be returned @param [in] var Variable name for which a position should be returned
@author Allan Bowe @author Allan Bowe
@version 9.2 @version 9.2

View File

@@ -13,8 +13,8 @@ Usage:
@param libds Two part dataset (or view) reference. @param [in] libds Two part dataset (or view) reference.
@param var the variable name to be checked @param [in] var the variable name to be checked
@return output returns C or N depending on variable type. If variable @return output returns C or N depending on variable type. If variable
does not exist then a blank is returned and a note is written to the log. does not exist then a blank is returned and a note is written to the log.

View File

@@ -10,7 +10,7 @@
returns: returns:
> TEMP > TEMP
@param fref The fileref to check @param [in] fref The fileref to check
@returns The XENGINE value in sashelp.vextfl or 0 if not found. @returns The XENGINE value in sashelp.vextfl or 0 if not found.

View File

@@ -11,8 +11,8 @@
%put Now we have run %mf_increment(cnt) lines; %put Now we have run %mf_increment(cnt) lines;
%put There are %mf_increment(cnt) lines in total; %put There are %mf_increment(cnt) lines in total;
@param [in] MACRO_NAME the name of the macro variable to increment @param [in] macro_name The name of the macro variable to increment
@param [in] ITER= The amount to add or subtract to the macro @param [in] incr= (1) The amount to add or subtract to the macro
<h4> Related Files </h4> <h4> Related Files </h4>
@li mf_increment.test.sas @li mf_increment.test.sas

View File

@@ -12,7 +12,7 @@
inspiration: inspiration:
https://support.sas.com/resources/papers/proceedings09/022-2009.pdf https://support.sas.com/resources/papers/proceedings09/022-2009.pdf
@param param VALUE to be checked @param [in] Param VALUE to be checked
@return output returns 1 (if blank) else 0 @return output returns 1 (if blank) else 0

View File

@@ -9,7 +9,7 @@
With thanks and full credit to Andrea Defronzo - With thanks and full credit to Andrea Defronzo -
https://www.linkedin.com/in/andrea-defronzo-b1a47460/ https://www.linkedin.com/in/andrea-defronzo-b1a47460/
@param path full path of the file/directory to be checked @param [in] path Full path of the file/directory to be checked
@return output returns 1 if path is a directory, 0 if it is not @return output returns 1 if path is a directory, 0 if it is not

View File

@@ -6,6 +6,10 @@
%put %mf_loc(POF); %*location of PlatformObjectFramework tools; %put %mf_loc(POF); %*location of PlatformObjectFramework tools;
@param [in] loc The item to locate, eg:
@li PLAATFORMOBJECTFRAMEWORK (or POF)
@li VIYACONFG
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe
**/ **/
@@ -15,7 +19,8 @@
%local root; %local root;
%if &loc=POF or &loc=PLATFORMOBJECTFRAMEWORK %then %do; %if &loc=POF or &loc=PLATFORMOBJECTFRAMEWORK %then %do;
%let root=%substr(%sysget(SASROOT),1,%index(%sysget(SASROOT),SASFoundation)-2); %let root=%sysget(SASROOT);
%let root=%substr(&root,1,%index(&root,SASFoundation)-2);
%let root=&root/SASPlatformObjectFramework/&sysver; %let root=&root/SASPlatformObjectFramework/&sysver;
%put Batch tools located at: &root; %put Batch tools located at: &root;
&root &root

View File

@@ -7,7 +7,7 @@ Usage:
%mf_mkdir(/some/path/name) %mf_mkdir(/some/path/name)
@param dir relative or absolute pathname. Unquoted. @param [in] dir Relative or absolute pathname. Unquoted.
@version 9.2 @version 9.2
**/ **/

View File

@@ -8,6 +8,8 @@
%if %mf_mval(maynotexist)=itdid %then %do; %if %mf_mval(maynotexist)=itdid %then %do;
@param [in] var The macro variable NAME to return the (possible) value for
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe
**/ **/

View File

@@ -9,7 +9,7 @@
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_getattrn.sas @li mf_getattrn.sas
@param libds library.dataset @param [in] libds library.dataset
@return output returns result of the attrn value supplied, or log message @return output returns result of the attrn value supplied, or log message
if err. if err.

View File

@@ -11,8 +11,8 @@
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@param basestr The string to be modified @param [in] basestr The string to be modified
@param trimstr The string to be removed from the end of `basestr`, if it @param [in] trimstr The string to be removed from the end of `basestr`, if it
exists exists
@return output returns result with the value of `trimstr` removed from the end @return output returns result with the value of `trimstr` removed from the end

View File

@@ -13,8 +13,8 @@
returns: returns:
> blah blaaah brah > blah blaaah brah
@param str1= string containing words to extract @param [in] str1= () string containing words to extract
@param str2= used to compare with the extract string @param [in] str2= () used to compare with the extract string
@warning CASE SENSITIVE! @warning CASE SENSITIVE!

View File

@@ -16,8 +16,8 @@
returns: returns:
> sss bram boo > sss bram boo
@param [in] str1= string containing words to extract @param [in] str1= () String containing words to extract
@param [in] str2= used to compare with the extract string @param [in] str2= () Used to compare with the extract string
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -21,8 +21,8 @@
@param [in] mode= (O) Available options are A or O as follows: @param [in] mode= (O) Available options are A or O as follows:
@li A APPEND mode, writes new records after the current end of the file. @li A APPEND mode, writes new records after the current end of the file.
@li O OUTPUT mode, writes new records from the beginning of the file. @li O OUTPUT mode, writes new records from the beginning of the file.
@param [in] l1= First line @param [in] l1= () First line
@param [in] l2= Second line (etc through to l10) @param [in] l2= () Second line (etc through to l10)
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mf_writefile.test.sas @li mf_writefile.test.sas

View File

@@ -27,14 +27,15 @@
currently investigating approaches to deal with this. currently investigating approaches to deal with this.
@param mac= (mp_abort.sas) To contain the name of the calling macro. Do not @param [in] mac= (mp_abort.sas) To contain the name of the calling macro. Do
use &sysmacroname as this will always resolve to MP_ABORT. not use &sysmacroname as this will always resolve to MP_ABORT.
@param msg= message to be returned @param [out] msg= message to be returned
@param iftrue= (1=1) Supply a condition for which the macro should be executed @param [in] iftrue= (1=1) Condition under which the macro should be executed
@param errds= (work.mp_abort_errds) There is no clean way to end a process @param [in] errds= (work.mp_abort_errds) There is no clean way to end a
within a %include called within a macro. Furthermore, there is no way to process within a %include called within a macro. Furthermore, there is no
test if a macro is called within a %include. To handle this particular way to test if a macro is called within a %include. To handle this
scenario, the %include should be switched for the mp_include.sas macro. particular scenario, the %include should be switched for the mp_include.sas
macro.
This provides an indicator that we are running a macro within a \%include This provides an indicator that we are running a macro within a \%include
(`_SYSINCLUDEFILEDEVICE`) and allows us to provide a dataset with the abort (`_SYSINCLUDEFILEDEVICE`) and allows us to provide a dataset with the abort
values (msg, mac). values (msg, mac).
@@ -45,8 +46,8 @@
@li msg (the message) @li msg (the message)
@li mac (the mac param) @li mac (the mac param)
@param mode= (REGULAR) If mode=INCLUDE then the &errds dataset is checked for @param [in] mode= (REGULAR) If mode=INCLUDE then the &errds dataset is checked
an abort status. for an abort status.
Valid values: Valid values:
@li REGULAR (default) @li REGULAR (default)
@li INCLUDE @li INCLUDE

View File

@@ -62,8 +62,8 @@
7998580.8415 7998580.8415
@param var The (data step, character) variable to modify @param [in] var The (data step, character) variable to modify
@param width= (8) The number of characters BEFORE the decimal point @param [in] width= (8) The number of characters BEFORE the decimal point
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_getuniquename.sas @li mf_getuniquename.sas

View File

@@ -17,8 +17,8 @@
%mp_appendfile(baseref=tmp1, appendrefs=tmp2 tmp3) %mp_appendfile(baseref=tmp1, appendrefs=tmp2 tmp3)
@param [in] baseref= Fileref of the base file (should exist) @param [in] baseref= (0) Fileref of the base file (should exist)
@param [in] appendrefs= One or more filerefs to be appended to the base @param [in] appendrefs= (0) One or more filerefs to be appended to the base
fileref. Space separated. fileref. Space separated.
@version 9.2 @version 9.2

View File

@@ -94,7 +94,7 @@ data &outds;
if libref(lib) ne 0 then do; if libref(lib) ne 0 then do;
msg=catx(' ','libref',lib,'is not assigned!'); msg=catx(' ','libref',lib,'is not assigned!');
%if &errds=0 %then %do; %if &errds=0 %then %do;
putlog "%str(ERR)OR: " msg; putlog 'ERR' +(-1) "OR: " msg;
%end; %end;
output; output;
return; return;
@@ -102,7 +102,7 @@ data &outds;
if exist(cats(lib,'.',ds)) ne 1 then do; if exist(cats(lib,'.',ds)) ne 1 then do;
msg=catx(' ','libds',lib,'.',ds,'does not exist!'); msg=catx(' ','libds',lib,'.',ds,'does not exist!');
%if &errds=0 %then %do; %if &errds=0 %then %do;
putlog "%str(ERR)OR: " msg; putlog 'ERR' +(-1) "OR: " msg;
%end; %end;
output; output;
return; return;
@@ -111,7 +111,7 @@ data &outds;
if is_fmt=0 then do; if is_fmt=0 then do;
msg=catx(' ','format',fmt,'on libds',lib,'.',ds,'.',var,'is not valid!'); msg=catx(' ','format',fmt,'on libds',lib,'.',ds,'.',var,'is not valid!');
%if &errds=0 %then %do; %if &errds=0 %then %do;
putlog "%str(ERR)OR: " msg; putlog 'ERR' +(-1) "OR: " msg;
%end; %end;
output; output;
return; return;
@@ -123,7 +123,7 @@ data &outds;
if dsid=0 then do; if dsid=0 then do;
msg=catx(' ','libds',lib,'.',ds,' could not be opened!'); msg=catx(' ','libds',lib,'.',ds,' could not be opened!');
%if &errds=0 %then %do; %if &errds=0 %then %do;
putlog "%str(ERR)OR: " msg; putlog 'ERR' +(-1) "OR: " msg;
%end; %end;
output; output;
return; return;
@@ -131,7 +131,7 @@ data &outds;
if varnum(dsid,var)<1 then do; if varnum(dsid,var)<1 then do;
msg=catx(' ','Variable',lib,'.',ds,'.',var,' was not found!'); msg=catx(' ','Variable',lib,'.',ds,'.',var,' was not found!');
%if &errds=0 %then %do; %if &errds=0 %then %do;
putlog "%str(ERR)OR: " msg; putlog 'ERR' +(-1) "OR: " msg;
%end; %end;
output; output;
end; end;

View File

@@ -31,8 +31,8 @@
@param [in] inds The input library.dataset to test for values @param [in] inds The input library.dataset to test for values
@param [in] cols= The list of columns to check for @param [in] cols= (0) The list of columns to check for
@param [in] desc= (Testing observations) The user provided test description @param [in] desc= (0) The user provided test description
@param [in] test= (ALL) The test to apply. Valid values are: @param [in] test= (ALL) The test to apply. Valid values are:
@li ALL - Test is a PASS if ALL columns exist in &inds @li ALL - Test is a PASS if ALL columns exist in &inds
@li ANY - Test is a PASS if ANY of the columns exist in &inds @li ANY - Test is a PASS if ANY of the columns exist in &inds

View File

@@ -36,7 +36,7 @@
@param [in] indscol The input library.dataset.column to test for values @param [in] indscol The input library.dataset.column to test for values
@param [in] checkvals= A library.dataset.column value containing a UNIQUE @param [in] checkvals= (0) A library.dataset.column value containing a UNIQUE
list of values to be compared against the source (indscol). list of values to be compared against the source (indscol).
@param [in] desc= (Testing observations) The user provided test description @param [in] desc= (Testing observations) The user provided test description
@param [in] test= (ALLVALS) The test to apply. Valid values are: @param [in] test= (ALLVALS) The test to apply. Valid values are:

View File

@@ -28,8 +28,8 @@
put _infile_; put _infile_;
run; run;
@param [in] inref= Fileref of the input file (should exist) @param [in] inref= (0) Fileref of the input file (should exist)
@param [out] outref= Output fileref. If it does not exist, it is created. @param [out] outref= (0) Output fileref. If it does not exist, it is created.
@param [in] action= (ENCODE) The action to take. Valid values: @param [in] action= (ENCODE) The action to take. Valid values:
@li ENCODE - Convert the file to base64 format @li ENCODE - Convert the file to base64 format
@li DECODE - Decode the file from base64 format @li DECODE - Decode the file from base64 format

View File

@@ -22,16 +22,17 @@
%mp_binarycopy(inref=tmp1, outref=tmp2, mode=APPEND) %mp_binarycopy(inref=tmp1, outref=tmp2, mode=APPEND)
@param [in] inloc quoted "path/and/filename.ext" of the file to be copied @param [in] inloc= () quoted "path/and/filename.ext" of the file to be copied
@param [out] outloc quoted "path/and/filename.ext" of the file to be created @param [out] outloc= () quoted "path/and/filename.ext" of the file to create
@param [in] inref (____in) If provided, this fileref will take precedence over @param [in] inref= (____in) If provided, this fileref takes precedence over
the `inloc` parameter the `inloc` parameter
@param [out] outref (____in) If provided, this fileref will take precedence @param [out] outref= (____in) If provided, this fileref takes precedence
over the `outloc` parameter. It must already exist! over the `outloc` parameter. It must already exist!
@param [in] mode (CREATE) Valid values: @param [in] mode= (CREATE) Valid values:
@li CREATE - Create the file (even if it already exists) @li CREATE - Create the file (even if it already exists)
@li APPEND - Append to the file (don't overwrite) @li APPEND - Append to the file (don't overwrite)
@param iftrue= (1=1) Supply a condition for which the macro should be executed @param [in] iftrue= (1=1)
Supply a condition for which the macro should be executed
@returns nothing @returns nothing

View File

@@ -44,7 +44,7 @@
For more examples, see mp_chop.test.sas For more examples, see mp_chop.test.sas
@param [in] infile The QUOTED path to the file on which to perform the chop @param [in] infile The QUOTED path to the file on which to perform the chop
@param [in] matchvar= Macro variable NAME containing the string to split by @param [in] matchvar= () Macro variable NAME containing the string to split by
@param [in] matchpoint= (START) Valid values: @param [in] matchpoint= (START) Valid values:
@li START - chop at the beginning of the string in `matchvar`. @li START - chop at the beginning of the string in `matchvar`.
@li END - chop at the end of the string in `matchvar`. @li END - chop at the end of the string in `matchvar`.
@@ -54,7 +54,8 @@
@li FIRST - keep the section of the file before the chop @li FIRST - keep the section of the file before the chop
@li LAST - keep the section of the file after the chop @li LAST - keep the section of the file after the chop
@param [in] mdebug= (0) Set to 1 to provide macro debugging @param [in] mdebug= (0) Set to 1 to provide macro debugging
@param outfile= (0) Optional QUOTED path to the adjusted output file (avoids @param [out] outfile= (0)
Optional QUOTED path to the adjusted output file (avoids
overwriting the first file). overwriting the first file).
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@@ -185,7 +186,7 @@ run;
infile &outfile lrecl=32767; infile &outfile lrecl=32767;
input; input;
list; list;
if _n_>50 then stop; if _n_>200 then stop;
run; run;
%end; %end;
/* END */ /* END */

View File

@@ -12,11 +12,12 @@
fileref mycsv "/path/your/csv"; fileref mycsv "/path/your/csv";
%mp_cleancsv(in=mycsv,out=/path/new.csv) %mp_cleancsv(in=mycsv,out=/path/new.csv)
@param in= (NOTPROVIDED) Provide path or fileref to input csv. If a period is @param [in] in= (NOTPROVIDED)
Provide path or fileref to input csv. If a period is
found, it is assumed to be a file. found, it is assumed to be a file.
@param out= (NOTPROVIDED) Output path or fileref to output csv. If a period @param [in] out= (NOTPROVIDED) Output path or fileref to output csv.
is found, it is assumed to be a file. If a period is found, it is assumed to be a file.
@param qchar= ('22'x) Quote char - hex code 22 is the double quote. @param [in] qchar= ('22'x) Quote char - hex code 22 is the double quote.
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -58,9 +58,9 @@
%end; %end;
proc format lib=&libcat cntlout=&cntlds; proc format lib=&libcat cntlout=&cntlds;
%if "&fmtlist" ne "0" %then %do; %if "&fmtlist" ne "0" and "&fmtlist" ne "" %then %do;
select select
%do i=1 %to %sysfunc(countw(&fmtlist)); %do i=1 %to %sysfunc(countw(&fmtlist,%str( )));
%scan(&fmtlist,&i,%str( )) %scan(&fmtlist,&i,%str( ))
%end; %end;
; ;

View File

@@ -18,7 +18,7 @@
@param [in] source Unquoted path to the folder to copy from. @param [in] source Unquoted path to the folder to copy from.
@param [out] target Unquoted path to the folder to copy to. @param [out] target Unquoted path to the folder to copy to.
@param [in] copymax=(MAX) Set to a positive integer to indicate the level of @param [in] copymax= (MAX) Set to a positive integer to indicate the level of
subdirectory copy recursion - eg 3, to go `./3/levels/deep`. For unlimited subdirectory copy recursion - eg 3, to go `./3/levels/deep`. For unlimited
recursion, set to MAX. recursion, set to MAX.
@@ -69,7 +69,7 @@
rc2=filename(fref2,filepath2,'disk','recfm=n'); rc2=filename(fref2,filepath2,'disk','recfm=n');
if fcopy(fref1,fref2) ne 0 then do; if fcopy(fref1,fref2) ne 0 then do;
msg=sysmsg(); msg=sysmsg();
putlog "%str(ERR)OR: Unable to copy " filepath " to " filepath2; putlog 'ERR' +(-1) "OR: Unable to copy " filepath " to " filepath2;
putlog msg=; putlog msg=;
end; end;
end; end;

View File

@@ -18,11 +18,11 @@
%mp_deleteconstraints(inds=work.constraints,outds=dropped,execute=YES) %mp_deleteconstraints(inds=work.constraints,outds=dropped,execute=YES)
%mp_createconstraints(inds=work.constraints,outds=created,execute=YES) %mp_createconstraints(inds=work.constraints,outds=created,execute=YES)
@param inds= (work.mp_getconstraints) The input table containing the @param [in] inds= (work.mp_getconstraints) The input table containing the
constraint info constraint info
@param outds= (work.mp_createconstraints) A table containing the create @param [out] outds= (work.mp_createconstraints) A table containing the create
statements (create_statement column) statements (create_statement column)
@param execute= (NO) To actually create, use YES. @param [in] execute= (NO) To actually create, use YES.
<h4> Related Files </h4> <h4> Related Files </h4>
@li mp_getconstraints.sas @li mp_getconstraints.sas

View File

@@ -1,6 +1,6 @@
/** /**
@file mp_createwebservice.sas @file mp_createwebservice.sas
@brief Create a web service in SAS 9, Viya or SASjs Server @brief Create a web service in SAS 9, Viya or SASjs Server (legacy)
@details This is actually a wrapper for mx_createwebservice.sas, remaining @details This is actually a wrapper for mx_createwebservice.sas, remaining
for legacy purposes. For new apps, use mx_createwebservice.sas. for legacy purposes. For new apps, use mx_createwebservice.sas.

View File

@@ -19,11 +19,12 @@
%mp_csv2ds(inref=mycsv,outds=myds,baseds=sashelp.class) %mp_csv2ds(inref=mycsv,outds=myds,baseds=sashelp.class)
@param inref= fileref to the CSV @param [in] inref= (0) Fileref to the CSV
@param outds= output ds (lib.ds format) @param [out] outds= (0) Output ds (lib.ds format)
@param view= Set to YES or NO to determine whether the output should be @param [in] view= (NO) Set to YES or NO to determine whether the output
a view or not. Default is NO (not a view). should be a view or not. Default is NO (not a view).
@param baseds= Template dataset on which to create the input statement. @param [in] baseds= (0)
Template dataset on which to create the input statement.
Is used to determine types, lengths, and any informats. Is used to determine types, lengths, and any informats.
@version 9.2 @version 9.2

View File

@@ -17,9 +17,11 @@
%mp_getconstraints(lib=work,ds=example,outds=work.constraints) %mp_getconstraints(lib=work,ds=example,outds=work.constraints)
%mp_deleteconstraints(inds=work.constraints,outds=dropped,execute=YES) %mp_deleteconstraints(inds=work.constraints,outds=dropped,execute=YES)
@param inds= The input table containing the constraint info @param [in] inds= (mp_getconstraints)
@param outds= a table containing the drop statements (drop_statement column) The input table containing constraint info
@param execute= `YES|NO` - default is NO. To actually drop, use YES. @param [out] outds= (mp_deleteconstraints)
Table containing the drop statements (drop_statement column)
@param [in] execute= (NO) `YES|NO` - default is NO. To actually drop, use YES.
@version 9.2 @version 9.2

View File

@@ -15,7 +15,7 @@
%mp_deletefolder(&rootdir) %mp_deletefolder(&rootdir)
@param path Unquoted path to the folder to delete. @param [in] folder Unquoted path to the folder to delete.
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_getuniquename.sas @li mf_getuniquename.sas

View File

@@ -29,7 +29,7 @@
![](https://user-images.githubusercontent.com/4420615/188278365-2987db97-0594-4a39-ac81-dbacdef5cdc8.png) ![](https://user-images.githubusercontent.com/4420615/188278365-2987db97-0594-4a39-ac81-dbacdef5cdc8.png)
@param lib= (WORK) The libref in which to create the views @param [in] lib= (WORK) The libref in which to create the views
<h4> Related Files </h4> <h4> Related Files </h4>
@li mp_dictionary.test.sas @li mp_dictionary.test.sas

View File

@@ -7,11 +7,11 @@
%mp_distinctfmtvalues(libds=sashelp.class,var=age,outvar=age,outds=test) %mp_distinctfmtvalues(libds=sashelp.class,var=age,outvar=age,outds=test)
@param libds input dataset @param [in] libds= () input dataset
@param var variable to get distinct values for @param [in] var= (0) variable to get distinct values for
@param outvar variable to create. Default: `formatted_value` @param [out] outvar= (formatteed_value) variable to create.
@param outds dataset to create. Default: work.mp_distinctfmtvalues @param [out] outds= (work.mp_distinctfmtvalues) dataset to create.
@param varlen length of variable to create (default 200) @param [in] varlen= (2000) length of variable to create
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -1,8 +1,20 @@
/** /**
@file @file
@brief A wrapper for mp_getddl.sas @brief Fetches DDL for a specific table
@details In the next release, this will be the main version. @details Uses mp_getddl under the hood
@param [in] libds library.dataset to create ddl for
@param [in] fref= (getddl) the fileref to which to _append_ the DDL. If it
does not exist, it will be created.
@param [in] flavour= (SAS) The type of DDL to create. Options:
@li SAS
@li TSQL
@param [in]showlog= (NO) Set to YES to show the DDL in the log
@param [in] schema= () Choose a preferred schema name (default is to use
actual schema, else libref)
@param [in] applydttm= (NO) For non SAS DDL, choose if columns are created with
native datetime2 format or regular decimal type
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mp_getddl.sas @li mp_getddl.sas

View File

@@ -49,8 +49,8 @@
https://support.sas.com/resources/papers/proceedings14/1549-2014.pdf) by https://support.sas.com/resources/papers/proceedings14/1549-2014.pdf) by
[Louise Hadden](https://www.linkedin.com/in/louisehadden/). [Louise Hadden](https://www.linkedin.com/in/louisehadden/).
@param libds The library.dataset to export the metadata for @param [in] libds The library.dataset to export the metadata for
@param outds= (work.dsmeta) The output table to contain the metadata @param [out] outds= (work.dsmeta) The output table to contain the metadata
<h4> Related Files </h4> <h4> Related Files </h4>
@li mp_dsmeta.test.sas @li mp_dsmeta.test.sas

View File

@@ -37,10 +37,12 @@
@param [in] targetds= The target dataset against which to verify VARIABLE_NM. @param [in] targetds= The target dataset against which to verify VARIABLE_NM.
This must be available (ie, the library must be assigned). This must be available (ie, the library must be assigned).
@param [out] abort= (YES) If YES will call mp_abort.sas on any exceptions @param [out] abort= (YES) If YES will call mp_abort.sas on any exceptions
@param [out] outds= The output table, which is a copy of the &inds. table @param [out] outds= (work.badrecords) The output table, which is a copy of the
plus a REASON_CD column, containing only bad records. If bad records found, &inds. table plus a REASON_CD column, containing only bad records.
the SYSCC value will be set to 1008 (general data problem). Downstream If bad records are found, the SYSCC value will be set to 1008
processes should check this table (and return code) before continuing. (a general data problem).
Downstream processes should check this table (and return code) before
continuing.
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mp_abort.sas @li mp_abort.sas

View File

@@ -51,8 +51,8 @@
> ) > )
@param [in] inds The input table with query values @param [in] inds The input table with query values
@param [out] outref= The output fileref to contain the filter clause. Will @param [out] outref= (filter) The output fileref to contain the filter clause.
be created (or replaced). Will be created (or replaced).
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mp_filtercheck.sas @li mp_filtercheck.sas

View File

@@ -44,9 +44,10 @@
mp_coretable.sas as follows: `mp_coretable(LOCKTABLE)`. mp_coretable.sas as follows: `mp_coretable(LOCKTABLE)`.
@param [in] maxkeytable= (0) Optional permanent reference table used for @param [in] maxkeytable= (0) Optional permanent reference table used for
retained key tracking. Described in mp_retainedkey.sas. retained key tracking. Described in mp_retainedkey.sas.
@param [in] mdebug= set to 1 to enable DEBUG messages @param [in] mdebug= (1) set to 1 to enable DEBUG messages
@param [out] outresult= The result table with the FILTER_RK @param [out] outresult= (work.result) The result table with the FILTER_RK
@param [out] outquery= The original query, taken as extract after table load @param [out] outquery= (work.query) The original query, taken as extract
after table load
<h4> SAS Macros </h4> <h4> SAS Macros </h4>

View File

@@ -12,14 +12,15 @@
%mp_getcols(sashelp.airline,outds=work.myds) %mp_getcols(sashelp.airline,outds=work.myds)
@param ds The dataset from which to obtain column metadata @param [in] ds The dataset from which to obtain column metadata
@param outds= (work.cols) The output dataset to create. Sample data: @param [out] outds= (work.cols) The output dataset to create. Sample data:
|NAME:$32.|LENGTH:best.|VARNUM:best.|LABEL:$256.|FMTNAME:$32.|FORMAT:$49.|TYPE:$1.|DDTYPE:$9.| |NAME:$32.|LENGTH:best.|VARNUM:best.|LABEL:$256.|FMTNAME:$32.|FORMAT:$49.|TYPE:$1.|DDTYPE:$9.|
|---|---|---|---|---|---|---|---| |---|---|---|---|---|---|---|---|
|`AIR `|`8 `|`2 `|`international airline travel (thousands) `|` `|`8. `|`N `|`NUMERIC `| |`AIR `|`8 `|`2 `|`international airline travel (thousands) `|` `|`8. `|`N `|`NUMERIC `|
|`DATE `|`8 `|`1 `|`DATE `|`MONYY `|`MONYY. `|`N `|`DATE `| |`DATE `|`8 `|`1 `|`DATE `|`MONYY `|`MONYY. `|`N `|`DATE `|
|`REGION `|`3 `|`3 `|`REGION `|` `|`$3. `|`C `|`CHARACTER `| |`REGION `|`3 `|`3 `|`REGION `|` `|`$3. `|`C `|`CHARACTER `|
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mf_getvarlist.sas @li mf_getvarlist.sas
@li mm_getcols.sas @li mm_getcols.sas

View File

@@ -23,10 +23,10 @@
@li mf_getquotedstr.sas @li mf_getquotedstr.sas
@li mp_getconstraints.sas @li mp_getconstraints.sas
@param liblist= Space seperated list of librefs to take as @param [in] liblist= (SASHELP) Space seperated list of librefs to take as
input (Default=SASHELP) input
@param outref= Fileref to contain the DBML (Default=getdbml) @param [out] outref= (getdbml) Fileref to contain the DBML
@param showlog= set to YES to show the DBML in the log (Default is NO) @param [in] showlog= (NO) set to YES to show the DBML in the log
@version 9.3 @version 9.3
@author Allan Bowe @author Allan Bowe

View File

@@ -22,16 +22,21 @@
@li mf_getvarcount.sas @li mf_getvarcount.sas
@li mp_getconstraints.sas @li mp_getconstraints.sas
@param lib libref of the library to create DDL for. Should be assigned. @param [in] libref Libref of the library to create DDL for. Should already
@param ds dataset to create ddl for (optional) be assigned.
@param fref= the fileref to which to _append_ the DDL. If it does not exist, @param [in] ds dataset to create ddl for (optional)
it will be created. @param [in] fref= (getddl) the fileref to which to _append_ the DDL. If it
@param flavour= The type of DDL to create (default=SAS). Supported=TSQL does not exist, it will be created.
@param showlog= Set to YES to show the DDL in the log @param [in] flavour= (SAS) The type of DDL to create. Options:
@param schema= Choose a preferred schema name (default is to use actual schema @li SAS
,else libref) @li TSQL
@param applydttm= for non SAS DDL, choose if columns are created with native
datetime2 format or regular decimal type @param [in]showlog= (NO) Set to YES to show the DDL in the log
@param [in] schema= () Choose a preferred schema name (default is to use
actual schema, else libref)
@param [in] applydttm= (NO) For non SAS DDL, choose if columns are created
with native datetime2 format or regular decimal type
@version 9.3 @version 9.3
@author Allan Bowe @author Allan Bowe
**/ **/

View File

@@ -7,10 +7,15 @@
Formats are taken from the library / dataset reference and / or a static Formats are taken from the library / dataset reference and / or a static
format list. format list.
Note - the source for this information is the dictionary.formats table. This
cannot show formats that are not already declared in the FMTSEARCH path.
Example usage: Example usage:
%mp_getformats(lib=sashelp,ds=prdsale,outsummary=work.dictable) %mp_getformats(lib=sashelp,ds=prdsale,outsummary=work.dictable)
%mp_getformats(fmtlist=FORMAT1 $FORMAT2 @INFMT3,outsummary=work.table2)
@param [in] lib= (0) The libref for which to return formats. @param [in] lib= (0) The libref for which to return formats.
@todo Enable exporting of formats for an entire library @todo Enable exporting of formats for an entire library
@param [in] ds= (0) The dataset from which to obtain format definitions @param [in] ds= (0) The dataset from which to obtain format definitions
@@ -49,7 +54,9 @@ https://support.sas.com/documentation/cdl/en/proc/61895/HTML/default/viewer.htm#
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mf_getfmtlist.sas
@li mp_applyformats.sas @li mp_applyformats.sas
@li mp_cntlout.sas
@li mp_getformats.test.sas @li mp_getformats.test.sas
@version 9.2 @version 9.2
@@ -66,7 +73,7 @@ https://support.sas.com/documentation/cdl/en/proc/61895/HTML/default/viewer.htm#
%local i fmt allfmts tempds fmtcnt; %local i fmt allfmts tempds fmtcnt;
%if "&fmtlist" ne "0" %then %do i=1 %to %sysfunc(countw(&fmtlist,,%str( ))); %if "&fmtlist" ne "0" %then %do i=1 %to %sysfunc(countw(&fmtlist,%str( )));
/* ensure format list contains format _name_ only */ /* ensure format list contains format _name_ only */
%let fmt=%scan(&fmtlist,&i,%str( )); %let fmt=%scan(&fmtlist,&i,%str( ));
%let fmt=%mf_getfmtname(&fmt); %let fmt=%mf_getfmtname(&fmt);
@@ -90,8 +97,7 @@ https://support.sas.com/documentation/cdl/en/proc/61895/HTML/default/viewer.htm#
proc sql; proc sql;
create table &outsummary as create table &outsummary as
select * from dictionary.formats select * from dictionary.formats
where fmtname in (%mf_getquotedstr(&allfmts,quote=D)) where fmtname in (%mf_getquotedstr(&allfmts,quote=D));
and fmttype='F';
%if "&outdetail" ne "0" %then %do; %if "&outdetail" ne "0" %then %do;
/* ensure base table always exists */ /* ensure base table always exists */
@@ -115,6 +121,10 @@ create table &outsummary as
data &tempds; data &tempds;
if 0 then set &outdetail; if 0 then set &outdetail;
set &tempds; set &tempds;
/* set fmtrow (position of record within the format) */
by type fmtname notsorted;
if first.fmtname then fmtrow=1;
else fmtrow+1;
run; run;
proc append base=&outdetail data=&tempds ; proc append base=&outdetail data=&tempds ;
run; run;

View File

@@ -22,15 +22,15 @@
list; list;
run; run;
@param file= (0) The file to perform the substitution on @param [in] file= (0) The file to perform the substitution on
@param patternvar= A macro variable containing the Lua @param [in] patternvar= A macro variable containing the Lua
[pattern](https://www.lua.org/pil/20.2.html) to search for. Due to the use [pattern](https://www.lua.org/pil/20.2.html) to search for. Due to the use
of special (magic) characters in Lua patterns, it is safer to pass the NAME of special (magic) characters in Lua patterns, it is safer to pass the NAME
of the macro variable containing the string, rather than the value itself. of the macro variable containing the string, rather than the value itself.
@param replacevar= The name of the macro variable containing the replacement @param [in] replacevar= ()
_string_. The name of the macro variable containing the replacement _string_.
@param outfile= (0) The file to write the output to. If zero, then the file @param [out] outfile= (0) The file to write the output to.
is overwritten in-place. If zero, then the file is overwritten in-place.
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li ml_gsubfile.sas @li ml_gsubfile.sas

View File

@@ -18,7 +18,7 @@
%mp_guesspk(sashelp.class,outds=classpks) %mp_guesspk(sashelp.class,outds=classpks)
@param [in] baseds The dataset to analyse @param [in] baseds The dataset to analyse
@param [out] outds= The output dataset to contain the possible PKs @param [out] outds= (mp_guesspk) Output dataset to contain the possible PKs
@param [in] max_guesses= (3) The total number of possible primary keys to @param [in] max_guesses= (3) The total number of possible primary keys to
generate. A table may have multiple (unlikely) PKs, so no need to list them generate. A table may have multiple (unlikely) PKs, so no need to list them
all. all.

View File

@@ -24,7 +24,7 @@
@li mp_hashdirectory.sas @li mp_hashdirectory.sas
@param [in] libds dataset to hash @param [in] libds dataset to hash
@param [in] salt= Provide a salt (could be, for instance, the dataset name) @param [in] salt= () Provide a salt (could be, for instance, the dataset name)
@param [in] iftrue= (1=1) A condition under which the macro should be executed @param [in] iftrue= (1=1) A condition under which the macro should be executed
@param [out] outds= (work._data_) The output dataset to create. This @param [out] outds= (work._data_) The output dataset to create. This
will contain one column (hashkey) with one observation (a $hex32. will contain one column (hashkey) with one observation (a $hex32.

View File

@@ -24,19 +24,19 @@
@li mf_trimstr.sas @li mf_trimstr.sas
@li mp_ds2cards.sas @li mp_ds2cards.sas
@param [in] lib= Library in which to convert all datasets @param [in] lib= () Library in which to convert all datasets
@param [out] outloc= Location in which to store output. Defaults to WORK @param [out] outloc= (%sysfunc(pathname(work))) Location in which to store
library. No quotes. output. No quotes.
@param [out] outfile= Optional output file NAME - if provided, then will create @param [out] outfile= (0) Optional output file NAME - if provided, then
a single output file instead of one file per input table. will create a single output file instead of one file per input table.
@param [in] maxobs= limit output to the first <code>maxobs</code> observations @param [in] maxobs= (max) limit output to the first <code>maxobs</code> rows
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe
**/ **/
%macro mp_lib2cards(lib= %macro mp_lib2cards(lib=
,outloc=%sysfunc(pathname(work)) /* without trailing slash */ ,outloc=%sysfunc(pathname(work))
,maxobs=max ,maxobs=max
,random_sample=NO ,random_sample=NO
,outfile=0 ,outfile=0

View File

@@ -68,7 +68,7 @@
); );
/* set up local macro variables and temporary tables (with a prefix) */ /* set up local macro variables and temporary tables (with a prefix) */
%local err msg prefix dslist i var fmtlist ibufsize; %local err msg prefix dslist i var fmtlist ibufsize;
%let dslist=base_fmts template inlibds ds1 stagedata storediffs; %let dslist=base_fmts template inlibds ds1 stagedata storediffs del1 del2;
%if &outds_add=0 %then %let dslist=&dslist outds_add; %if &outds_add=0 %then %let dslist=&dslist outds_add;
%if &outds_del=0 %then %let dslist=&dslist outds_del; %if &outds_del=0 %then %let dslist=&dslist outds_del;
%if &outds_mod=0 %then %let dslist=&dslist outds_mod; %if &outds_mod=0 %then %let dslist=&dslist outds_mod;
@@ -199,6 +199,18 @@ create table &outds_add(drop=&delete_col) as
and upcase(a.&delete_col) ne "YES" and upcase(a.&delete_col) ne "YES"
order by type, fmtname, fmtrow; order by type, fmtname, fmtrow;
/**
* Identify modified records
*/
create table &outds_mod (drop=&delete_col) as
select a.*
from &inlibds a
inner join &base_fmts b
on a.type=b.type and a.fmtname=b.fmtname and a.fmtrow=b.fmtrow
where upcase(a.&delete_col) ne "YES"
and a.fmthash ne b.fmthash
order by type, fmtname, fmtrow;
/** /**
* Identify deleted records * Identify deleted records
*/ */
@@ -211,16 +223,23 @@ create table &outds_del(drop=&delete_col) as
order by type, fmtname, fmtrow; order by type, fmtname, fmtrow;
/** /**
* Identify modified records * Identify fully deleted formats (where every record is removed)
* These require to be explicitly deleted in proc format
* del1 - identify _partial_ deletes
* del2 - exclude these, and also formats that come with _additions_
*/ */
create table &outds_mod (drop=&delete_col) as create table &del1 as
select a.* select a.*
from &inlibds a from &base_fmts a
inner join &base_fmts b left join &outds_del b
on a.type=b.type and a.fmtname=b.fmtname and a.fmtrow=b.fmtrow on a.type=b.type and a.fmtname=b.fmtname and a.fmtrow=b.fmtrow
where upcase(a.&delete_col) ne "YES" where b.fmtrow is null;
and a.fmthash ne b.fmthash
order by type, fmtname, fmtrow; create table &del2 as
select * from &outds_del
where cats(type,fmtname) not in (select cats(type,fmtname) from &outds_add)
and cats(type,fmtname) not in (select cats(type,fmtname) from &del1);
%mp_abort( %mp_abort(
iftrue=(&syscc ne 0) iftrue=(&syscc ne 0)
@@ -253,7 +272,7 @@ create table &outds_mod (drop=&delete_col) as
,msg=%str(SYSCC=&syscc prior to actual load) ,msg=%str(SYSCC=&syscc prior to actual load)
) )
%if &loadtarget=YES %then %do; %if &loadtarget=YES %then %do;
%if %mf_nobs(&stagedata)=0 %then %do; %if %mf_nobs(&stagedata)=0 and %mf_nobs(&del2)=0 %then %do;
%put There are no changes to load in &libcat!; %put There are no changes to load in &libcat!;
%return; %return;
%end; %end;
@@ -269,6 +288,22 @@ create table &outds_mod (drop=&delete_col) as
/* do the actual load */ /* do the actual load */
proc format lib=&libcat cntlin=&stagedata; proc format lib=&libcat cntlin=&stagedata;
run; run;
/* apply any full deletes */
%if %mf_nobs(&del2)>0 %then %do;
%local delfmtlist;
proc sql noprint;
select distinct case when type='N' then cats(fmtname,'.FORMAT')
when type='C' then cats(fmtname,'.FORMATC')
when type='J' then cats(fmtname,'.INFMTC')
when type='I' then cats(fmtname,'.INFMT')
else cats(fmtname,'.BADENTRY!!!') end
into: delfmtlist
separated by ' '
from &del2;
proc catalog catalog=&libcat;
delete &delfmtlist;
quit;
%end;
%if &locklibds ne 0 %then %do; %if &locklibds ne 0 %then %do;
/* unlock the table */ /* unlock the table */
%mp_lockanytable(UNLOCK %mp_lockanytable(UNLOCK

View File

@@ -194,35 +194,39 @@ run;
%end; %end;
%end; %end;
%else %if &ACTION=UNLOCK %then %do; %else %if &ACTION=UNLOCK %then %do;
%local status; %local status cnt;
%let cnt=0;
proc sql noprint; proc sql noprint;
select LOCK_STATUS_CD into: status from &ctl_ds select count(*) into: cnt from &ctl_ds where LOCK_LIB ="&lib" & LOCK_DS="&ds";
where LOCK_LIB ="&lib" and LOCK_DS="&ds"; %if &cnt=0 %then %do;
quit; %put %str(WAR)NING: &lib..&ds was not previously locked in &ctl_ds!;
%if &syscc>0 %then %put syscc=&syscc sqlrc=&sqlrc;
%if &sqlobs=0 %then %do;
%put %str(WAR)NING: &lib..&ds has never been locked!;
%end;
%else %if &status=LOCKED %then %do;
data _null_;
putlog "&sysmacroname: unlocking &lib..&ds:";
run;
proc sql;
update &ctl_ds
set LOCK_STATUS_CD='UNLOCKED'
, LOCK_END_DTTM="%sysfunc(datetime(),%mf_fmtdttm())"dt
, LOCK_USER_NM="&user"
, LOCK_PID="&sysjobid"
, LOCK_REF="&ref"
where LOCK_LIB ="&lib" and LOCK_DS="&ds";
quit;
%end;
%else %if &status=UNLOCKED %then %do;
%put %str(WAR)NING: &lib..&ds is already unlocked!;
%end; %end;
%else %do; %else %do;
%put NOTE: Unrecognised STATUS_CD (&status) in &ctl_ds; select LOCK_STATUS_CD into: status from &ctl_ds
%let abortme=1; where LOCK_LIB ="&lib" and LOCK_DS="&ds";
quit;
%if &syscc>0 %then %put syscc=&syscc sqlrc=&sqlrc;
%if &status=LOCKED %then %do;
data _null_;
putlog "&sysmacroname: unlocking &lib..&ds:";
run;
proc sql;
update &ctl_ds
set LOCK_STATUS_CD='UNLOCKED'
, LOCK_END_DTTM="%sysfunc(datetime(),%mf_fmtdttm())"dt
, LOCK_USER_NM="&user"
, LOCK_PID="&sysjobid"
, LOCK_REF="&ref"
where LOCK_LIB ="&lib" and LOCK_DS="&ds";
quit;
%end;
%else %if &status=UNLOCKED %then %do;
%put %str(WAR)NING: &lib..&ds is already unlocked!;
%end;
%else %do;
%put NOTE: Unrecognised STATUS_CD (&status) in &ctl_ds;
%let abortme=1;
%end;
%end; %end;
%end; %end;
%else %do; %else %do;

View File

@@ -2,8 +2,7 @@
@file @file
@brief Generates an md5 expression for hashing a set of variables @brief Generates an md5 expression for hashing a set of variables
@details This is the same algorithm used to hash records in @details This is the same algorithm used to hash records in
[Data Controller for SAS](https://datacontroller.io) (free for up [Data Controller for SAS](https://datacontroller.io).
to 5 users).
It is not designed to be efficient - it is designed to be effective, It is not designed to be efficient - it is designed to be effective,
given the range of edge cases (large floating points, special missing given the range of edge cases (large floating points, special missing
@@ -29,8 +28,8 @@
@li Global option: `options dsoptions=nonote2err;` @li Global option: `options dsoptions=nonote2err;`
@li Data step option: `data YOURLIB.YOURDATASET /nonote2err;` @li Data step option: `data YOURLIB.YOURDATASET /nonote2err;`
@param cvars= Space seperated list of character variables @param [in] cvars= () Space seperated list of character variables
@param nvars= Space seperated list of numeric variables @param [in] nvars= () Space seperated list of numeric variables
<h4> Related Programs </h4> <h4> Related Programs </h4>
@li mp_init.sas @li mp_init.sas

View File

@@ -11,9 +11,9 @@
%mp_perflog(finished) %mp_perflog(finished)
@param label Provide label to go into the control dataset @param [in] label Provide label to go into the control dataset
@param libds= Provide a dataset in which to store performance stats. Default @param [in] libds= (work.mp_perflog) Provide a dataset in which to store
name is <code>work.mp_perflog</code>; performance stats. Default name is <code>work.mp_perflog</code>;
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -34,12 +34,12 @@
Credit is made to `data _null_` for authoring this very helpful paper: Credit is made to `data _null_` for authoring this very helpful paper:
https://www.lexjansen.com/pharmasug/2008/cc/CC08.pdf https://www.lexjansen.com/pharmasug/2008/cc/CC08.pdf
@param action Either FETCH a current or previous record, or INITialise. @param [in] action Either FETCH a current or previous record, or INITialise.
@param record The relative (to current) position of the previous observation @param [in] record The relative (to current) position of the previous row
to return. to return.
@param history= The number of records to retain in the hash table. Default=5 @param [in] history= (5) The number of records to retain in the hash table.
@param prefix= the prefix to give to the variables used to store the hash name @param [in] prefix= (mp_prevobs) The prefix to give to the variables used to
and index. Default=mp_prevobs store the hash name and index.
@version 9.2 @version 9.2
@author Allan Bowe @author Allan Bowe

View File

@@ -23,12 +23,13 @@
,childvar=c ,childvar=c
) )
@param base_ds= base table containing hierarchy (not modified) @param [in] base_ds= base table containing hierarchy (not modified)
@param outds= the output dataset to create with the generated hierarchy @param [out] outds= the output dataset to create with the generated hierarchy
@param matchval= the ultimate parent from which to filter @param [in] matchval= the ultimate parent from which to filter
@param parentvar= name of the parent variable @param [in] parentvar= name of the parent variable
@param childvar= name of the child variable (should be same type as parent) @param [in] childvar= () name of the child variable (should be same type as
@param mdebug= set to 1 to prevent temp tables being dropped parent)
@param [in] mdebug= set to 1 to prevent temp tables being dropped
@returns outds contains the following variables: @returns outds contains the following variables:

View File

@@ -32,10 +32,11 @@
Note - if you are running a version of SAS that will allow the io package in Note - if you are running a version of SAS that will allow the io package in
LUA, you can also use this macro: mp_gsubfile.sas LUA, you can also use this macro: mp_gsubfile.sas
@param infile The QUOTED path to the file on which to perform the substitution @param [in] infile The QUOTED path to the file on which to perform the
@param findvar= Macro variable NAME containing the string to search for substitution
@param replacevar= Macro variable NAME containing the replacement string @param [in] findvar= Macro variable NAME containing the string to search for
@param outfile= (0) Optional QUOTED path to the adjusted output file (to @param [in] replacevar= Macro variable NAME containing the replacement string
@param [out] outfile= (0) Optional QUOTED path to the adjusted output file (to
avoid overwriting the first file). avoid overwriting the first file).
<h4> SAS Macros </h4> <h4> SAS Macros </h4>

View File

@@ -31,9 +31,9 @@
%mp_runddl(/some/rootlib, exc=LIBREF3) * same as above ; %mp_runddl(/some/rootlib, exc=LIBREF3) * same as above ;
@param path location of the DDL folder structure @param [in] path location of the DDL folder structure
@param inc= list of librefs to include @param [in] inc= list of librefs to include
@param exc= list of librefs to exclude (takes precedence over inc=) @param [in] exc= list of librefs to exclude (takes precedence over inc=)
@version 9.3 @version 9.3
@author Allan Bowe @author Allan Bowe

View File

@@ -9,12 +9,13 @@
%mp_searchcols(libs=sashelp work, cols=name sex age) %mp_searchcols(libs=sashelp work, cols=name sex age)
@param libs=(SASHELP) Space separated list of libraries to search for columns @param [in] libs= (SASHELP)
@param cols= Space separated list of column names to search for (not case Space separated list of libraries to search for columns
sensitive) @param [in] cols=
@param outds=(mp_searchcols) the table to create with the results. Will have Space separated list of column names to search for (not case sensitive)
one line per table match. @param [out] outds= (mp_searchcols)
@param match=(ANY) The match type. Valid values: The table to create with the results. Will have one line per table match.
@param [in] match= (ANY) The match type. Valid values:
@li ANY - The table contains at least one of the columns @li ANY - The table contains at least one of the columns
@li WILD - The table contains a column with a name that partially matches @li WILD - The table contains a column with a name that partially matches

View File

@@ -6,8 +6,7 @@
data recovery, and change re-application. This macro is one of many data recovery, and change re-application. This macro is one of many
data management utilities used in [Data Controller for SAS]( data management utilities used in [Data Controller for SAS](
https:datacontroller.io) - a comprehensive data ingestion solution, which https:datacontroller.io) - a comprehensive data ingestion solution, which
works on any SAS platform (Viya, SAS 9, Foundation) and is free for up to 5 works on any SAS platform (Viya, SAS 9, Foundation).
users.
NOTE - this macro does not validate the inputs. It is assumed that the NOTE - this macro does not validate the inputs. It is assumed that the
datasets containing the new / changed / deleted rows are CORRECT, contain datasets containing the new / changed / deleted rows are CORRECT, contain
@@ -165,7 +164,7 @@ data &ds4;
if upcase(&inds_auto)="&ds2" then tgtvar_type='N'; if upcase(&inds_auto)="&ds2" then tgtvar_type='N';
else if upcase(&inds_auto)="&ds3" then tgtvar_type='C'; else if upcase(&inds_auto)="&ds3" then tgtvar_type='C';
else do; else do;
putlog "%str(ERR)OR: unidentified vartype input!" &inds_auto; putlog 'ERR' +(-1) "OR: unidentified vartype input!" &inds_auto;
call symputx('syscc',98); call symputx('syscc',98);
end; end;
@@ -174,7 +173,7 @@ data &ds4;
else if &inds_keep="&modds" then move_type='M'; else if &inds_keep="&modds" then move_type='M';
else if &inds_keep="&origds" then move_type='O'; else if &inds_keep="&origds" then move_type='O';
else do; else do;
putlog "%str(ERR)OR: unidentified movetype input!" &inds_keep; putlog 'ERR' +(-1) "OR: unidentified movetype input!" &inds_keep;
call symputx('syscc',99); call symputx('syscc',99);
end; end;
tgtvar_nm=upcase(tgtvar_nm); tgtvar_nm=upcase(tgtvar_nm);

View File

@@ -21,9 +21,10 @@
%mp_stprequests(status_cd=INIT, libds=YOURLIB.DATASET ) %mp_stprequests(status_cd=INIT, libds=YOURLIB.DATASET )
@param status_cd= Use INIT for INIT and TERM for TERM events @param [in] status_cd= Use INIT for INIT and TERM for TERM events
@param libds= Location of base table (library.dataset). To minimise risk @param [in] libds= (somelib.stp_requests) Location of base table
of table locks, we HIGHLY recommend using a database (NOT a SAS dataset). (library.dataset). To minimise risk of table locks, we HIGHLY recommend
using a database (NOT a SAS dataset).
THE LIBRARY SHOULD BE ASSIGNED ALREADY - eg in autoexec or earlier in the THE LIBRARY SHOULD BE ASSIGNED ALREADY - eg in autoexec or earlier in the
init program proper. init program proper.

View File

@@ -8,8 +8,8 @@
duration=60*5 duration=60*5
) )
@param [in] duration= the time in seconds which the job should run for. Actual @param [in] duration= (30) The time in seconds which the job should run for.
time may vary, as the check is done in between steps. Default = 30 (seconds). Actual time may vary, as the check is done in between steps.
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_getuniquelibref.sas @li mf_getuniquelibref.sas

View File

@@ -11,9 +11,9 @@
,outds=work.results ,outds=work.results
) )
@param lib= (WORK) The library in which to create the table @param [in] lib= (WORK) The library in which to create the table
@param size= (0.1) The size in GB of the table to create @param [in] size= (0.1) The size in GB of the table to create
@param outds= (WORK.RESULTS) The output dataset to be created. @param [out] outds= (WORK.RESULTS) The output dataset to be created.
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_getuniquename.sas @li mf_getuniquename.sas

View File

@@ -15,8 +15,8 @@ https://communities.sas.com/t5/SAS-Programming/listing-all-files-within-a-direct
https://communities.sas.com/t5/SAS-Programming/listing-all-files-of-all-types-from-all-subdirectories/m-p/334113/highlight/true#M75419 https://communities.sas.com/t5/SAS-Programming/listing-all-files-of-all-types-from-all-subdirectories/m-p/334113/highlight/true#M75419
@param dir= Directory to be scanned (default=/tmp) @param [in] dir= (/tmp) Directory to be scanned
@param outds= Dataset to create (default=work.mp_tree) @param [out] outds= (work.mp_tree) Dataset to create
@returns outds contains the following variables: @returns outds contains the following variables:

View File

@@ -13,11 +13,12 @@
%mp_unzip(ziploc="/some/file.zip",outdir=/some/folder) %mp_unzip(ziploc="/some/file.zip",outdir=/some/folder)
More info: https://blogs.sas.com/content/sasdummy/2015/05/11/using-filename-zip-to-unzip-and-read-data-files-in-sas/ More info:
https://blogs.sas.com/content/sasdummy/2015/05/11/using-filename-zip-to-unzip-and-read-data-files-in-sas/
@param ziploc= Fileref or quoted full path to zip file ("/path/to/file.zip") @param [in] ziploc= Fileref or quoted full path, eg: "/path/to/file.zip"
@param outdir= (%sysfunc(pathname(work))) Directory in which to write the @param [out] outdir= (%sysfunc(pathname(work))) Directory in which to write
outputs (created if non existant) the outputs (created if needed)
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_mkdir.sas @li mf_mkdir.sas

View File

@@ -14,9 +14,9 @@
proc sql; proc sql;
describe table example; describe table example;
@param libds the library.dataset to be modified @param [in] libds the library.dataset to be modified
@param var The variable to modify @param [in] var The variable to modify
@param len The new length to apply @param [in] len The new length to apply
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mf_existds.sas @li mf_existds.sas

View File

@@ -57,7 +57,7 @@
%end; %end;
%else %if &rule=ISNUM %then %do; %else %if &rule=ISNUM %then %do;
/* /*
credit SØREN LASSEN credit SOREN LASSEN
https://sasmacro.blogspot.com/2009/06/welcome-isnum-macro.html https://sasmacro.blogspot.com/2009/06/welcome-isnum-macro.html
*/ */
&tempcol=input(&incol,?? best32.); &tempcol=input(&incol,?? best32.);
@@ -71,7 +71,7 @@
retain &tempcol; retain &tempcol;
&tempcol=prxparse('/^[_a-z]\w{0,7}\.[_a-z]\w{0,31}$/i'); &tempcol=prxparse('/^[_a-z]\w{0,7}\.[_a-z]\w{0,31}$/i');
if missing(&tempcol) then do; if missing(&tempcol) then do;
putlog "%str(ERR)OR: Invalid expression for LIBDS"; putlog 'ERR' +(-1) "OR: Invalid expression for LIBDS";
stop; stop;
end; end;
drop &tempcol; drop &tempcol;
@@ -85,7 +85,7 @@
retain &tempcol; retain &tempcol;
&tempcol=prxparse('/^[_a-z\$]\w{0,31}\.[0-9]*$/i'); &tempcol=prxparse('/^[_a-z\$]\w{0,31}\.[0-9]*$/i');
if missing(&tempcol) then do; if missing(&tempcol) then do;
putlog "%str(ERR)OR: Invalid expression for FORMAT"; putlog 'ERR' +(-1) "OR: Invalid expression for FORMAT";
stop; stop;
end; end;
drop &tempcol; drop &tempcol;

View File

@@ -11,7 +11,7 @@
@param [in] file The file to wait for. Must be provided. @param [in] file The file to wait for. Must be provided.
@param [in] maxwait= (0) Number of seconds to wait. If set to zero, will @param [in] maxwait= (0) Number of seconds to wait. If set to zero, will
loop indefinitely (to a maximum of 46 days, per SAS [documentation]( loop indefinitely (to a maximum of 46 days, per SAS [documentation](
https://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a001418809.htm https://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a001418809.htm
)). Otherwise, execution will proceed upon sleep expiry. )). Otherwise, execution will proceed upon sleep expiry.
@param [in] interval= (1) The wait period between sleeps, in seconds @param [in] interval= (1) The wait period between sleeps, in seconds

View File

@@ -18,7 +18,7 @@
Usage: Usage:
%mp_webin() %mp_webin()
This was created as a macro procedure (over a macro function) as it will also This was created as a macro procedure (over a macro function) as it will also
use the filename statement in Viya environments (where `_webin_fileuri` is use the filename statement in Viya environments (where `_webin_fileuri` is

View File

@@ -15,14 +15,14 @@
<h4> SAS Macros </h4> <h4> SAS Macros </h4>
@li mp_dirlist.sas @li mp_dirlist.sas
@param in= unquoted filepath, dataset of files or directory to zip @param [in] in= unquoted filepath, dataset of files or directory to zip
@param type= (FILE) Valid values: @param [in] type= (FILE) Valid values:
@li FILE - /full/path/and/filename.extension to a particular file @li FILE - /full/path/and/filename.extension to a particular file
@li DATASET - a dataset containing a list of files to zip (see `incol`) @li DATASET - a dataset containing a list of files to zip (see `incol`)
@li DIRECTORY - a directory to zip @li DIRECTORY - a directory to zip
@param outname= (FILE) Output file to create, _without_ .zip extension @param [out] outname= (FILE) Output file to create, _without_ .zip extension
@param outpath= (%sysfunc(pathname(WORK))) Parent folder for output zip file @param [out] outpath= (%sysfunc(pathname(WORK))) Parent folder for zip file
@param incol= if DATASET input, say which column contains the filepath @param [in] incol= () If DATASET input, say which column contains the filepath
<h4> Related Macros </h4> <h4> Related Macros </h4>
@li mp_unzip.sas @li mp_unzip.sas

View File

@@ -35,7 +35,18 @@
,NOEDIT num length=3 label='Is picture string noedit?' ,NOEDIT num length=3 label='Is picture string noedit?'
,SEXCL char(1) label='Start exclusion' ,SEXCL char(1) label='Start exclusion'
,EEXCL char(1) label='End exclusion' ,EEXCL char(1) label='End exclusion'
,HLO char(13) label='Additional information. M=MultiLabel' ,HLO char(13) label='Additional information.
F=Standard format/informat.
H=Range ending value is HIGH.
I=Numeric informat.
J=Justification for an informat.
L=Range starting value is LOW.
M=MultiLabel.
N=Format or informat has no ranges, including no OTHER= range.
O=Range is OTHER.
R=ROUND option is in effect.
S=Specifies that NOTSORTED is in effect.
U=Specifies that the UPCASE option for an informat be used.'
,DECSEP char(1) label='Decimal separator' ,DECSEP char(1) label='Decimal separator'
,DIG3SEP char(1) label='Three-digit separator' ,DIG3SEP char(1) label='Three-digit separator'
,DATATYPE char(8) label='Date/time/datetime?' ,DATATYPE char(8) label='Date/time/datetime?'

View File

@@ -13,9 +13,9 @@
,group=someGroup) ,group=someGroup)
@param user= the user name (not displayname) @param [in] user= the user name (not displayname)
@param group= the group to which to add the user @param [in] group= the group to which to add the user
@param mdebug= (0) set to 1 to show debug info in log @param [in] mdebug= (0) set to 1 to show debug info in log
<h4> Related Files </h4> <h4> Related Files </h4>
@li ms_adduser2group.sas @li ms_adduser2group.sas

View File

@@ -18,12 +18,13 @@
@li mf_getengine.sas @li mf_getengine.sas
@li mp_abort.sas @li mp_abort.sas
@param libref the libref (not name) of the metadata library @param [in] libref the libref (not name) of the metadata library
@param open_passthrough= provide an alias to produce the CONNECT TO statement @param [in] open_passthrough= () Provide an alias to produce the CONNECT TO
for the relevant external database statement for the relevant external database
@param sql_options= an override default output fileref to avoid naming clash @param [in] sql_options= () Add any options to add to proc sql statement,
@param mDebug= set to 1 to show debug messages in the log eg outobs= (only valid for pass through)
@param mAbort= set to 1 to call %mp_abort(). @param [in] mDebug= (0) set to 1 to show debug messages in the log
@param [in] mAbort= (0) set to 1 to call %mp_abort().
@returns libname statement @returns libname statement
@@ -33,12 +34,9 @@
**/ **/
%macro mm_assigndirectlib( %macro mm_assigndirectlib(
libref /* libref to assign from metadata */ libref
,open_passthrough= /* provide an alias to produce the ,open_passthrough=
CONNECT TO statement for the ,sql_options=
relevant external database */
,sql_options= /* add any options to add to proc sql statement eg outobs=
(only valid for pass through) */
,mDebug=0 ,mDebug=0
,mAbort=0 ,mAbort=0
)/*/STORE SOURCE*/; )/*/STORE SOURCE*/;
@@ -214,7 +212,7 @@ run;
%else %if &engine=ODBC %then %do; %else %if &engine=ODBC %then %do;
&mD.%put NOTE: Retrieving ODBC connection details; &mD.%put NOTE: Retrieving ODBC connection details;
data _null_; data _null_;
length connx_uri conprop_uri value datasource up_uri schema $256.; length connx_uri conprop_uri value datasource up_uri schema domprop_uri authdomain $256.;
call missing (of _all_); call missing (of _all_);
/* get source connection ID */ /* get source connection ID */
rc=metadata_getnasn("&liburi",'LibraryConnection',1,connx_uri); rc=metadata_getnasn("&liburi",'LibraryConnection',1,connx_uri);
@@ -229,6 +227,13 @@ run;
rc2=-1; rc2=-1;
end; end;
end; end;
/* get auth domain */
autrc=metadata_getnasn(connx_uri,"Domain",1,domprop_uri);
arc=metadata_getattr(domprop_uri,"Name",authdomain);
if not missing(authdomain) then authdomain=cats('AUTHDOMAIN=',authdomain);
call symputx('authdomain',authdomain,'l');
/* get SCHEMA */ /* get SCHEMA */
rc6=metadata_getnasn("&liburi",'UsingPackages',1,up_uri); rc6=metadata_getnasn("&liburi",'UsingPackages',1,up_uri);
rc7=metadata_getattr(up_uri,'SchemaName',schema); rc7=metadata_getattr(up_uri,'SchemaName',schema);
@@ -245,7 +250,7 @@ run;
(INSERT_SQL=YES DATASRC=&sql_dsn. CONNECTION=global); (INSERT_SQL=YES DATASRC=&sql_dsn. CONNECTION=global);
%end; %end;
%else %do; %else %do;
libname &libref ODBC DATASRC=&sql_dsn SCHEMA=&sql_schema; libname &libref ODBC DATASRC=&sql_dsn SCHEMA=&sql_schema &authdomain;
%end; %end;
%end; %end;
%else %if &engine=POSTGRES %then %do; %else %if &engine=POSTGRES %then %do;

View File

@@ -14,8 +14,8 @@
@li mp_abort.sas @li mp_abort.sas
@param [in] libref The libref (not name) of the metadata library @param [in] libref The libref (not name) of the metadata library
@param [in] mAbort= If not assigned, HARD will call %mp_abort(), SOFT will @param [in] mAbort= (HARD) If not assigned, HARD will call %mp_abort(), SOFT
silently return will silently return
@returns libname statement @returns libname statement

View File

@@ -21,21 +21,24 @@
@li mp_abort.sas @li mp_abort.sas
@li mf_verifymacvars.sas @li mf_verifymacvars.sas
@param tree= The metadata folder uri, or the metadata path, in which to @param [in] tree= The metadata folder uri, or the metadata path, in which to
create the object. This must exist. create the object. This must exist.
@param name= Application object name. Avoid spaces. @param [in] name= Application object name. Avoid spaces.
@param ClassIdentifier= the class of applications to which this app belongs @param [in] ClassIdentifier=
@param params= name=value pairs which will become public properties of the The class of applications to which this app belongs
@param [in] params=
name=value pairs which will become public properties of the
application object. These are delimited using &#x0a; (newline character) application object. These are delimited using &#x0a; (newline character)
@param desc= Application description (optional). Avoid ampersands as these @param [in] desc= Application description (optional).
Avoid ampersands as these
are illegal characters (unless they are escapted- eg &amp;) are illegal characters (unless they are escapted- eg &amp;)
@param version= version number of application @param [in] version= version number of application
@param frefin= fileref to use (enables change if there is a conflict). The @param [in] frefin= fileref to use (enables change if there is a conflict).
filerefs are left open, to enable inspection after running the The filerefs are left open, to enable inspection after running the
macro (or importing into an xmlmap if needed). macro (or importing into an xmlmap if needed).
@param frefout= fileref to use (enables change if there is a conflict) @param [out] frefout= fileref to use (enables change if there is a conflict)
@param mDebug= set to 1 to show debug messages in the log @param [in] mDebug= set to 1 to show debug messages in the log
@author Allan Bowe @author Allan Bowe

Some files were not shown because too many files have changed in this diff Show More