(WinAPI) 디렉터리 제어 응용

IT/Programming/WinAPI 2014. 4. 21. 15:13

 

출처 : http://blog.daum.net/studiocoma/6521408

 

Win32 API가 제공하는 CreateDirectory 함수의 응용.

API CreateDirectory의 경우 c:\1\2\3을 만들때 c:\1\2가 이미 존재하지 않으면 실패한다. -_-

이를 보완하고(상위폴더부터 주구장창 만들어 낸다;) 경로에 파일명까지 포함되어 있어도 폴더만 만들도록 해봤다.
- 말은 거창(?)한데 그냥 문자열 파싱해서 CreateDirectory를 반복 호출한다;; 

BOOL _CreateDirectory( LPCTSTR lpszPath )
{
    TCHAR szPathBuffer[MAX_PATH];

    size_t len = _tcslen( lpszPath );

    for ( size_t i = 0 ; i < len ; i++ )
    {
        szPathBuffer[i] = *( lpszPath + i );
        if ( szPathBuffer[i] == _T('\\') || szPathBuffer[i] == _T('/') )
        {
            szPathBuffer[i + 1] = NULL;
            if ( ! PathFileExists( szPathBuffer ) )
            {
                if ( ! ::CreateDirectory( szPathBuffer, NULL ) )
                {
                    if ( GetLastError() != ERROR_ALREADY_EXISTS )
                        return FALSE;
                }
            }
        }
    }
    return TRUE;
}


-----------------------------------------------------------------------------------------


CFileFind fileFinder;
 if(!fileFinder.FindFile(".\\simple\\MyMenu.mdb"))
 {
  CreateDirectory(".\\simple", NULL);
  CopyFile(".\\MyMenu.mdb", ".\\simple\\MyMenu.mdb", TRUE);
 }



부모디렉토리없어도 디렉토리 생성하기, 디렉토리에 파일있어도 하위디렉토리까지 모든파일 삭제하기


출처 :  http://www.devpia.com/MAEUL/Contents/Detail.aspx?BoardID=51&MAEULNo=20&no=7293&ref=7293

 

 

#include <windows.h>

#include <stdio.h>

#include <string>

 

using namespace std;

 

/*

 

  기존 디렉토리가 있을경우 안만들어지고 없으면 만든다. 부모디렉토리가 없어도 생성가능

 

*/

void CreateDir(char* Path)

{

    char DirName[256];  //생성할 디렉초리 이름

    char* p = Path;     //인자로 받은 디렉토리

    char* q = DirName;  

 

    while(*p)

    {

        if (('\\' == *p) || ('/' == *p))   //루트디렉토리 혹은 Sub디렉토리

        {

            if (':' != *(p-1))

            {

                CreateDirectory(DirName, NULL);

            }

        }

        *q++ = *p++;

        *q = '\0';

    }

    CreateDirectory(DirName, NULL);  

}

 

 

/*

 

 하위디렉토리를 제외한 해당 디렉토리 모든 파일들을 제거

 

 */

void DeleteAllFiles(char* folderPath)

{

    char fileFound[256];

    WIN32_FIND_DATA info;

    HANDLE hp;

 

    sprintf(fileFound, "%s\\*.*", folderPath);

    hp = FindFirstFile(fileFound, &info); //디렉토리에 파일이 있는지 첫번째 파일만.

    do

    {

        sprintf(fileFound,"%s\\%s", folderPath, info.cFileName);

        DeleteFile(fileFound);

 

    }while(FindNextFile(hp, &info));  //다른 파일이 있을때 까지

 

    FindClose(hp);

}

 

 

/*

 

 해당 하는 디렉토리에 파일이 존재해도  디렉토리가 비어있지 않아도 지울수 있다 .

 

*/

 

void EmptyDirectory(char* folderPath)

{

    char fileFound[256];

    WIN32_FIND_DATA info;

    HANDLE hp;

 

    sprintf(fileFound, "%s\\*.*", folderPath);

    hp = FindFirstFile(fileFound, &info);   //디렉토리에 파일이 있는지 첫번째 파일만.

    do

    {

        if (!((strcmp(info.cFileName, ".")==0)||(strcmp(info.cFileName, "..")==0)))

        {

            if((info.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)==FILE_ATTRIBUTE_DIRECTORY)  //Sub디렉토리가 존재하는경우

            {

                string subFolder = folderPath;

                subFolder.append("\\");

                subFolder.append(info.cFileName);

                EmptyDirectory((char*)subFolder.c_str()); /// {return (_Ptr == 0 ? _Nullstr() : _Ptr); }

                RemoveDirectory(subFolder.c_str());

            }

            else

            {

                sprintf(fileFound,"%s\\%s", folderPath, info.cFileName);

                BOOL retVal = DeleteFile(fileFound);

            }

        }

 

    }while(FindNextFile(hp, &info));

 

    FindClose(hp);

}


 

-----------------------------------------------------------------------------------------


CreateDirectory 에서 폴더 접근 권한 바꾸기


출처 : http://ktr0.egloos.com/757379


Windows API 를 보면 CreateDirectory 라는 함수가 있다.

CreateDirectory("c:\aaa",NULL);

위와 같은 방법으로 첫번째 파라메터에 폴더 이름을 써 주고
두번째 파라메터에 NULL 을 써 주는 경우가 많다.

두 번째 파라메터는 사실 보안에 대한 파라메터이다.

PSECURITY_ATTRIBUTE 형의 변수가 들어가는데, NULL 이면 부모 폴더의
값을 그대로 가져온다.

 SECURITY_ATTRIBUTES sa;
 SECURITY_DESCRIPTOR sd;
 PSID pEveryoneSID = NULL;
 SID_IDENTIFIER_AUTHORITY SIDAuthWorld = SECURITY_WORLD_SID_AUTHORITY;
 EXPLICIT_ACCESS ea[2];
 PACL pacl = NULL;
 if(!AllocateAndInitializeSid(&SIDAuthWorld,1, SECURITY_WORLD_RID,0,0,0,0,0,0,0,&pEveryoneSID))
 {
  AfxMessageBox("Fail to get Everyone SID!!!",0,0);
  return;
 }
 ZeroMemory(&ea, 2*sizeof(EXPLICIT_ACCESS));
 ea[0].grfAccessPermissions = GENERIC_ALL;
 ea[0].grfAccessMode = SET_ACCESS;
 ea[0].grfInheritance = SUB_CONTAINERS_AND_OBJECTS_INHERIT;
 ea[0].Trustee.TrusteeForm = TRUSTEE_IS_SID;
 ea[0].Trustee.TrusteeType = TRUSTEE_IS_WELL_KNOWN_GROUP;
 ea[0].Trustee.ptstrName = (LPTSTR) pEveryoneSID;

 SetEntriesInAcl(1,ea, NULL, &pacl);
 InitializeSecurityDescriptor(&sd,SECURITY_DESCRIPTOR_REVISION);
 SetSecurityDescriptorDacl(&sd, TRUE,pacl , FALSE);
 //SetSecurityDescriptorSacl(&sd, TRUE,pacl , FALSE);


 sa.nLength = sizeof (SECURITY_ATTRIBUTES);
 sa.lpSecurityDescriptor = &sd;
 sa.bInheritHandle = TRUE;
 
 ::CreateDirectory(sysDirBuffer_tmp,&sa);
 if(pEveryoneSID){
  FreeSid(pEveryoneSID);
 }
 if(pacl){
  LocalFree(pacl);
 }

위의 예가 바로 CreateDirectory 함수에서 SECURITY_ATTRIBUTE 값을 가지고
폴더에 모든 ACCESS 권한을 주는 예제이다.

 

http://www.tipssoft.com/bulletin/board.php?bo_table=QnA&wr_id=380&page=392

GetCurrentDirectory 함수 : 현재의 작업 디렉토리를 얻어온다. 
SetCurrentDirectory 함수 : 작업디렉토리의 경로를 셋팅한다. 

일반적으로 작업디렉토리는 파일이 실행된 경로가 지정됩니다. 
아래는 작업디렉토리의 변경이 일어나는 대표적인 예인 CFileDialog 대화상자를 이용한 경우입니다 

참고하시면 될 듯 싶습니다. 


    char path[MAX_PATH] = {0}; 
    // 현재의 작업디렉토리를 저장한다. 
    GetCurrentDirectory(MAX_PATH, path); 

    // CFileDialog 를 Open 모드로 생성한다. 
    CFileDialog dlg(TRUE); 
    if(dlg.DoModal()==IDOK){ 
                // 사용자가 폴더를 옮겨가며 특정 파일을 지정 
                // 이경우 작업폴더가 변경됨. 
                CString str = dlg.GetFileName(); 
                //얻어온 파일과 관련된 코드 추가.............. 
                
                // 이전에 저장했던 작업디렉토리 경로를 되돌려 셋팅 
                SetCurrentDirectory(path); 
    }

 

 

=============================================

 

Directory 컨트롤에 관하여 좋은 응용 예제를 모아놓은 블로그(http://blog.naver.com/dolicom/10096040743)에서 관련된 내용을 퍼왔다.

 

위의 응용 예제도 나쁘지 않지만, CreateDirectory 를 사용하여 디렉터리 트리를 구성할 때에는 CreateDirectory() 보다는 SHCreateDirectory / SHCreateDirectoryEx() 를 사용하는 것이 훨씬 편하다.

 

 SHCreateDirectoryEx(NULL, "C:\\a\\b\\", NULL);

 

이런식으로만 하면 a 폴더가 없더라도 a\b 폴더 둘 다 만들어지기 때문이다. 해당 함수를 쓰기 위해서는 Shlobj.h 를 포함시켜야 한다.

 

SHCreateDirectoryEx : http://msdn.microsoft.com/en-us/library/windows/desktop/bb762131(v=vs.85).aspx

 

SHSHFileOperation function : http://msdn.microsoft.com/en-us/library/windows/desktop/bb762164(v=vs.85).aspx

 

설정

트랙백

댓글

CentOS EPEL Repo 이용

IT/Programming/Solution/Tip 2014. 4. 16. 18:34

기본 패키지에서 설치할 수 없는 다양한 패키지들은 EPEL(Extra Packages for Enterprise Linux) 에서 구할수 있다.

 

CentOS EPEL Repo 를 설치해주고 원하는 패키지를 설치하면 된다.

 

아래는 weechat을 CentOS 5.4 에서 설치하는 예이다.

  1. Download the latest epel-release rpm from
    http://dl.fedoraproject.org/pub/epel/5/x86_64/
  2. Install epel-release rpm:
    # rpm -Uvh epel-release*rpm
  3. Install weechat-devel rpm package:
    # yum install weechat-devel
 

* 메신저로 추가 문의하는 사람이 있어 내용을 덧붙입니다.

여기서 EPEL 시리즈를 올바르게 설치하려면 위의 링크(http://dl.fedoraproject.org/pub/epel/5)에서 무작정 epel 을 내려 받지 마세요.

자신의 배포판 버젼과 시스템 아키텍쳐에 맞는 EPEL 을 설치하시길 바랍니다. 6.x 배포판을 x86_64 시스템 환경으로 구동하신다면

http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm 이 링크를 통해서 epel 을 설치할 수 있습니다.

 

epel rpm 은 올바르게 경로를 찾아가셔서 CTRL + F 로 epel 을 검색하셔서 rpm 주소를 가져오신 후, wget 등으로 rpm 을 내려받아 설치하시면 됩니다.

설정

트랙백

댓글

PHP 배열 활용 총망라

IT/Programming/Programming 2014. 4. 7. 20:13

(퍼온글) 출처 : http://www.picomax.net/xe/?mid=study&category=231&document_srl=557&sort_index=readed_count&order_type=desc&listStyle=viewer&page=54

 

======

 

php는 배열이 정말로 좋다... 신기하게도 모든 자료형과 객체들을 다 넣을 수 있다...

 

예전에 C를 배울때는 배열이 좋구나 라는 것을 느끼면서 하나씩 배우기는 시작했는데... C에서의 배열은 일단 틀(자료형과 개수)을 정해야한다는 단점이 있다.

그래서 여러가지 동적인 자료구조를 이용하지만 설정하는데 여러가지 번거로움이 존재한다.

자바에서는 그나마 배열이 동적으로 바뀌는 자료구조를 여러가지 채택하고 있지만... 연관배열 같은 구조는 바로 바로 쓰기 어렵다. 꼭 HashMap 이나 기타 다른 키값을 가지고 있는 클래스를 사용하여야 한다.

 

php는 스크립트 언어이다. 대부분의 스크립트 언어들이 유연한 자료구조로서 배열을 사용하는데 특히나 php는 따른 설정 없이 모든 자료형이 배열에 들어갈 수가 있다.

그래서 다른 언어에 있는 자료구조 형식을 따로 만들어 줄 필요가 없다... 그래서 php 하는 사람들이 자료구조에 약한가.. 흠.. ^^;;

 

  1. 모든 것을 담아라.

array 형은 모든 것을 담을 수 있다.

 

$arr = array(1, '안녕', 234.566, new Object(), array(1,2,3) );

 

여러가지 자료형을 동시에 담을 수 있다.

연관배열은 기본... $arr = array('aaa' => 'varchar'); 와 같은 방식으로 바로 바로 설정이 된다.

 

2. 특별한 자료 구조를 필요로 하지 않는다.

php에서는 배열은 동적으로 늘어나고 줄어들기 때문에 동적 자료구조를 만들 필요가 없다. 그리고 일반 자료구조처럼 조작할 수 있는 여러가지 함수들을 제공한다.

 

1) statck 형태로 사용하기

스택은 가장 나중에 들어간 데이타가 가장 먼저 나오는 구조이다. (LIFO)

pop, push 스택의 가장 기본적인 2가지 형태의 조작 방법이다.

pop은 가장 뒤에 있는 요소를 리턴해주고 배열에서 지워주는 것이고 push는 가장 뒤에 요소를 집어넣는다.

 

php는 array_pop($arr), array_push($arr, 데이타) 등으로 스택을 구현할 수 있다.

array_push 같은 경우는 언어 문법 상으로도 지원을 한다. $arr 이 배열일 경우 $arr[] = 데이타; 와 같은 형식은 array_push 와 같은 역할을 한다.

 

2 ) Queue 형태로 사용하기

Queue는 가장 먼저 들어간 데이타가 가장 먼저 나오는 구조 (FIFO) 이다.

그래서 큐는 기본적으로 push와 enqueue의 2가지 방법을 가진다. push는 데이타를 넣는 것이고 enqueue 는 젤 앞 요소를 리턴해주고 배열에서 삭제해준다.

 

php는 array_push($arr, 데이타), array_shift($arr) 등으로 구현한다.

 

3) Dequeue 형태로 사용하기

Dequeue 는 앞뒤 쪽으로 어느 곳으로 나 데이타를 빼고 넣을 수 있는 자료구조이다. stack과 queue를 잘 조합했다고 보시면 된다.

 

앞으로 넣을때는 array_unshift($arr, 데이타), 뒤로 넣을 때는 array_push($arr, 데이타)

앞에서 자료를 뺄 때는 array_shift($arr), 뒤로 자료를 뺄 때는 array_pop($arr)

4) 연결 리스트 (Linked List) 처럼 사용하기

연결 리스트라는 것은 배열의 단점을 보완하기 위해서 나온 것이다.

배열은 기본적으로 자료형과 크기가 정해져있다.

그래서 arr[100] 와 같이 100개의 요소를 가지는 배열을 선언해놓고 10개만 사용하면 메모리 사용측면에서 아주 안 좋게 된다.

이렇듯 메모리 사용을 좀 줄이고 유연한 배열 구조를 만들어 보고자 나온 것이 연결리스트이다. C에서는 포인터, java에서는 참조를 사용하지만

php에서는 애초에 동적으로 배열이 변하기 때문에 php의 배열 자체가 연결리스트와 비슷 하다고 보시면 된다.

 

연결리스트의 가장 좋은 점이 참조만으로 이루어진 자료형이라서 삽입과 삭제에 비용이 거의 들지 않는 다는 점이다.

php의 배열의 경우는 삭제는 쉽지만 중간에 삽입하는 것은 다른언어와 비슷한 절차를 가져야 한다.

삭제하는 방법은 unset($arr[10]) 과 같은 방법으로 요소를 메모리에서 지우면 된다.

 

5) Hash

Hash 라는 것은 고유키를 만들어서 그 키와 데이타를 일대일로 매칭 시키는 기법이다. 일반적으로 사전과 비슷하다고 보시면 된다.

php는 배열 자체적으로 연관배열이라고 하는 것을 지원한다.

 

$arr['key'] = 'value'; echo $arr['key'];

 

아주 간단하게 hash 구조로 셋팅이 가능하다. 배열이 자체적으로 지원을 하기 때문이다. 스크립트 언어들이 대부분 이런 구조를 지원하지만

vb 스크립트는 지원하지 않아서 asp 코딩할때 약간의 생각을 더 해야한다.

 

※ 기타 다른 구조들도 많지만 지금은 생각이 안나서 잠시 접어두도록 하겠다.

 

3. 배열 제어 방법

이제는 실제 php에서 배열을 제어 하는 방법을 알아보자..

 

1) Iterator 형식

php는 foreach라는 키워드를 이용해서 배열 요소를 바로 접근할 수 있게 해준다.

foreach ($arr as $value) { echo $value ; }

 

키값을 가지고 있는 배열도 바로 사용 할 수 있다. 어떻게? ㅋ 바로 이렇게

foreach ($arr as $key => $value) { echo $key, $value; }

 

php5 들어오면서 재미난 기능이 하나 더 생겼다. php4에서는 foreach에서 나오는 배열 값을 실제 배열 요소로서 조작이 불가능했다. 하지만 php5에서는 가능하다.

foreach ($ass as &$value) { $value = $value.'aaa'; }

 

값을 참조 형태로 받을 수 있기 때문에 그 배열 요소에 있는 값들을 바로 수정하는 것도 가능하다. 재밌는 기능이다.

 

2) list, each 함수를 사용하기

list 함수는 배열을 각각의 변수로 바꿔주는 것이고 each는 배열에서 키와 값을 배열 형태로 넘겨주는 함수이다. 예를 들어서

$arr = array(0 => 1, 1=> 2, 2 => 3);

while(list($key, $value) = each($arr)) {

echo $key, $value;

}

 

대충 이런 형태로 가능한데. 요즘은 이렇게 쓰는 사람이 잘 없다. foreach가 더 심플하니깐.. .

 

3) 연관 배열은 key, value로 이루어져 있으니 그냥 셋팅만 해주면 된다.

$arr = array( 'key' => 'value' ); 형태로 셋팅하면 끝.. 사용할 때는 $arr['key'] 로 얻어오면 됨..

 

4. 배열을 위한 유틸리티 함수들

php의 동적 배열을 좀 더 자유롭고 유연하게 이용할 수 있도록 여러가지 함수들을 지원한다.

 

1) 키 또는 값으로만 배열 만들기

$keys = array_keys($arr);

$values = array_values($arr);

 

2) 배열 값을 유니크한 배열로 만들기

$unique = array_unique($arr); // 만약 값이 array(1, "1", 2, 3,"3") 이런식이라면 만들어 지는 배열은 array(1,2,3) 이 됩니다.

 

3) 배열 값으로 합계내기

$sum = array_sum($arr);

 

4) 배열 요소에 모두 특정 함수 사용하여 변환하기

보통 배열을 특정 함수를 이용해서 바꿀려고 하면 loop를 도는게 일반적인 방식이다.

for ($i = 0; $i < 10; $i++) {

$arr[$i] = strtoupper($arr[$i]);

}

 

하지만 php에서는 이런상황을 위해서 여러가지를 지원하는데 가장 간단한 구조가 array_map 이다. array_map은 주어진 함수를 가지고 변환한 값들을 새로운 배열로 만들어 낸다. 위의 제어 구분을 아주 간단하게 바꾸면 아래와 같다.

 

$arr = array_map('strtoupper', $arr); // 모든 요소 대문자로 변경

$arr = array_map('trim', $arr); // 모든 요소 공백 제거

 

여기서 앞에 사용되어지는 함수 이름은 문자열로 들어간다. 함수는 매개변수를 하나만 가진다.

 

5) 배열 2개로 연관 배열 만들기

$keys = array('1','2','3','4');

$values = array('a','b','c','d');

 

$arr = array_combine($keys, $values) ; 하면

$arr = array('1' => 'a' , '2' => 'b', '3' => 'c', '4' => 'd'); 와 같은 형태로 변경이 된다.

 

6) 배열에 값이 있는지 없는지 체크하기

단순하게 체크 할 때는 in_array 라는 함수를 사용한다.

$arr = array(1, 2, 3, 4, 5,);

if (in_array(1,$arr)) { echo "1 포함"; }

 

아주 쉽다. 그렇다면 배열에 배열이 들어가 있는 이중배열은 어떻게 될까?

$arr = array(array(1, 2,), 3, 4, 5, array(6, 7));

if (in_array(array(1,2), $arr)) { echo "array(1, 2) 가 있음 "; }

 

배열 자체적으로 체크도 가능하다.

 

7) 자료형이 배열인지 알아볼려면 ?

echo is_array($arr) ;

 

8) 배열을 정렬 할려면..

(1) 값을 기반으로 정렬 : sort($arr); , 역순 정렬 : rsort($arr);

(2) 키를 기반으로 정렬 : ksort($arr); , 역순 정렬 : krsort($arr);

(3) 사용자 정의 함수로 정렬하기 : usort($arr, callback);

function cmp($a, $b) {

if ($a == $b) return 0;

return ($a < $b) ? -1 : 1 ;

}

usort($arr, "cmp"); 하면 자동으로 사용자 정의 함수를 기반으로 바뀐다.

 

같으면 : 0, 작으면 : -1, 크면 : 1 로 함수로 잘 만들어보삼.. 당신의 능력을 믿어요.. ^^/

 

일단은 이정도.... 다르게 정렬 하는 함수들이 있지만 다음에 소개할게요...

 

9) 서브 배열 가지고 오기

가끔 배열도 중간에 있는 리스트만 가지고 오고 싶을 때가 있다... 파이썬의 경우는 배열 자료형 자체도 객체이기 때문에 arr[:10] 과 같은 슬라이스 형태로

서브배열을 가지고 오는 것이 가능하지만 php는 아직 그런것은 안되고 함수로 지원을 한다.

$arr = array(1, 2, 3, 4, 5);

$sub = array_slice ($arr, 2); // array(3, 4, 5);

$sub = array_slice($arr, 2, 1); // array(3);

$sub = array_slice($arr ,2, -1); // array(3, 4);

 

위와 같은 형태로 배열을 가지고 올 수 있습니다.

기본 형태는 array_slice (배열, 시작지점, 길이); 정도로 된다. 길이는 생략가능하고 길이가 안정해지면 마지막 요소까지로 측정된다.

 

10) 배열 요소 랜덤으로 가지고 오기

$values = array_rand($arr, $num);

 

위와 같은 형태로 사용하는데... 내부적으로 rand() 함수를 부르기 때문에 srand() 를 미리 실행해야 정확하게 각 시간별 랜덤결과를 얻을 수 있다.

srand(time());

$pick = array_rand($arr, $num);

 

$num 은 랜덤으로 가지올 개수인데 1 개 일때는 그냥 일반 자료형으로 리턴해주고 2개 이상일때는 해당 키값들을 배열로 리턴해준다.

그래서 실제 사용할려면

echo $arr[$pick[0]]; 형태로 값을 출력시켜야한다.

 

11) 배열 합치기 (합집합)

$new_arr = array_merge($ar1, $ar2); 와 같은형태로 배열을 합칠 수 있다.

연관 배열로 이루어진 배열들은 키값이 같으면 뒤에서 합쳐진 배열 값을 기준으로 값이 정해진다.

여기서 재미난 거 하나 .

$ar1 = array();

$ar2 = array(1 => 'a');

$new = array_merge($ar1, $ar2) ; // array(0 => 'a') 와 같은 형태로 기존의 인덱스는 완전 무시 된다. 이것을 방지할려면 + 연산자를 이용할 수 있다.

 

$new = $ar1 + $ar2; // array(1 => 'a'); 배열끼리 + 연산자를 사용하면 인덱스를 유지한채 배열을 합칠 수 있다. ㅋ

 

12) 키 값 존재 여부

if (array_key_exists('key', $arr)) { echo 'key 값 확인'; }

 

13) 교집합 구하기

교집합은 값을 기준으로 구할 수 있다.

$arr1 = array('a' => '안녕', '바보', '메롱');

$arr2 = array('b' => '안녕', '메롱', '쪼다');

$result = array_intersect($arr1, $arr2); // array('a' => '안녕', 0 => '메롱');

 

14) 키와 값의 위치 바꾸기 (키 <-> 값)

$arr = array('a' => 1, 'b' => 1, 'c' => 2);

$temp = array_flip($arr); // array(1 => 'b', 2 => 'c');

 

15) 요소 개수별로 서브 배열 만들기

$arr = array(1, 2, 3, 4, 5);

$temp = array_chunk($arr, 2); // array(array(1,2), array(3, 4), array(5));

$temp = array_chunk($arr, 2, true); // array(array(0 => 1, 1 => 2), array(2 = >3, 3 => 4), array(4 => 5));

설정

트랙백

댓글

/etc/lightdm/lightdm.conf 수정 후 부팅 문제

IT/Programming/Solution/Tip 2014. 4. 5. 22:52

Ubuntu에서 root 로그인을 위해 /etc/lightdm/lightdm.conf 에서 greeter-show-manual-login=true 설정을 적용했을 때 부팅이 안되는 경우, recovery 모드나 싱글 모드나 live cd 등을 이용하여 쉘을 띄운 후 다음과 같이 작업한다. :

 

/etc/lightdm/lightdm.conf.d/50-unity-greeter.conf 를 열고 아래와 같이 해당 내용을 편집한다 :

 

[SeatDefaults]
 greeter-session=unity-greeter
 greeter-show-manual-login=true

 

필자가 직접 경험한 문제는 아니고, 친구 문제의 해결을 도우면서 겪은 이슈라서 바로 해결되지 않을 수 있다.

 

그래도 문제가 계속 일어난다면, /etc/lightdm/lightdm.conf 에 적용된 greeter-show-manual-login=true 설정을 해제해주면 된다.

설정

트랙백

댓글

The Expert (Short Comedy Sketch)

ETC/Whatever! 2014. 4. 5. 17:40

'ETC > Whatever!' 카테고리의 다른 글

SNS 세상에서 늙어간다는 것.. Getting Old..  (0) 2010.11.14
cisco 안마기?!  (1) 2010.09.27
쉘노트 - shellnote  (0) 2010.09.27
You are being Monitored!  (0) 2010.06.29
Art : Wiltshire's CD Sea  (0) 2010.06.25

설정

트랙백

댓글

PHP 예전 버전 다운로드

IT/Programming/PHP 2014. 4. 4. 16:45

http://windows.php.net/downloads/releases/archives/

설정

트랙백

댓글

(jQuery) Uncaught Error: cannot call methods on dialog prior to initialization

IT/Programming/Solution/Tip 2014. 4. 3. 16:24

Uncaught Error: cannot call methods on dialog prior to initialization


jQuery로 작업을 하다가 위와 같은 에러를 만나서 엄청 고생을 했다. 


천천히 잘 읽어보면, 초기화되지 않은 상태로 호출을 하여 문제가 되는 것이다.

이는 다양한 상황에서 발생할 수 있는 문제이다. 예를 들면 다이얼로그가 존재하지도 않는데 open() 이나 close() 를 호출한다던가..



관련된 포스트가 있어서 인용한다. : (출처 : http://hbs.pe.kr/50152021782)


기다리던 jQueryUI 1.9 가 업데이트 되었습니다.


grid 가 제외되어서 안타깝습니다만..


어쨌든 개발중 1.9를 적용해 보고 발생하는 오류 포인트에 대해 간단히 정리합니다.


저의 경우 1.8.24 에서 1.9 로 올라갔기 때문에 정확히 1.9의 변경사항에만 영향이 있었습니다.

 

jQueryUI 1.8

        $('<div/>').dialog('close');

        오류 없음

 

        jQueryUI 1.9

        $('<div/>').dialog('close');

        Error: cannot call methods on dialog prior to initialization; attempted to call method 'close'

 

위처럼 간단히 오류 재현코드를 작성해 보았습니다.

포인트는 아래와 같습니다.

1. jQueryUI 1.9 이전에는 UI Plugin initialize 되지 않은 객체에 실행되면 그냥 무시 되었습니다.

2. jQueryUI 1.9 에서는 initialize 되지 않은 플러그인 관련 옵션/메소드를 사용할 경우 오류가 발생 합니다.

 

제가 발견한 포인트는 다음과 같습니다.

1. Dialog 생성되기 전에 close 부터 하는 경우. (dialog 있으면 close, 없어도 무시였으나 이제는 오류가 발생)

2. Div 밑에 children button icon 변경하는 경우
div.children().button('option','icons',{primary:'ui-icon-close'});
children
 버튼이 아닌 객체가 포함되어 있다면 1.8에서는 문제 없으나 1.9에서는 오류 발생
따라서 children('BUTTON') 등으로 대상을 정확히 특정 하는 것이 좋고  좋은건 selector 의존을 줄이고 memoization 활용 하면 됩니다.

 

특히  포인트의 2번째는 본인의 코드가 아닌 플러그인이나 프레임웍 등에 의해 하위 객체 구성이 바뀌는 경우 children이나 find통한 chaining에서 문제가   있습니다.



근데 난 jQueryUI 1.10 을 사용 중인데 이런 에러가 나는 걸 보니 꼭 위의 포스트처럼 1.9 버젼에만 국한된 이슈가 아닌 것 같다.


나는 Ajax로 다이얼로그에서 다른 페이지를 load() 할 때 이 문제를 만났는데, 온갖 삽질 끝에 불러오는 페이지에 있는 include 되는 모든 스크립트를 제거하고 시도한 끝에 해결할 수 있었다. 페이지가 순수하게 내가 의도한 데이터만 들어와야하는데, 페이지에 포함되어 있는 불필요한 스크립트 등이 함께 불러와져서 문제가 발생한 것이다.


천천히 소스를 검토해보고, 하나씩 테스트해봐가며 문제를 찾아보면 어렵지 않게 해결할 수 있는 문제다.

정작 나는 거의 5시간을 소비해버리고 말았지만..;; -_-;


설정

트랙백

댓글

Sublime Text :: Bracket Highlighter

IT/Programming/Solution/Tip 2014. 3. 29. 15:23

이번에 Sublime Text 를 사용하면서 Bracket Highlighter 이라는 플러그인을 사용하였는데, 꽤 만족스럽다.

Sublime Text 자체에도 하이라이팅을 해주긴 하지만 많이 흐릿하고 눈에 잘 보이지도 않고, 지원하지 않는 문자도 있어 이 플러그인을 사용하는 것을 강력히 추천한다.

 

다만 아주 가끔씩 bracket 이 정확히 쌍을 이룸에도 불구하고 bracket missing 을 띄우는 문제가 있긴하다.

 

 

 

공식 홈페이지 : https://sublime.wbond.net/packages/BracketHighlighter

플러그인 설치를 처음 한다면 opentutorial 의 다음 강좌를 참고하면 된다. : http://opentutorials.org/course/671/3642

 

설치 초기에는 단순히 밑줄로 하이라이팅을 해줄텐데, Preferences > Package Settings > Bracket Hightlighter > Bracket Setting Default 로 들어가서 bracket_styles 로 검색하여 "style" : "underline" 를 "style" : "solid" 로 고쳐주면 된다.

설정

트랙백

댓글

(MSSQL) 긴 동적쿼리 작성시 유의사항

IT/Programming/Programming 2014. 2. 27. 20:39

동적쿼리를 길~게 작성하다보면 쿼리가 잘려서 들어가는 경우가 있다.

 

주로 2가지의 원인을 꼽을 수 있는데, 첫째는 동적 쿼리를 담는 변수의 크기가 작거나 둘째는 4000byte가 넘는 쿼리를 sp_executesql 프로시저로 넘겨서 사용할 때이다. 공식적인 문서에서 sp_executesql 이 긴 쿼리에 대해서 제대로 처리하지 못한다는 내용은 본 적은 없지만, 서핑 중에 보았던 글에서 sp_executesql 이 아주 긴 동적 쿼리를 처리할 때 문제가 생기는 경우가 있다고 한다.

 

지금은 아주 긴 동적 쿼리를 잘 쓰지 않아서 정말 그러한지는 테스트를 안해봤는데.. 나중에 짬을 내서 직접 테스트 해봐야겠다.

 

참고 링크 :

sp_executesql http://technet.microsoft.com/ko-kr/library/ms175170(v=sql.105).aspx

건방진 연이 - sp_executesql & exec() http://ddoung2.tistory.com/141

 

설정

트랙백

댓글

MSSQL 데이터 타입 크기 및 범위

IT/Programming 2014. 2. 21. 12:30

 

 

 

 

분류

데이터 타입

범위

저장소크기

정수

Bit

O 또는 1

bit

Int

-2,147,483,648 ~ 2,147,483,647

4 바이트

Smallint

-32,768 ~ 32,767

2 바이트

Tinyint

0 ~ 255

1 바이트

Bigint

-2^63 ~ 2^63-1

8 바이트

부동소수점

Float[n]

-1.79E+308 ~ 1.79E+308
n = 1~24

4 바이트

Float[n]

-1.79E+308 ~ 1.79E+308
n = 25~53

8 바이트

Real

-3.40E + 38 ~ 3.40E + 38

4 바이트

문자데이터

char[n]

n = 1~8000

n 바이트

Varchar[n]

n = 1~8000

varchar [ ( n | max ) ]

max는 최대 저장소 크기가 2^31-1바이트임

입력한 데이터의 길이

Text

최대 2,147,483,647자의 가변길이

 

유니코드
문자데이터

Nchar

n = 1~4000

n*2 바이트

nvarchar

n = 1~4000

nvarchar [ ( n | max ) ]

max는 최대 저장소 크기가 2^31-1바이트임

입력한 데이터의 길이*2 바이트

Ntext

최대 1,073,741,823자의 가변길이

 

이진데이터

binary

n = 1~8000

n+4 바이트

varbinary

n = 1~8000

varbinary [ ( n | max) ]

max는 최대 저장소 크기가 2^31-1바이트임

입력한 데이터의 길이+4 바이트

Image

최대 2,147,483,647자의 가변길이

 

날짜와시간

datetime

1753/1/1~9999/12/31

8 바이트

smalldatetime

1900/1/1~2079/6/6

4 바이트

화폐

money

-922,337,203,685,477.5808~ +922,337,203,685,477.5807

8 바이트

smallmoney

-214,748.3648~214,748.3647

4 바이트


기타 데이터 형식

decimal , numeric, cursor, timestamp, sql_variant, uniqueidentifier, table, xml

 

 

text, ntext 및 image 데이터 형식 대신 varchar(max), nvarchar(max) 및 varbinary(max) 데이터 형식을 사용합니다.


ntext, text 및 image 데이터 형식은 Microsoft SQL Server 의 다음 버전에서 제거될 예정입니다. 향후 개발 작업에서는 이 데이터 형식을 사용하지 않도록 하고 현재 이 데이터 형식을 사용하는 응용 프로그램은 수정하십시오. 대신 nvarchar(max), varchar(max) 및 varbinary(max)를 사용합니다. 자세한 내용은 큰 값 데이터 형식 사용을 참조하십시오.

 

 

출처 : http://msdn.microsoft.com/ko-kr/library/ms187752.aspx  http://potato8.tistory.com/97  http://cafe.naver.com/devweb/32 

 

'IT/Programming' 카테고리의 다른 글

CP949 코드표 문자셋  (0) 2014.06.27
LocalDB  (0) 2014.01.09
git 을 웹에서 쉽게 배우자  (0) 2014.01.09
DDR1/DDR2/DDR3 외형차이  (0) 2013.07.31
개인적으로 좋아하는 엑셀 함수 사이트  (0) 2013.03.27

설정

트랙백

댓글