Cannot invoke an expression whose type lacks a call signature BinaryTree Type Script












1















I'm trying to implement binary search tree in Type Script using generic types. However I have an issue with adding child in node, because there is an error when parent.leftChild(newNode) - "Cannot invoke an expression whose type is lacks a call signature. Type Node has no compatible call signatures."



export { };

class Node <T> {
private _key: number;
private _data: T;
private _leftChild: Node <T>;
private _rightChild: Node <T>;
constructor(key: number, data: T) {
this._key = key;
this._data = data;
}
get key(): number {
return this._key;
}
get data(): T {
return this._data;
}
get leftChild(): Node <T> {
return this._leftChild;
}
get rightChild(): Node <T> {
return this._rightChild;
}
set leftChild(child: Node <T>) {
this._leftChild = child;
}
set rightChild(child: Node <T>) {
this._rightChild = child;
}
}

class BinaryTree <H> {
private _root: Node<H>;
public addNode(key: number, data: H): void {
const newNode: Node <H> = new Node <H> (key, data);
if (this._root == null) {
this._root = newNode;
} else {
let focusNode: Node <H> = this._root;
let parent: Node <H>;
while (true) {
parent = focusNode;
if (key < focusNode.key) {
focusNode = focusNode.leftChild;
if (focusNode == null) {
parent.leftChild(newNode);
return;
}
}
}
}
}
}









share|improve this question







New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





















  • leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

    – Peter Hull
    Jan 18 at 14:15











  • @peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

    – Mr. Vazovsky
    Jan 18 at 14:28











  • Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

    – Peter Hull
    Jan 18 at 15:45
















1















I'm trying to implement binary search tree in Type Script using generic types. However I have an issue with adding child in node, because there is an error when parent.leftChild(newNode) - "Cannot invoke an expression whose type is lacks a call signature. Type Node has no compatible call signatures."



export { };

class Node <T> {
private _key: number;
private _data: T;
private _leftChild: Node <T>;
private _rightChild: Node <T>;
constructor(key: number, data: T) {
this._key = key;
this._data = data;
}
get key(): number {
return this._key;
}
get data(): T {
return this._data;
}
get leftChild(): Node <T> {
return this._leftChild;
}
get rightChild(): Node <T> {
return this._rightChild;
}
set leftChild(child: Node <T>) {
this._leftChild = child;
}
set rightChild(child: Node <T>) {
this._rightChild = child;
}
}

class BinaryTree <H> {
private _root: Node<H>;
public addNode(key: number, data: H): void {
const newNode: Node <H> = new Node <H> (key, data);
if (this._root == null) {
this._root = newNode;
} else {
let focusNode: Node <H> = this._root;
let parent: Node <H>;
while (true) {
parent = focusNode;
if (key < focusNode.key) {
focusNode = focusNode.leftChild;
if (focusNode == null) {
parent.leftChild(newNode);
return;
}
}
}
}
}
}









share|improve this question







New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





















  • leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

    – Peter Hull
    Jan 18 at 14:15











  • @peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

    – Mr. Vazovsky
    Jan 18 at 14:28











  • Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

    – Peter Hull
    Jan 18 at 15:45














1












1








1








I'm trying to implement binary search tree in Type Script using generic types. However I have an issue with adding child in node, because there is an error when parent.leftChild(newNode) - "Cannot invoke an expression whose type is lacks a call signature. Type Node has no compatible call signatures."



export { };

class Node <T> {
private _key: number;
private _data: T;
private _leftChild: Node <T>;
private _rightChild: Node <T>;
constructor(key: number, data: T) {
this._key = key;
this._data = data;
}
get key(): number {
return this._key;
}
get data(): T {
return this._data;
}
get leftChild(): Node <T> {
return this._leftChild;
}
get rightChild(): Node <T> {
return this._rightChild;
}
set leftChild(child: Node <T>) {
this._leftChild = child;
}
set rightChild(child: Node <T>) {
this._rightChild = child;
}
}

class BinaryTree <H> {
private _root: Node<H>;
public addNode(key: number, data: H): void {
const newNode: Node <H> = new Node <H> (key, data);
if (this._root == null) {
this._root = newNode;
} else {
let focusNode: Node <H> = this._root;
let parent: Node <H>;
while (true) {
parent = focusNode;
if (key < focusNode.key) {
focusNode = focusNode.leftChild;
if (focusNode == null) {
parent.leftChild(newNode);
return;
}
}
}
}
}
}









share|improve this question







New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












I'm trying to implement binary search tree in Type Script using generic types. However I have an issue with adding child in node, because there is an error when parent.leftChild(newNode) - "Cannot invoke an expression whose type is lacks a call signature. Type Node has no compatible call signatures."



export { };

class Node <T> {
private _key: number;
private _data: T;
private _leftChild: Node <T>;
private _rightChild: Node <T>;
constructor(key: number, data: T) {
this._key = key;
this._data = data;
}
get key(): number {
return this._key;
}
get data(): T {
return this._data;
}
get leftChild(): Node <T> {
return this._leftChild;
}
get rightChild(): Node <T> {
return this._rightChild;
}
set leftChild(child: Node <T>) {
this._leftChild = child;
}
set rightChild(child: Node <T>) {
this._rightChild = child;
}
}

class BinaryTree <H> {
private _root: Node<H>;
public addNode(key: number, data: H): void {
const newNode: Node <H> = new Node <H> (key, data);
if (this._root == null) {
this._root = newNode;
} else {
let focusNode: Node <H> = this._root;
let parent: Node <H>;
while (true) {
parent = focusNode;
if (key < focusNode.key) {
focusNode = focusNode.leftChild;
if (focusNode == null) {
parent.leftChild(newNode);
return;
}
}
}
}
}
}






javascript typescript oop data-structures binary-tree






share|improve this question







New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question







New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question






New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked Jan 18 at 14:02









Mr. VazovskyMr. Vazovsky

61




61




New contributor




Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Mr. Vazovsky is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.













  • leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

    – Peter Hull
    Jan 18 at 14:15











  • @peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

    – Mr. Vazovsky
    Jan 18 at 14:28











  • Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

    – Peter Hull
    Jan 18 at 15:45



















  • leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

    – Peter Hull
    Jan 18 at 14:15











  • @peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

    – Mr. Vazovsky
    Jan 18 at 14:28











  • Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

    – Peter Hull
    Jan 18 at 15:45

















leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

– Peter Hull
Jan 18 at 14:15





leftChild is a property setter not a function so try parent.leftChild = newNode (typescriptlang.org/docs/handbook/classes.html#accessors)

– Peter Hull
Jan 18 at 14:15













@peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

– Mr. Vazovsky
Jan 18 at 14:28





@peter-hull Thanks man! It works! I've tried to fix it for over 24 last hours)) Why TS has so weird syntax????)

– Mr. Vazovsky
Jan 18 at 14:28













Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

– Peter Hull
Jan 18 at 15:45





Glad it works. As an aside, since your property accessors don't have any computation in them, you can just expose the bare properties (marking data and key as readonly)

– Peter Hull
Jan 18 at 15:45












0






active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});






Mr. Vazovsky is a new contributor. Be nice, and check out our Code of Conduct.










draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54255581%2fcannot-invoke-an-expression-whose-type-lacks-a-call-signature-binarytree-type-sc%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes








Mr. Vazovsky is a new contributor. Be nice, and check out our Code of Conduct.










draft saved

draft discarded


















Mr. Vazovsky is a new contributor. Be nice, and check out our Code of Conduct.













Mr. Vazovsky is a new contributor. Be nice, and check out our Code of Conduct.












Mr. Vazovsky is a new contributor. Be nice, and check out our Code of Conduct.
















Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54255581%2fcannot-invoke-an-expression-whose-type-lacks-a-call-signature-binarytree-type-sc%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Liquibase includeAll doesn't find base path

How to use setInterval in EJS file?

Petrus Granier-Deferre