Deep copy of an unknown(ish) type in a templated linked list

Bash: What does "masking return values" mean?

Meaning of "SEVERA INDEOVI VAS" from 3rd Century slab

Using "wallow" verb with object

Why doesn't the EU now just force the UK to choose between referendum and no-deal?

Counting certain elements in lists

Sword in the Stone story where the sword was held in place by electromagnets

Do I need life insurance if I can cover my own funeral costs?

Could the Saturn V actually have launched astronauts around Venus?

Happy pi day, everyone!

Humanity loses the vast majority of its technology, information, and population in the year 2122. How long does it take to rebuild itself?

How to explain that I do not want to visit a country due to personal safety concern?

How is the Swiss post e-voting system supposed to work, and how was it wrong?

Font with correct density?

Professor being mistaken for a grad student

Making a sword in the stone, in a medieval world without magic

Identifying the interval from A♭ to D♯

I need to drive a 7/16" nut but am unsure how to use the socket I bought for my screwdriver

Instead of Universal Basic Income, why not Universal Basic NEEDS?

Does the statement `int val = (++i > ++j) ? ++i : ++j;` invoke undefined behavior?

Brexit - No Deal Rejection

Schematic conventions for different supply rails

Possible Leak In Concrete

Does splitting a potentially monolithic application into several smaller ones help prevent bugs?

Why must traveling waves have the same amplitude to form a standing wave?



Deep copy of an unknown(ish) type in a templated linked list














0












$begingroup$


I have a templated linked list (Inventory), and I have instantiated a inventory object of type Item *



Inventory<Item*> myinv;


Item is an abstract base class, I have two other classes, Weapon and Armor which both publicly derive from the Item ABC.



I have instantiated a Weapon object:



Weapon * frost = new Weapon("Weapon", 100, 0.01, 100);


I have used my function PushFront(const T & data)



myinv.PushFront(frost);


The function copies over the pointer to said data into the new nodes m_data, instead of doing a deep copy



template<class T>
inline void Inventory<T>::PushFront(const T & data)
{

Node<T> * nn = new Node<T>;

nn->m_data = data; //Copies over pointer instead of calling an overloaded assignment operator

m_count += 1;
.
.
.


I cannot for the life of me figure out the syntax to get it to use an overloaded assignment operator, I can post more code to those of you that need it.



Thank you for any help.









share







New contributor




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







$endgroup$
















    0












    $begingroup$


    I have a templated linked list (Inventory), and I have instantiated a inventory object of type Item *



    Inventory<Item*> myinv;


    Item is an abstract base class, I have two other classes, Weapon and Armor which both publicly derive from the Item ABC.



    I have instantiated a Weapon object:



    Weapon * frost = new Weapon("Weapon", 100, 0.01, 100);


    I have used my function PushFront(const T & data)



    myinv.PushFront(frost);


    The function copies over the pointer to said data into the new nodes m_data, instead of doing a deep copy



    template<class T>
    inline void Inventory<T>::PushFront(const T & data)
    {

    Node<T> * nn = new Node<T>;

    nn->m_data = data; //Copies over pointer instead of calling an overloaded assignment operator

    m_count += 1;
    .
    .
    .


    I cannot for the life of me figure out the syntax to get it to use an overloaded assignment operator, I can post more code to those of you that need it.



    Thank you for any help.









    share







    New contributor




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







    $endgroup$














      0












      0








      0





      $begingroup$


      I have a templated linked list (Inventory), and I have instantiated a inventory object of type Item *



      Inventory<Item*> myinv;


      Item is an abstract base class, I have two other classes, Weapon and Armor which both publicly derive from the Item ABC.



      I have instantiated a Weapon object:



      Weapon * frost = new Weapon("Weapon", 100, 0.01, 100);


      I have used my function PushFront(const T & data)



      myinv.PushFront(frost);


      The function copies over the pointer to said data into the new nodes m_data, instead of doing a deep copy



      template<class T>
      inline void Inventory<T>::PushFront(const T & data)
      {

      Node<T> * nn = new Node<T>;

      nn->m_data = data; //Copies over pointer instead of calling an overloaded assignment operator

      m_count += 1;
      .
      .
      .


      I cannot for the life of me figure out the syntax to get it to use an overloaded assignment operator, I can post more code to those of you that need it.



      Thank you for any help.









      share







      New contributor




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







      $endgroup$




      I have a templated linked list (Inventory), and I have instantiated a inventory object of type Item *



      Inventory<Item*> myinv;


      Item is an abstract base class, I have two other classes, Weapon and Armor which both publicly derive from the Item ABC.



      I have instantiated a Weapon object:



      Weapon * frost = new Weapon("Weapon", 100, 0.01, 100);


      I have used my function PushFront(const T & data)



      myinv.PushFront(frost);


      The function copies over the pointer to said data into the new nodes m_data, instead of doing a deep copy



      template<class T>
      inline void Inventory<T>::PushFront(const T & data)
      {

      Node<T> * nn = new Node<T>;

      nn->m_data = data; //Copies over pointer instead of calling an overloaded assignment operator

      m_count += 1;
      .
      .
      .


      I cannot for the life of me figure out the syntax to get it to use an overloaded assignment operator, I can post more code to those of you that need it.



      Thank you for any help.







      c++





      share







      New contributor




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










      share







      New contributor




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








      share



      share






      New contributor




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









      asked 44 secs ago









      MikeMike

      1




      1




      New contributor




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





      New contributor





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






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




















          0






          active

          oldest

          votes











          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
          );
          );
          , "mathjax-editing");

          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: "196"
          ;
          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: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          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
          );



          );






          Mike 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%2fcodereview.stackexchange.com%2fquestions%2f215467%2fdeep-copy-of-an-unknownish-type-in-a-templated-linked-list%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








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









          draft saved

          draft discarded


















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












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











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














          Thanks for contributing an answer to Code Review Stack Exchange!


          • 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.

          Use MathJax to format equations. MathJax reference.


          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%2fcodereview.stackexchange.com%2fquestions%2f215467%2fdeep-copy-of-an-unknownish-type-in-a-templated-linked-list%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

          कुँवर स्रोत दिक्चालन सूची"कुँवर""राणा कुँवरके वंशावली"

          शेव्रोले वोल्ट अनुक्रम इतिहास इन्हे भी देखें चित्र दीर्घा संदर्भ दिक्चालन सूची

          चैत्य भूमि चित्र दीर्घा सन्दर्भ बाहरी कडियाँ दिक्चालन सूची"Chaitya Bhoomi""Chaitya Bhoomi: Statue of Equality in India""Dadar Chaitya Bhoomi: Statue of Equality in India""Ambedkar memorial: Centre okays transfer of Indu Mill land"चैत्यभमि