티스토리 뷰

개요

  • Maven플러그인으로 YAML스키마 파일을 Java코드를 생성하는 부분이 있다.
  •  Maven플러그인은 실행환경에 따라서 윈도우는 CRLF로 맥에서는 LF로 개행되는 자바코드를 만든다.
  • 프로젝트에 참여하는 인원은 윈도우도 쓰고 맥도 쓰고있다.
  • GIT을 쓰는데 개행문자는 LF로 통일하였다.
  • 하지만 Java코드를 생성할 때는 윈도우에서는 CRLF로 만들어져 버리고 자동생성 코드라 그런지 아무 생각없이 커밋하는 경우가 많다.
  • CRLF로 만들어진 코드를 LF로 바꾸고, 이번에 변경된 파일이 아니면 커밋을 안하면 되는 일이지만, 잘 지켜지지 않고 귀찮다.
  • 가장 좋은 방법은 코드를 생성할 때 무조건 LF로 만들어지는 것.
  • 결론부터 말하고 어떻게 해결방법을 찾았는지 다시 설명하겠다.

결론

  • Maven프로젝트의 .mvn/jvm.config파일에 개행문자를 지정해준다.
  • 위와 같이 처리하면 플러그인만의 동작에는 문제가 없지만,
    전체 동작이나 Intellij의 Maven동작시 Maven자체가 동작하지 않는 문제가 발생하였다.
    • Maven Wrapper를 추가해서 처리하고자 하였으나 이것도 잘 동작하지 않았다.
      • 어쩌면 파라미터나 개행문자의 처리 방식이 잘못되었을지도...
    • 전용 Maven자체를 설치하면 될 것 같은데... 우선은 좀 더 좋은 방법이 있을까 기다려봐야겠다.

 

코드생성 플러그인: jsonschema2pojo-maven-plugin

  • 이름을 보면 알겠지만 JSON스키마를 POJO로 만들어주는 플러그인이다.
  • 이 프로젝트에서는 JSON스키마는 안쓰고 YAML스키마를 쓴다.
  • YAML스키마가 있는 디렉토리를 sourceDirectory에 지정하고
    sourceType에 yamlschema를 지정하고
    outputDirectory과 targetPackage를 지정하고 Maven 컴파일 동작을 하면 자바 코드가 만들어진다.

 

실마리를 찾아서

  • configuration에 대한 문서를 찾을 수 없어서 코드를 보기로 했다.
  • line이나 seperator가 들어가는 부분을 찾았으나 없었다.
  • 그래서 실제 파일을 출력하는 부분까지 찾아가다 아래와 같은 코드를 발견했다.

JPackage.class
PrintWriter.java
System.java

 

개행문자 파라미터로 넘기기

  • 결국 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만 커밋하면 다른 사람들도 똑같은 결과를 얻을 수 있게 되었다.

 

 

참고자료