• Viernes 8 de Noviembre de 2024, 22:55

Autor Tema:  error C2440: '=' : no se puede realizar la conversión de 'co  (Leído 2588 veces)

ipadilla

  • Nuevo Miembro
  • *
  • Mensajes: 6
    • Ver Perfil
error C2440: '=' : no se puede realizar la conversión de 'co
« en: Miércoles 7 de Julio de 2010, 13:09 »
0
error C2440: '=' : no se puede realizar la conversión de 'const char *' a 'char *'
Estoy intentando compilar con Visual Studio 2003 un programa que fue creado con Visual Studio 6.0 y obtengo en siguiente error:

c:En Curso_1ChromaticSvnTruckSrcClassesCList.h(13 5) : error C2440: '=' : no se puede realizar la conversión de 'const char *' a 'char *'
Se pierden calificadores en la conversión
c:En Curso_1ChromaticSvnTruckSrcClassesCList.h(10 5) : vea la referencia a la creación de instancias de plantilla de función 'CList<T>::CList_Entry *CList<T>::Set<const char>(CList<T>::CList_Entry *,const char)' que se está compilando
with
[
T=char *
]
c:En Curso_1ChromaticSvnTruckSrcDlg_UserMenusEd.cp p(758) : vea la referencia a la creación de instancias de plantilla de función 'CList<T>::CList_Entry *CList<T>::Add<const char*>(const char)' que se está compilando
with
[
T=char *
]


¿Alguien me puede ayudar a solucionarlo?

Muchas gracias
ipadilla
     Editar/Borrar Mensaje

Eternal Idol

  • Moderador
  • ******
  • Mensajes: 4696
  • Nacionalidad: ar
    • Ver Perfil
Re: error C2440: '=' : no se puede realizar la conversión de 'co
« Respuesta #1 en: Miércoles 7 de Julio de 2010, 13:29 »
0
¿Probaste haciendo un casting? Sin ver el codigo no se me ocurre otra cosa.

Nacional y Popular En mi país la bandera de Eva es inmortal.


Queremos una Argentina socialmente justa, económicamente libre y  políticamente soberana.
¡Perón cumple, Evita dignifica!


La mano invisible del mercado me robo la billetera.

ipadilla

  • Nuevo Miembro
  • *
  • Mensajes: 6
    • Ver Perfil
Re: error C2440: '=' : no se puede realizar la conversión de 'co
« Respuesta #2 en: Miércoles 7 de Julio de 2010, 13:40 »
0
Gracias por responder. El codigo es este, lo que ocurre es que estoy aparendiendo y no soy un exprerto, si me puede ayudar se lo agradeceré.
ipadilla


// CList.h: interface for the CList class
// -----------------------------------------------------------------------

#ifndef _CLIST_H_
#define _CLIST_H_

// -----------------------------------------------------------------------
// Includes
#include <stdlib.h>
#include <string.h>

// -----------------------------------------------------------------------
// Class definition
template <typename T> class CList
{
    public:

        #define ERASE_CALLBACK void (*CallBack)(T Content)

        struct CList_Entry
        {
            struct CList_Entry *Next;
            struct CList_Entry *Previous;
            T Content;
        };

        // Default Constructor/Destructor
        CList()
        {
            Free_Content = 0;
            Nbr_Entries = 0;
            Last_Entry = 0;
            First_Entry = 0;
        }

        ~CList()
        {
            this->Erase();
        }

        void Erase(ERASE_CALLBACK = NULL)
        {
            CList_Entry *Entry_To_Free;

            // Take first entry in the list
            Entry_To_Free = this->First_Entry;

            while(Entry_To_Free)
            {
                First_Entry = Entry_To_Free->Next;
                if(CallBack)
                {
                    CallBack(Entry_To_Free->Content);
                }
                Del(Entry_To_Free);
                Entry_To_Free = First_Entry;
            }
        }

        int Amount(void)
        {
            return(Nbr_Entries);
        }

        CList_Entry *Add(T Datas, int Size)
        {
            CList_Entry *New_Entry = Create_Entry(Size);
            Set(New_Entry, Datas, Size);
            return(New_Entry);
        }

        template<typename T> CList_Entry *Add(T Datas)
        {
            CList_Entry *New_Entry = Create_Entry(0);
            Set(New_Entry, Datas);
            return(New_Entry);
        }

        template< > CList_Entry *Add<char *>(char *Datas)
        {
            int Size = strlen(Datas) + 1;
            CList_Entry *New_Entry = Create_Entry(Size);
            Set(New_Entry, Datas, Size);
            return(New_Entry);
        }

        void MAdd(int Number, T Datas)
        {
            while(Number)
            {
                Add(Datas);
                Number--;
            }
        }

        CList_Entry *Set(int Entry_Number, T Datas)
        {
            CList_Entry *Entry_To_Set = Get(Entry_Number);
            Set(Entry_To_Set, Datas);
            return(Entry_To_Set);
        }

        template<typename T> CList_Entry *Set(CList_Entry *Entry_To_Set, T Datas)
        {
            Entry_To_Set->Content = (T) Datas;
         return(Entry_To_Set);
        }

        template< > CList_Entry *Set<char *>(CList_Entry *Entry_To_Set, char *Datas)
        {
            return(Set(Entry_To_Set, Datas, strlen(Datas) + 1));
        }

        CList_Entry *Set(int Entry_Number, T Datas, int Size)
        {
            CList_Entry *Entry_To_Set = Get(Entry_Number);
            Set(Entry_To_Set, Datas, Size);
            return(Entry_To_Set);
        }

        CList_Entry *Set(CList_Entry *Entry_To_Set, T Datas, int Size)
        {
            free((void *) Entry_To_Set->Content);
            Entry_To_Set->Content = (T) calloc(Size, 1);
            memcpy((void *) Entry_To_Set->Content, (void *) Datas, Size);
            Free_Content = 1;
            return(Entry_To_Set);
        }

        CList_Entry *Get(CList_Entry *Entry_To_Get)
        {
            CList_Entry *Current_Entry;

            Current_Entry = this->First_Entry;
            while(Current_Entry != Entry_To_Get)
            {
                Current_Entry = Current_Entry->Next;
            }
            return(Current_Entry);
        }

        CList_Entry *Get(int Entry_Number)
        {
            CList_Entry *Entry_To_Get;

            Entry_To_Get = First_Entry;
            while(Entry_Number)
            {
                Entry_To_Get = Entry_To_Get->Next;
                Entry_Number--;
            }
            return(Entry_To_Get);
        }

        void Del(CList_Entry *Entry_To_Delete)
        {
            CList_Entry *Previous_Entry;
            CList_Entry *Next_Entry;

            if(!First_Entry)
            {
                Nbr_Entries = 0;
                Last_Entry = 0;
                First_Entry = 0;
                return;
            }
            // First will be next
            if(First_Entry == Entry_To_Delete) First_Entry = Entry_To_Delete->Next;
            // Last will be previous
            if(Last_Entry == Entry_To_Delete) Last_Entry = Entry_To_Delete->Previous;
            // Get next/previous entries
            Previous_Entry = Entry_To_Delete->Previous;
            Next_Entry = Entry_To_Delete->Next;
            if(Free_Content)
            {
                free((void *) Entry_To_Delete->Content);
            }
            free(Entry_To_Delete);
            // Update previous/next entries
            if(Next_Entry) Next_Entry->Previous = Previous_Entry;
            if(Previous_Entry) Previous_Entry->Next = Next_Entry;
            if(this->Nbr_Entries) this->Nbr_Entries--;
        }

        void Del(int Entry_Number)
        {
            Del((CList_Entry *) Get(Entry_Number));
        }

        CList_Entry *Search_Entry(T &Datas, int Start, int Length)
        {
            CList_Entry *Entry_To_Get;

            Entry_To_Get = First_Entry;
            while(Entry_To_Get)
            {
                if(memcmp(((uint8 *) &Datas) + Start,
                          ((uint8 *) &Entry_To_Get->Content) + Start,
                          Length) == 0)
                {
                    return(Entry_To_Get);
                }
                Entry_To_Get = Entry_To_Get->Next;
            }
            return(NULL);
        }

    private:

        int Nbr_Entries;
        int Free_Content;
        struct CList_Entry *Last_Entry;
        struct CList_Entry *First_Entry;

        CList_Entry *Create_Entry(int Size)
        {
            CList_Entry *New_Entry;
            CList_Entry *Old_Entry;

            New_Entry = (CList_Entry *) calloc(sizeof(CList_Entry), 1);
            if(!First_Entry) First_Entry = New_Entry;
            if(Last_Entry)
            {
                // Update previous entry
                Old_Entry = Last_Entry;
                Old_Entry->Next = New_Entry;
            }
            // Last entry
            New_Entry->Next = 0;
            New_Entry->Previous = this->Last_Entry;
            if(Size)
            {
                New_Entry->Content = (T) calloc(Size, 1);
            }
            else
            {
                New_Entry->Content = 0;
            }
            // Store newly created entry
            Last_Entry = New_Entry;
            // Increment number of entries
            Nbr_Entries++;
            return(New_Entry);
        }

        CList_Entry *Insert_Entry_Before(CList_Entry *Entry_To_Insert_Before)
        {
            CList_Entry *New_Entry;
            CList_Entry *Prev_Entry;

            New_Entry = (CList_Entry *) calloc(sizeof(CList_Entry), 1);
            if(!First_Entry) First_Entry = New_Entry;
            if(!Last_Entry) Last_Entry = New_Entry;
            // Set headers
            New_Entry->Next = Entry_To_Insert_Before;
            // This one is the new next one in previous entry
            Prev_Entry = Entry_To_Insert_Before->Previous;
            New_Entry->Previous = Prev_Entry;
            // Don't correct previous entry if this one is the first of the list
            if(Prev_Entry) Prev_Entry->Next = New_Entry;
            // This one is the new previous one in next entry
            Entry_To_Insert_Before->Previous = New_Entry;
            // Increment number of entries
            Nbr_Entries++;
            return(New_Entry);
        }

        CList_Entry *Insert_Entry_Before(CList_Entry *Entry_To_Insert_Before, T &Datas)
        {
            if(!Entry_To_Insert_Before) return(Add(Datas));
            CList_Entry *New_Entry = Insert_Entry_Before(Entry_To_Insert_Before);
            Set(New_Entry, Datas);
            return(New_Entry);
        }

        CList_Entry *Insert_Entry_After(CList_Entry *Entry_To_Insert_After)
        {
            CList_Entry *New_Entry;
            CList_Entry *Next_Entry;

            New_Entry = (CList_Entry *) calloc(sizeof(CList_Entry), 1);
            if(!First_Entry) First_Entry = New_Entry;
            if(!Last_Entry) Last_Entry = New_Entry;
            // Set new previous
            New_Entry->Previous = Entry_To_Insert_After;
            // Check if it was the last created one
            if(Last_Entry == Entry_To_Insert_After) Last_Entry = New_Entry;
            // Take latest next
            Next_Entry = Entry_To_Insert_After->Next;
            // Store it as new/old next
            New_Entry->Next = Next_Entry;
            if(Next_Entry) Next_Entry->Previous = New_Entry;
            // This one is the new next one
            Entry_To_Insert_After->Next = New_Entry;
            // Increment number of entries
            Nbr_Entries++;
            return(New_Entry);
        }

        CList_Entry *Insert_Entry_After(CList_Entry *Entry_To_Insert_After, T &Datas)
        {
            if(!Entry_To_Insert_After) return(Add(Datas));
            CList_Entry *New_Entry = Insert_Entry_After(Entry_To_Insert_After);
            Set(New_Entry, Datas);
            return(New_Entry);
        }
};

#endif