lex 구문 분석중 정규 표현식 질문입니다.
글쓴이: jbkdd / 작성시간: 월, 2005/05/30 - 10:15오후
yacc/lex 로 작성된 ANSI C grammar 분석중 잘 모르는 정규표현식이 있어서... 해석좀 부탁 드립니다.
L?\"(\\.|[^\\"])*\" { count(); return STRING_LITERAL); }
L?'(\\.|[^\\'])+' { count(); return(CONSTANT); }
위 두 문장입니다..
리턴 값으로 봐서는 겹따옴표("") 홑따옴표('')를 의미 하는것 같은데 정확한지 모르겠군요...
원문은
http://kbs.cs.tu-berlin.de/~jutta/c/ANSI-C-grammar-y.html
입니다. 그럼
Forums:
검색해보니 답이 있네요..문자열 ,문자 상수 매칭 이군요 그런
검색해보니 답이 있네요..
문자열 ,문자 상수 매칭 이군요
그런데 '\' 문자를 왜 따로 매칭 하는지 이해가 좀...
', " 를 위한 escape 시퀀스 를 처리할려면 해야겠죠
', " 를 위한 escape 시퀀스 를 처리할려면 해야겠죠
-- 아쉬운 하루 되세요 --
다음 문자들을 제외하고자 합니다.L?\"(\\.|[^\\"])*\
다음 문자들을 제외하고자 합니다.
L?\"(\\.|[^\\"])*\" 의 경우
의 문자를 제외합니다.
L?'(\\.|[^\\'])+' 의 경우
의 문자를 제외합니다.
Lex 에서..."[string]"를 처리해 줄 수 있는 방법이 있나
Lex 에서...
"[string]"를 처리해 줄 수 있는 방법이 있나요 ?
'['[a-zA-Z]+']'
'['[:alpha:]+']'
둘다 잘 안되는것 같더군요..
원래 하고자 하는것은...
[]사이에 들어갈 수 있는 스트링으로 "a-zA-Z0-9_/^" 이지만..
이거 쉽게 처리할 수 있는 방법이 안보이네요..
orz
자세한 내용은 정규수식을 참조하시기 바랍니다.['[a-zA-Z]+
자세한 내용은 정규수식을 참조하시기 바랍니다.
['[a-zA-Z]+']' 또는 '['[:alpha:]+']'
여기서 [a-zA-Z]+ 이부분을 원하시는 부분
으로 변경하시면 될것 같습니다.
첫문자로 항상 알파벳이란 가정이 있다면 정규수식을 좀더 활용해야 합니다.
[quote="lovewar"]자세한 내용은 정규수식을 참조하시기 바랍니
감사합니다.
근데 지금은 다른일에 치여서 한 일주일정도 여기에 손을 댈 수가 없겠군요.
확인해 보겠습니다.
그럼...
'['[:walpha:][[:walpha:]_/^']*]'
이렇게 하면 되겠군요...
unicode 환경으로 개발하고있거든요....
WOW Wow!!!
Computer Science is no more about computers than astronomy is about telescopes.
-- E. W. Dijkstra
댓글 달기