gpt4 book ai didi

linux - Haskell:quoteFile 在 unicode 字符上带有 "invalid byte sequence"的文本文件上失败

转载 作者:可可西里 更新时间:2023-11-01 11:45:46 26 4
gpt4 key购买 nike

我在虚拟环境(安装了 GHC 7.8.4 的 Debian Wheezy)中遇到 quoteFile 问题。我已经从 Text.Shakespeare.Text 中描述了面向文件的 st 准引用版本:

import Language.Haskell.TH.Quote    (QuasiQuoter, quoteFile)
import Text.Shakespeare.Text (st)

sfFile :: QuasiQuoter
stFile = quoteFile st

这在我的主机上运行良好,但是,在我的虚拟环境(Docker 镜像)上失败并出现以下错误:

Exception when trying to run compile-time code: test-file.md: hGetContents: invalid argument (invalid byte sequence)

Code: Language.Haskell.TH.Quote.quoteExp stFile "test-file.md"

我的 REPL 调查显示,错误发生在文本文件中的第一个 unicode 字符上,在我当前的情况下,这是 '«' 左指针双角引号:

import System.IO (IOMode(..), hGetContents, openFile, openBinaryFile, utf8)

main =
do h <- openBinaryFile "test-file.md" ReadMode
hGetContentContents h
-- Binary read works fine out-of-box.

h' <- openFile "test-file.md" ReadMode
hSetEncoding h' utf8
hGetContentContents h'
-- This works only if encoding is explicitly set, otherwise
-- it gives "invalid byte sequence" error at run-time

在我看来,我需要配置一些我的虚拟环境,或者可能重建 GHC 本身。

我尝试将语言环境设置为 en.UTF-8 UTF-8,但没有帮助(最初我根本没有进行语言环境配置)。

更新:目标文件有 UTF-8 编码:

$ file -bi test-file.md
text/x-c++; charset=utf-8

最佳答案

最后,我发现我的虚拟语言环境设置不正确,例如locale 命令显示所有 LANG 变量都设置为 POSIX

LANG 变量导出到命令是最快的解决方法(bash 示例):

export LANG=en_US.UTF8 cabal build

但是,您可能需要安装 en_US 语言环境,Debian 手动配置是:

  1. 编辑文件/etc/locale.gen,添加新行en_US.UTF-8 UTF-8
  2. 调用 locale-gen 生成语言环境。
  3. 导出 LANG 变量。

Debian 语言环境维基 1

附言我的默认 Debian Wheezy 安装在默认语言环境列表中有 C.UTF-8,所以我相信极简主义的目的是可以使用它而不是安装额外的英语语言环境,但是我没有亲自测试。

关于linux - Haskell:quoteFile 在 unicode 字符上带有 "invalid byte sequence"的文本文件上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30421845/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com