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

Remove runtime dependencies for release binary #13

Closed
wants to merge 13 commits into from

Conversation

7sDream
Copy link
Owner

@7sDream 7sDream commented May 23, 2020

I hope issue #10 will disappear after finish this.

This PR need two part of work:

1. For macOS: Use Core Text API to match font

Due to servo-fontconfig-sys do not compile static library itselfs on macOS.(servo/libfontconfig#53)

TODO List for this goal:

  • Extract font match logic as a trait
  • fontconfig impl the matcher trait
  • Make a core-text font match api wrapper
  • Adjust Font/Family struct to use Cow to support owned string type
  • fontconfig matcher trait impl update as Font/Family struct has changed
  • core-text api impl the matcher trait
  • diff with fontconfig result
  • figure out how to get font face index(opend question in Apple Developer Forum)
  • Extract font render logic as a trait
  • FreeType impl render trait
  • Make a core-text font render api wrapper
  • core-text api impl the render trait

Now the list font and preview in browser should works fine in macOS without fontconfig installed.

freetype-sys support static link, so manual install from brew is not required too.

The only missing part is: freetype needs index to load font from file, but Core Text API seems do not provide this attribute, So tui preview not work for now.

Maybe we need adjust render logic to support Core Text Glyph Renderer too...... I'm not sure for now. I will pause work on this part before I figure out how to get index or have enough time to do a renderer refactor.

2020/05/31: I decide to use Core Text as Render Engine in macOS.
I just recently made a abstract layer to support different engines and adapted FreeType to this layer, it works well. I think I will implement Core Text Render logic in next weekends.

2. For Linux: Static link to fontconfig and freetype

TODO List for this goal:

Now this goal works well by using deps' git master version and my patched fork.

But I think we need waiting for upstream merge/publish those change and upgrade deps to that official version to make a stable release.

@7sDream 7sDream force-pushed the feature/use-core-text-on-macOS branch from 7f5a3ad to e7b3402 Compare May 23, 2020 20:20
@7sDream 7sDream changed the title [WIP] feat(font-matcher): use Core-Text API on macOS [WIP] Remove runtime fontconfig/freetype dependencies for release binary May 25, 2020
@7sDream 7sDream changed the title [WIP] Remove runtime fontconfig/freetype dependencies for release binary [WIP] Remove runtime fontconfig and freetype dependencies for release binary May 25, 2020
@7sDream 7sDream marked this pull request as ready for review May 25, 2020 14:56
@7sDream 7sDream changed the title [WIP] Remove runtime fontconfig and freetype dependencies for release binary [WIP] Do not require fontconfig and freetype installed when running release binary May 25, 2020
@7sDream 7sDream changed the title [WIP] Do not require fontconfig and freetype installed when running release binary [WIP] Do not require Fontconfig and FreeType installed for release binary May 25, 2020
@7sDream 7sDream changed the title [WIP] Do not require Fontconfig and FreeType installed for release binary Do not require Fontconfig and FreeType installed for release binary May 25, 2020
@7sDream 7sDream changed the title Do not require Fontconfig and FreeType installed for release binary Remove runtime dependencies for release binary May 25, 2020
@7sDream 7sDream force-pushed the feature/use-core-text-on-macOS branch from a2a92bb to fa28445 Compare May 31, 2020 15:18
@7sDream 7sDream closed this Jul 7, 2020
@7sDream 7sDream reopened this Jul 7, 2020
@7sDream 7sDream closed this Jul 7, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant