Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Simplify IBMi class #2277

Open
wants to merge 37 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
c4de790
Extend the base API to allow other extensions to add their own compon…
worksofliam Aug 28, 2024
3d4a611
Implement custom casting function
worksofliam Sep 3, 2024
00482be
Remove use of deprecated function
worksofliam Sep 3, 2024
178c391
Implement test for ensuring correct lines are returned
worksofliam Sep 3, 2024
51e55df
Code cleanup
sebjulliand Sep 18, 2024
d440c72
Components management refactoring
sebjulliand Sep 18, 2024
b2123c4
Merge branch 'master' into feature/extendable_components
sebjulliand Sep 18, 2024
5e5e0af
Require context to register a component + display components list
sebjulliand Sep 19, 2024
56427ca
Show version of each component
sebjulliand Sep 19, 2024
cee0a54
Seperating logic from IBMi.ts into a new class.
krethan Sep 27, 2024
83938f5
Merge branch 'master' of https://github.com/krethan/vscode-ibmi
krethan Sep 27, 2024
9564ffc
Fixed few issues introduced with IBMiSettings
krethan Oct 2, 2024
9f6a355
Removed unneccessary comments
krethan Oct 2, 2024
a7d5f14
Merge branch 'master' into feature/extendable_components
sebjulliand Oct 3, 2024
226d0ce
Fixed wrong import
sebjulliand Oct 3, 2024
34fda10
Always show "Download client certificate" button
sebjulliand Oct 4, 2024
f79e370
Use type for component state instead of enum
worksofliam Oct 4, 2024
afc71a2
Merge pull request #2281 from codefori/fix/localDebugCertDownload
worksofliam Oct 6, 2024
2d65d6a
Merge pull request #2232 from codefori/feature/extendable_components
worksofliam Oct 7, 2024
2061409
Merge branch 'master' into fix/bad_lines_from_member
worksofliam Oct 7, 2024
41609be
Discover IBM i Java installation
sebjulliand Oct 7, 2024
d23ff7d
Use IBMi remote Java feature for debug service
sebjulliand Oct 7, 2024
d3a5e50
Fix debug java test
sebjulliand Oct 7, 2024
449783f
Do not use interpolation when not needed
sebjulliand Oct 8, 2024
c4e8a15
Merge pull request #2245 from codefori/fix/bad_lines_from_member
worksofliam Oct 9, 2024
7fefd51
Merge pull request #2283 from codefori/feature/discoverjdk
sebjulliand Oct 9, 2024
32e4566
Bump to 2.13.1
worksofliam Oct 10, 2024
f7da821
Fix type issue in Search
worksofliam Oct 10, 2024
fea455d
Bump to 2.13.2
worksofliam Oct 10, 2024
6c4f0fd
Release 2.13.2
github-actions[bot] Oct 10, 2024
0acd262
Starting 2.13.3-dev.0 development
github-actions[bot] Oct 10, 2024
685141f
Reuse checkObject from content and moved
krethan Oct 13, 2024
58bb714
Seperating logic from IBMi.ts into a new class.
krethan Sep 27, 2024
73ee37c
Fixed few issues introduced with IBMiSettings
krethan Oct 2, 2024
6c5df52
Removed unneccessary comments
krethan Oct 2, 2024
f9d0e4c
Reuse checkObject from content and moved
krethan Oct 13, 2024
a0b8440
Merge branch 'master' of https://github.com/krethan/vscode-ibmi
krethan Oct 13, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
"icon": "icon.png",
"displayName": "Code for IBM i",
"description": "Maintain your RPGLE, CL, COBOL, C/CPP on IBM i right from Visual Studio Code.",
"version": "2.13.4-dev.0",
"version": "2.13.3-dev.0",
"keywords": [
"ibmi",
"rpgle",
Expand Down
543 changes: 139 additions & 404 deletions src/api/IBMi.ts

Large diffs are not rendered by default.

87 changes: 87 additions & 0 deletions src/api/IBMiApps.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
import IBMi from "./IBMi";
import { RemoteApp, RemoteApps, RemoteFeatures } from "../typings";

export default class IBMiApps {

private remoteApps: RemoteApps;
private remoteFeatures: RemoteFeatures;

constructor() {
this.remoteApps = [
{
path: `/usr/bin/`,
names: [`setccsid`, `iconv`, `attr`, `tar`, `ls`]
},
{
path: `/QOpenSys/pkgs/bin/`,
names: [`git`, `grep`, `tn5250`, `md5sum`, `bash`, `chsh`, `stat`, `sort`, `tar`, `ls`, `find`]
},
{
path: `/QSYS.LIB/`,
// In the future, we may use a generic specific.
// Right now we only need one program
// specific: `*.PGM`,
specific: `QZDFMDB2.PGM`,
names: [`QZDFMDB2.PGM`]
},
{
path: `/QIBM/ProdData/IBMiDebugService/bin/`,
specific: `startDebugService.sh`,
names: [`startDebugService.sh`]
}
];

this.remoteFeatures = {};
this.initRemoteFeatures();

}

addRemoteApp(remoteApp: RemoteApp) {

//Add remote App
this.remoteApps.push(remoteApp);

//Add possible features to list
for (const name of remoteApp.names) {
this.remoteFeatures[name] = undefined;
}

}

getRemoteApps(): RemoteApps {
return this.remoteApps;
}

initRemoteFeatures() {

for (const feature of this.remoteApps) {
for (const name of feature.names) {
this.remoteFeatures[name] = undefined;
}
}

}

getRemoteFeatures(): RemoteFeatures {
return this.remoteFeatures;
}

async checkRemoteFeatures(remoteApp: RemoteApp, connection: IBMi) {

const call = await connection.sendCommand({ command: `ls -p ${remoteApp.path}${remoteApp.specific || ``}` });
if (call.stdout) {
const files = call.stdout.split(`\n`);

if (remoteApp.specific) {
for (const name of remoteApp.names)
this.remoteFeatures[name] = files.find(file => file.includes(name));
} else {
for (const name of remoteApp.names)
if (files.includes(name))
this.remoteFeatures[name] = remoteApp.path + name;
}
}

}

}
14 changes: 13 additions & 1 deletion src/api/IBMiContent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -906,6 +906,18 @@ export default class IBMiContent {
})).code === 0;
}

async deleteObject(object: { library: string, name: string, type: string }) {

return (await this.ibmi.runCommand({
command: this.toCl(`DLTOBJ`, {
obj: `${this.ibmi.upperCaseName(object.library)}/${this.ibmi.upperCaseName(object.name)}`,
objtype: object.type.toLocaleUpperCase()
}),
noLibList: true
})).code === 0;

}

async testStreamFile(path: string, right: "e" | "f" | "d" | "r" | "w" | "x") {
return (await this.ibmi.sendCommand({ command: `test -${right} ${Tools.escapePath(path)}` })).code === 0;
}
Expand Down Expand Up @@ -951,7 +963,7 @@ export default class IBMiContent {
return cl;
}

async getAttributes(path: string | (QsysPath & { member?: string }), ...operands: AttrOperands[]) {
async getAttributes(path: string | (QsysPath & { member?: string }), ...operands: AttrOperands[]) {
const target = (path = typeof path === 'string' ? Tools.escapePath(path) : this.ibmi.sysNameInAmerican(Tools.qualifyPath(path.library, path.name, path.member, path.asp)));

const result = await this.ibmi.sendCommand({ command: `${this.ibmi.remoteFeatures.attr} -p ${target} ${operands.join(" ")}` });
Expand Down
Loading