today'work
Maven에서 개행문자 LF로 고정하기.
msna
2023. 11. 2. 23:03
개요
- Maven플러그인으로 YAML스키마 파일을 Java코드를 생성하는 부분이 있다.
- Maven플러그인은 실행환경에 따라서 윈도우는 CRLF로 맥에서는 LF로 개행되는 자바코드를 만든다.
- 프로젝트에 참여하는 인원은 윈도우도 쓰고 맥도 쓰고있다.
- GIT을 쓰는데 개행문자는 LF로 통일하였다.
- 하지만 Java코드를 생성할 때는 윈도우에서는 CRLF로 만들어져 버리고 자동생성 코드라 그런지 아무 생각없이 커밋하는 경우가 많다.
- CRLF로 만들어진 코드를 LF로 바꾸고, 이번에 변경된 파일이 아니면 커밋을 안하면 되는 일이지만, 잘 지켜지지 않고 귀찮다.
- 가장 좋은 방법은 코드를 생성할 때 무조건 LF로 만들어지는 것.
- 결론부터 말하고 어떻게 해결방법을 찾았는지 다시 설명하겠다.
결론
Maven프로젝트의 .mvn/jvm.config파일에 개행문자를 지정해준다.- 위와 같이 처리하면 플러그인만의 동작에는 문제가 없지만,
전체 동작이나 Intellij의 Maven동작시 Maven자체가 동작하지 않는 문제가 발생하였다.
- Maven Wrapper를 추가해서 처리하고자 하였으나 이것도 잘 동작하지 않았다.
- 어쩌면 파라미터나 개행문자의 처리 방식이 잘못되었을지도...
- 전용 Maven자체를 설치하면 될 것 같은데... 우선은 좀 더 좋은 방법이 있을까 기다려봐야겠다.
- Maven Wrapper를 추가해서 처리하고자 하였으나 이것도 잘 동작하지 않았다.
코드생성 플러그인: jsonschema2pojo-maven-plugin
- 이름을 보면 알겠지만 JSON스키마를 POJO로 만들어주는 플러그인이다.
- 이 프로젝트에서는 JSON스키마는 안쓰고 YAML스키마를 쓴다.
- YAML스키마가 있는 디렉토리를 sourceDirectory에 지정하고
sourceType에 yamlschema를 지정하고
outputDirectory과 targetPackage를 지정하고 Maven 컴파일 동작을 하면 자바 코드가 만들어진다.
실마리를 찾아서
- configuration에 대한 문서를 찾을 수 없어서 코드를 보기로 했다.
- line이나 seperator가 들어가는 부분을 찾았으나 없었다.
- 그래서 실제 파일을 출력하는 부분까지 찾아가다 아래와 같은 코드를 발견했다.
개행문자 파라미터로 넘기기
- 결국 line.separator라는 시스템 변수만 설정하면 되는것으로 보인다.
- Maven의 명령어(mvn compile)에 -Dline.separator=$'\n'을 추가해준다.
- 안된다.
Maven실행파일에 직접 추가하기
- Maven이 설치된 곳을 찾아본 사람은 알겠지만, mvn은 바이너리가 아닌 스크립트이고 수정도 가능하다.
- 아래와 같이 수정해주니 개행문자가 LF로 바뀐다.
- 이제부터 이 메이븐을 쓰면 개행문자는 LF로 될 것이다.
(line.separator변수를 쓴다는 가정하에)
.mvn/jvm.config파일 설정하기
- 우선 성공은 하였지만, 프로젝트 참여자들이 위와 같은 작업을 하는 것은 좀 좋지 않은 것 같다.
- 좀더 살펴보면 MAVEN_OPTS라는 변수가 있고, Maven프로젝트 디렉토리의 ./mvn/jvm.config파일을 읽어들이는 것 같다.
- jvm.config파일을 만들고 다시 실행하니 성공.
- 이제 ./mvn/jvm.config만 커밋하면 다른 사람들도 똑같은 결과를 얻을 수 있게 되었다.