반응형

현재 작업중인 소스코드가 git에 마지막으로 commit된 소스코드와

비교를 해야할 경우가 종종 발생한다.

이럴경우 이전 commit코드와 비교하여 추가,삭제 및 수정된 부분을

알 수 있도록 보여주는 기능(Code Review)을 사용하도록 하자. 

 

View / Show Code Review

Shift + Option + Command + Enter

 

'Code Review' 가 활성화되면 Xcode 우상단 아이콘(1번)이 아래 그림과 같이 변경된다.

또한 우측 목록 아이콘을 클릭하여 Inline, Side By Side 비교방법(2번)을 선택할 수 있다.

 

Inline Comparision - 현재 소스코드에서 저장된 코드와의 비교

다음과 같이 변경된 부분은 좌측 라인번호에 파란색 마크가 생긴다.

 

Side By Side Comparision - 현재 소스코드와 저장된 코드를 화면분할 출력하여 비교

다음과 같이 현재 코드와 저장된 코드를 둘다 출력하여 변경된 부분을 비교해 준다.

 

 

반응형

'개발 > Note' 카테고리의 다른 글

랜덤 seed 초기화  (0) 2022.11.18
matplotlib 사용  (0) 2022.11.18
20진수 변환  (0) 2021.09.16
RSA 암복호화 테스트  (0) 2021.02.05
RSA key 파일 생성  (0) 2021.02.05
블로그 이미지

SKY STORY

,
반응형

정치, 종교 얘기를 하지 말아야 하는 이유  

                                              written by netcanis

 

누군가 삼각형을 원이라고 말하면 어떻게 반응할까?

분명 삼각형인데 어딜 봐도 삼각형인데 말이다…

당연히 싸움이 생길 수 있다.

 

대부분 사람들은 2차원적 사고를 한다. 이런 사람들 눈에는 

삼각형은 삼각형, 원은 원인 것이다.

 

예를 들어 아래 원뿔(Circular Cone) 그림을 보자.

원뿔

 

이 도형을 앞에서 바라보면 삼각형으로 보이며

위나 아래에서 바라보면 원으로 보인다.

 

앞에서 얘기한 2차원적인 사람들 눈에는 2가지 모양으로 보인다.

당연히 삼각형으로 보는 사람에게 원이라고 말해도…

원으로 보는 사람에게 삼각형이라 말해도…

그들은 절대 믿지 않을 것이다.

 

왜냐하면 정말 그들이 바라볼 때는 

삼각형이나 원으로 만 보이기 때문이다…

 

당신이 원뿔을 볼 수 있다면 침묵할 것을 권고한다.

그렇지 않으면 미친 사람이 될 수 있으니까…

 

반응형
블로그 이미지

SKY STORY

,
반응형

하이브리드 앱을 제작하다 보면 웹페이지에서 저장한 데이터(쿠키, 캐시)를

삭제해야 하는 경우가 생긴다.

하지만 모든 저장 데이터를 삭제하다 보면 다른 웹 페이지에 저장된 데이터까지

모두 삭제되어 예외사항이 발생할 수 있다.

 

특정 페이지에서 저장된 데이터만 삭제하는 코드를 알아보자.

// 다음과 같이 displayName을 이용하여 특정 데이터만 삭제.
WKWebsiteDataStore.default().fetchDataRecords(ofTypes: WKWebsiteDataStore.allWebsiteDataTypes()) { records in
	WKWebsiteDataStore.default().removeData(ofTypes: WKWebsiteDataStore.allWebsiteDataTypes(),
                                            for: records.filter { $0.displayName.contains("mytest.com") },
                                            completionHandler: {
                                                print("\("delete website data")")
                                            })
}

 

다음은 모든 캐시데이터 및 특정 도메인 쿠키 삭제

// 모든 캐시데이터 삭제
let cacheDataTypes : Set<String> = [WKWebsiteDataTypeDiskCache, WKWebsiteDataTypeMemoryCache]
let date = Date(timeIntervalSince1970: 0)
WKWebsiteDataStore.default().removeData(ofTypes: cacheDataTypes,
                                        modifiedSince: date ,
                                        completionHandler: {
                                            print("delete cache data")
                                        })
                                        
                                        
                                        
// 특정 도메인 쿠키만 삭제
let cookieDataType : Set<String> = [WKWebsiteDataTypeCookies]
WKWebsiteDataStore.default().fetchDataRecords(ofTypes: cookieDataType) { records in
    WKWebsiteDataStore.default().removeData(ofTypes: cookieDataType,
                                            for: records.filter { $0.displayName.contains("mytest.com") },
                                            completionHandler: {
                                                print("delete cookie data")
                                            })
}

 

웹 저장 데이터 로그 출력 

// 쿠키 정보 보기 
WKWebsiteDataStore.default().httpCookieStore.getAllCookies { cookies in
    for cookie in cookies {
        print("cookie : \(cookie)")
    }
}



/* 
출력 로그 :
cookie : <NSHTTPCookie
	version:1
	name:JSESSIONID
	value:43C2101193D26FDE7F2DB61D86E15B0E
	expiresDate:'(null)'
	created:'2021-09-17 00:06:31 +0000'
	sessionOnly:TRUE
	domain:www.mytest.com
	partition:none
	sameSite:none
	path:/
	isSecure:FALSE
	isHTTPOnly: YES
 path:"/" isSecure:FALSE isHTTPOnly: YES>
 */

 

 

 

 

반응형

'개발 > iOS' 카테고리의 다른 글

문자열 숫자에 콤마 넣기  (0) 2022.10.14
유니버셜 링크(Universal Links) 문제점 해결  (0) 2022.07.21
버전분기 샘플  (0) 2021.08.02
시뮬레이터 분기  (0) 2021.08.02
Foreground 이벤트 받기  (0) 2021.08.02
블로그 이미지

SKY STORY

,

20진수 변환

개발/Note 2021. 9. 16. 11:44
반응형

7세그먼트 LED는 아래와 같이 숫자 및 일부 영문자를 표시해 주는 디지털 표시 모듈이다.

7 세그먼트 LED

 

이 모듈에 숫자 이외에 출력 가능한 영문자는 다음과 같다.

A, b, C, d, E, F, H, L, P, U

이 모듈에 표현 가능한 최대 숫자는 10진수로 표현할 경우 0~9 10개의 

숫자(10진수)만 가능하지만 영문까지 사용할 경우 0~9, A~U

총 20개의 숫자/문자(20진수) 표현이 가능해 진다.

펌웨어 프로그래밍 작업을 하다보면 10진수와 20진수 변환해야

하는 경우가 생길 수 있는데 다음과 같이 변환하여 처리해 보았다.

 

// 20진수 문자열을 10진수 자료형 변수로 변환
/*
 좌측부터 10, .... 19
 A, b, C, d, E, F, H, L, P, U
 
 20진수 아스키코드 
 A:65(0x41)
 b:98(0x62)
 C:67(0x43)
 d:100(0x64)
 E:69(0x45)
 F:70(0x46)
 H:72(0x48)
 L:76(0x4C)
 P:80(0x50)
 U:85(0x55)
*/
unsigned long long convert20to10(char* str) {
    unsigned long long result = 0;
    unsigned long len = strlen(str);
    for (unsigned long i = 0; i < len; i++ ) {
        if ( str[i] >= 'A' && str[i] <= 'F' ) {         // A(65) ~ F(70)
            result = result * 20 + str[i] - 'A' + 10;
        } else if ( str[i] >= 'a' && str[i] <= 'f' ) {  // a(97) ~ f(102)
            result = result * 20 + str[i] - 'a' + 10;
        } else if ( str[i] >= '0' && str[i] <= '9' ) {  // 0(48) ~ 9(57)
            result = result * 20 + str[i] - '0';
        }
        else if (str[i] == 'H' || str[i] == 'h' ) { result = result * 20 + 16; }// H(72),h(104)
        else if (str[i] == 'L' || str[i] == 'l' ) { result = result * 20 + 17; }// L(76),l(108)
        else if (str[i] == 'P' || str[i] == 'p' ) { result = result * 20 + 18; }// P(80),p(112)
        else if (str[i] == 'U' || str[i] == 'u' ) { result = result * 20 + 19; }// U(85),u(117)
    }
    return result;
}


// 10진수 자료형 변수 값을 20진수 문자열로 변환
void convert10to20(unsigned long long decimal, char *result) {
    char szTemp[256] = {0,};
    unsigned long pos = 0;
    while(true) {
        unsigned long mod = decimal % 20;
        if (mod < 10) { // 0 ~ 9
            szTemp[pos] = 48 + mod;
        } else { //  A, b, C, d, E, F, H, L, P, U
            switch (mod) {
                case 10: szTemp[pos] = 'A'; break;
                case 11: szTemp[pos] = 'b'; break;
                case 12: szTemp[pos] = 'C'; break;
                case 13: szTemp[pos] = 'd'; break;
                case 14: szTemp[pos] = 'E'; break;
                case 15: szTemp[pos] = 'F'; break;
                case 16: szTemp[pos] = 'H'; break;
                case 17: szTemp[pos] = 'L'; break;
                case 18: szTemp[pos] = 'P'; break;
                case 19: szTemp[pos] = 'U'; break;
                default: break;
            }
        }
        decimal = decimal / 20;
        pos += 1;
        if (decimal == 0)
            break;
    }
    for (unsigned long i=0; i<pos; ++i) {
        result[i] = szTemp[pos-1-i];
    }
}

 

 

반응형

'개발 > Note' 카테고리의 다른 글

matplotlib 사용  (0) 2022.11.18
git 소스코드 비교  (0) 2022.02.23
RSA 암복호화 테스트  (0) 2021.02.05
RSA key 파일 생성  (0) 2021.02.05
용어 정리  (0) 2021.02.05
블로그 이미지

SKY STORY

,
반응형

사람은 흔히 자기가 처해 있는 상태를

환경의 탓이라고 불평한다.

나는 환경이라는 것을 믿지 않는다.

성공하는 사람들이란

자기가 바라는 환경을 찾아내는 사람들이다.

그리고 발견하지 못하면 자기가 만들면 된다.

 

- 조지 버나드 쇼 -

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

반응형
블로그 이미지

SKY STORY

,
반응형

1.Teslausb 다운로드

https://github.com/marcone/teslausb

현재 최신버전 Teslausb-20201211.zip파일 다운로드

https://github.com/marcone/teslausb/releases/tag/v2.5

 

 

2.Etcher 다운로드 및 설치

https://www.balena.io/etcher/

 

3.SMB teslausb conf 파일(teslausb_setup_variables.conf) 다운로드 

https://github.com/dasonwong/teslausb_variables

 

4.1번 파일(teslausb)을 더블클릭하여 마운트 시킨다. boot 드라이브에 3번파일을 복사한다.

 

5.SMB teslausb conf 파일에서 와이파이 접속 정보를 설정한다.

라즈베리파이 제로 W는 2.4Ghz 와이파이만 지원된다.

export SSID='netcanis'

export WIFIPASS='123456'

 

6.SMB teslausb conf 파일에서 와이파이 AP 접속 정보를 설정하고 저장.

비밀번호는 8자 이상이어야 한다.

export AP_SSID='teslausb'

export AP_PASS='12345678'

 

 

7.micro sd카드를 아답터에 삽입하여 컴퓨터에 연결한다.

 

8.balenaEtcher 실행하여 1번파일을 선택한다.

 

9.usb메모리 드라이브 선택하고 'Flash'버튼을 선택하여 라이팅한다.

 

10.완료되면 usb드라이브 제거후 microsd카드를 빼서 라즈베리파이에 넣는다.

11.iPhone 설정에서 핫스팟을 켜준다. 

 

 

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 1

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 2

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 3

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 4

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 1

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 2

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 3

 

 

 

반응형
블로그 이미지

SKY STORY

,
반응형

15.패스워드를 변경해 준다.

pi@teslausb:~ $ passwd

Changing password for pi.

Current password: [현재 패스워드 입력]

New password: [새로운 패스워드 입력]

Retype new password: [새로운 패스워드 재입력]

#passwd: password updated successfully

 

16.설정이 완료(약 10분)되면 자동 리부팅되며 이재부터는 부팅시 화면에 출력되는 내용은 없다.

17.라즈베리파이가 정상동작되는지 확인하려면 전원을 컴퓨터 USB단자에 연결했을 때 

라즈베리파이가 USB드라이브로 연결되고 'TeslaCam'폴더가 생성되어 있다면 성공이다.

 

17.재부팅 이후 휴대폰으로 와이파이 ‘teslausb’에 접속한다. (설정한 WiFi AP SSID로 접속)

18.앱스토어에서 'Cam Viewer for Tesla'앱을 다운로드 받아 실행하여 저장된 영상을 확인한다.

 

Cam Viewer for Tesla

https://apps.apple.com/us/app/cam-viewer-for-tesla/id1476197999

 

‎Cam Viewer for Tesla

‎Introducing Cam Viewer App with Tesla Software v10 Support You can now view your Tesla captured video directly on your iOS device. Note: to access a USB drive on your device requires iOS 13 AND the Lightning to USB 3 Camera Adapter. Plug in power to the

apps.apple.com

 

Documents:Files, PDF, Browser  (SMB 폴더 브라우징)

https://apps.apple.com/us/app/documents-files-pdf-browser/id364901807

 

‎Documents: Files, PDF, Browser

‎A central hub for all your files. Read, listen, view, annotate almost anything you want on your iPad and iPhone. Files, documents, books, any content is at home in Documents by Readdle. It’s the Finder for iOS you’ve always wanted. App Store Editors

apps.apple.com

 

https://apps.apple.com/us/app/sentry-dashcam-for-teslas/id1514151653

 

‎Sentry DashCam for Teslas

‎Introducing the simplest, and most hassle-free way to download, watch, and share your Tesla Sentry and DashCam Videos. Now with wireless support for Raspberry Pi 4 and Raspberry Pi Zero W(beta), Tesla Sentry DashCam is the simplest, and most hassle-free

apps.apple.com

 

 

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 1

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 2

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 3

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 4

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 1

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 2

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 3

 

 

 

반응형
블로그 이미지

SKY STORY

,
반응형

[ 라즈베리 파이에 사용할 모니터, 키보드, 마우스가 있을 경우 ]

12.라즈베리파이에 모니터, 키보드, 마우스를 연결한 후 전원을 연결한다.

13.휴대폰의 개인용 핫스팟에 라즈베리 파이가 연결되는지 확인한다. (좌상단 시계가 파란색으로 변하면 연결완료)

14.첫로그인  계정은 pi / raspberry 이다.

 

 

[ 라즈베리 파이에 사용할 모니터, 키보드, 마우스가  없을 경우 ]

12.사용자 컴퓨터도 휴대폰 핫스팟에 연결한다. 

13.mac컴퓨터 콘솔을 실행하여 ssh접속한다.

ssh pi@teslausb.local

yes입력

 

14.첫로그인 시 계정은 pi / raspberry 이다.

 

14-1.파일목록 보기

 

14-2.설정 로그 보기

 

14-3.설치가 완료되면 업그레이드를 한다.

sudo -I

bin/setup-teslausb upgrade

 

 

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 1

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 2

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 3

2021.08.09 - [Tesla] - Teslausb를 사용하여 TeslaCam 비디오를 무선으로 보기 - Step 4

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 1

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 2

2021.08.10 - [Tesla] - Rclone 설정 (Google Drive에 TeslaCam 파일 업로드) - Step 3

 

 

 

반응형
블로그 이미지

SKY STORY

,