Coder Social home page Coder Social logo

Comments (3)

stevemonaco avatar stevemonaco commented on June 22, 2024

The type to text ultimately goes through:

public static string? ToString(object o)
{
var converter = TypeDescriptor.GetConverter(o);
//CollectionConverter does not deliver any important information. It just displays "(Collection)".
if (!converter.CanConvertTo(typeof(string)) ||
converter.GetType() == typeof(CollectionConverter))
return o.ToString();
return converter.ConvertToInvariantString(o);
}

Component has a .NET type, ComponentConverter, that is being used to ConvertToInvariantString(...) which goes through ConvertTo in this case. Component and string aren't really convertible, so it returns null.

So the fix is probably to add another special case to the if so the type name is returned:

if (!converter.CanConvertTo(typeof(string)) ||
    converter.GetType() == typeof(CollectionConverter) ||
    converter.GetType() == typeof(ComponentConverter))
    return o.ToString();

I can PR if this seems reasonable to a maintainer. I'm not familiar with Component at all. ie. Should we force the type string to be returned or can/should the app dev write a custom+default implementation?

from avalonia.

jp2masa avatar jp2masa commented on June 22, 2024

Maybe it should just fallback to o.ToString()?

return converter.ConvertToInvariantString(o) ?? o.ToString();

or

if (!converter.CanConvertTo(typeof(string)) ||
    converter.GetType() == typeof(CollectionConverter) ||
    converter.ConvertToInvariantString(o) is not { } converted)
    return o.ToString();

return converted;

from avalonia.

stevemonaco avatar stevemonaco commented on June 22, 2024

I misdiagnosed because this is a bit nonsensical. converter.ConvertToInvariantString(o) for ComponentConverter actually returns an empty string after double-checking, so null fallback won't work. DevTools then somewhere along the line interprets this as (null) and I don't yet understand how/where.

Even simpler, you can repro with <TextBlock Text="" />, on 11.0.10 and nightly. The DevTools display will be (null).

Explicit ComponentConverter check might still be necessary?

from avalonia.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.