2016년 5월 14일 토요일

[앤써북 이벤트] 아두이노 드론 만들고 직접 코딩하기





한이음 프로젝트 수행 당시 가장 관심있었던 주제는 "드론"


여러 오픈소스도 많이 있지만 처음부터 내가 만들어보고 싶다는 생각은 버릴수가 없었다.


그래서 부품도 따로 사서 만들어보려고 했지만 1부터 100까지, A부터 Z까지 관련 지식도 없이 덤비는 건 무모했고




결국 실패했다.


미련이 남아서 KAIST 드론 챌린지에 참여해서 CC3D라는 모듈을 써서 openpilot 프로그램으로 드론을 제작하는 기회를 가졌고 특별상도 받을 수 있었다.


이 책이 출간되고 서점으로 바로 달려가서 보니 배경 지식과 상세한 설명, 그림을 통해 쉽게 익힐 수 있는 구성이 마음에 들었다.


부품만 사놓고 직접 만들어보지 못했던 드론... 켜켜이 묵은 먼지를 털고 다시 한 번 하늘을 날아봐야겠다!


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


아두이노 드론 만들고 직접 코딩하기


아두이노로 드론 만들고, 드론 소프트웨어 직접 구현하여 날리기



"직접 코딩하면서 아두이노 드론 하드웨어와 소프트웨어를 이해한다"





교보문고 링크


예스24 링크


인터파크 도서 링크

2016년 3월 27일 일요일

MySQL 언어 설정

링크 참고 : link

show variables like '%character%';
show variables like 'collation%';


# Example MySQL config file for medium systems.
#
# This is for a system with little memory (32M - 64M) where MySQL plays
# an important part, or systems up to 128M where MySQL is used together with
# other programs (such as a web server)
#
# You can copy this file to
# /etc/my.cnf to set global options,
# mysql-data-dir/my.cnf to set server-specific options (in this
# installation this directory is C:\mysql\data) or
# ~/.my.cnf to set user-specific options.
#
# In this file, you can use all long options that a program supports.
# If you want to know which options a program supports, run the program
# with the "--help" option.

# The following options will be passed to all MySQL clients
[client]
default-character-set = utf8
port = 3306

# Here follows entries for some specific programs

# The MySQL server
[mysqld]
default-character-set=utf8
character-set-server=utf8
skip-character-set-client-handshake

port = 3306
skip-locking
key_buffer_size = 16M
max_allowed_packet = 1M
table_open_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
skip-innodb

# Don't listen on a TCP/IP port at all. This can be a security enhancement,
# if all processes that need to connect to mysqld run on the same host.
# All interaction with mysqld must be made via Unix sockets or named pipes.
# Note that using this option without enabling named pipes on Windows
# (via the "enable-named-pipe" option) will render mysqld useless!
#
#skip-networking

# Replication Master Server (default)
# binary logging is required for replication
#log-bin=mysql-bin

# binary logging format - mixed recommended
#binlog_format=mixed

# required unique id between 1 and 2^32 - 1
# defaults to 1 if master-host is not set
# but will not function as a master if omitted
#server-id = 1

# Replication Slave (comment out master section to use this)
#
# To configure this host as a replication slave, you can choose between
# two methods :
#
# 1) Use the CHANGE MASTER TO command (fully described in our manual) -
#    the syntax is:
#
#    CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>,
#    MASTER_USER=<user>, MASTER_PASSWORD=<password> ;
#
#    where you replace <host>, <user>, <password> by quoted strings and
#    <port> by the master's port number (3306 by default).
#
#    Example:
#
#    CHANGE MASTER TO MASTER_HOST='125.564.12.1', MASTER_PORT=3306,
#    MASTER_USER='joe', MASTER_PASSWORD='secret';
#
# OR
#
# 2) Set the variables below. However, in case you choose this method, then
#    start replication for the first time (even unsuccessfully, for example
#    if you mistyped the password in master-password and the slave fails to
#    connect), the slave will create a master.info file, and any later
#    change in this file to the variables' values below will be ignored and
#    overridden by the content of the master.info file, unless you shutdown
#    the slave server, delete master.info and restart the slaver server.
#    For that reason, you may want to leave the lines below untouched
#    (commented) and instead use CHANGE MASTER TO (see above)
#
# required unique id between 2 and 2^32 - 1
# (and different from the master)
# defaults to 2 if master-host is set
# but will not function as a slave if omitted
#server-id       = 2
#
# The replication master for this slave - required
#master-host     =   <hostname>
#
# The username the slave will use for authentication when connecting
# to the master - required
#master-user     =   <username>
#
# The password the slave will authenticate with when connecting to
# the master - required
#master-password =   <password>
#
# The port the master is listening on.
# optional - defaults to 3306
#master-port     =  <port>
#
# binary logging - not required for slaves, but recommended
#log-bin=mysql-bin

# Point the following paths to different dedicated disks
#tmpdir = /tmp/
#log-update = /path-to-dedicated-directory/hostname


# Uncomment the following if you are using InnoDB tables
#innodb_data_home_dir = C:\mysql\data/
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = C:\mysql\data/
# You can set .._buffer_pool_size up to 50 - 80 %
# of RAM but beware of setting memory usage too high
#innodb_buffer_pool_size = 16M
#innodb_additional_mem_pool_size = 2M
# Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 5M
#innodb_log_buffer_size = 8M
#innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50

[mysqldump]
default-character-set = utf8
quick
max_allowed_packet = 16M

[mysql]
default-character-set = utf8
no-auto-rehash
# Remove the next comment character if you are not familiar with SQL
#safe-updates

[myisamchk]
key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M

[mysqlhotcopy]
interactive-timeout
=====================================================
apmsetup 설치 후 발생하는 초보자들의 좌충우돌 미친 삽집 

  이 사이트가 기존 질문과 답변 게시판에 있는 글을  검색하는 게 너무 어렵고
 짜증나서  
 내가 겪는 문제면 다른 사람도 겪는 거라 생각해서 적습니다.
 정말 이런곳에 적지 않는 귀차니즘 주의자지만
apmsetup을 설치할때마다 느끼는 고통이라 적습니다(자꾸 까먹어서 그렇지만.ㅎㅎ , 항상 몇시간을 끙끙된다)

이글은 정말 초보자들을 위한 착한 사람의 봉사 
apm_setup 관리자 비번 바꾸는건
apm_setup 모니터(빨간얼굴 히죽웃는 프로그램말이유~)
환경설정에 가서 바꾸는건 다 알거라 생각합니다.

문제는 ~
phpmyadmin 비번 변경이 처음엔 젤 많이 겪는 문제지
나온 화면 오른쪽 상단에 보면 phpmyadmin 이 있으니 그걸 누르면
phpmyadmin  이 나옵니다.
이거의 비번은 apmsetup이죠
비번을 바꿔야하는데
처음은 root 에 apmsetup 을 넣고 드가면 드갑니다.

 이건 다 알잖아 . 다른 놈도 알고 며느리도 알고.
 암호 바꿔야지 -> 1234로 바꿔야지
암호변경을 선택하고 변경했다.
안돼!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!꾸끼 어쩌구 어쩌구 한다. 시불
 자주하는 질문에 가서 본 건 시불 몬소리인지 도체 알수 없다. 짱난다. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 해결은 C:\APM_Setup\Server\phpMyAdmin   에 있는 config.inc.php 에서 controlpass 를 검색해서 처음으로 나오는 놈
$cfg['Servers'][$i]['controlpass']   = '1234';          // access to the "mysql/user"
1234로 바꿔준다.
저장하고
 으악 확힌해보자
 안될 이유가 없다.!~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

다음날 (보통 여기 안된다고 적는 사람들 보면 다음날 컴퓨터를 키니 mysql 중지됨 이라고 계속 뜬다고 말한다)
히죽웃는 빨간 얼굴의 apmsetup 모니터에 mysql 이 시작이 안된다.!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   phpmyadmin 비번 변경 후 그냥 어쩌다가 apmsetup 모니터 프로그램을 껐다가 다시 꼈을 경우
   아니면 그냥 mysql 서버를 다시 시작눌렀는대 중지중 이라고 만 뜨고 그냥 있을 경우~

   대부분 phpmyadmin 비번 변경후에 ~
   apmsetup 환경설정에 mysql 탭에 관리자 비번을 변경하지 않아서 그렇다.
  중요한건 대부분 phpmyadmin 비번 변경하고 그냥
  apmsetup 프로그램을 종료 시키거나 혹은 심심해서 만지다가 끄게 된다
 그러면  mysql 서버는 중지중이라고만 뜨고 배째버려서 강제종료하게 되는데
 그러고 나서는 절대 다시 mysql 서버 실행됨을 보지 못한다.
그러하여 재설치의 무한루프에 빠지지
 이유는 모른다. ㅎㅎㅎ

그러니깐 phpmyadmin 비번바꾸고
바로 
apmsetup 환경설정에서 mysql탭에 관리자 비번도 똑같게 ! 바꾸고
나서야 마음대로  mysql서버를 중지하고 실행해도 된다.

그러면 비번때문에 생기는 개 황당하고 어이없고 그지 같은 경우는 없을것같다.
단.완존 컴맹은 제오ㅣ



현재 세팅상황(한글 출력O)
# Example MySQL config file for medium systems.
#
# This is for a system with little memory (32M - 64M) where MySQL plays
# an important part, or systems up to 128M where MySQL is used together with
# other programs (such as a web server)
#
# You can copy this file to
# /etc/my.cnf to set global options,
# mysql-data-dir/my.cnf to set server-specific options (in this
# installation this directory is C:\mysql\data) or
# ~/.my.cnf to set user-specific options.
#
# In this file, you can use all long options that a program supports.
# If you want to know which options a program supports, run the program
# with the "--help" option.

# The following options will be passed to all MySQL clients
[client]
default-character-set = euckr
port = 3306

# Here follows entries for some specific programs

# The MySQL server
[mysqld]
default-character-set=euckr
init_connect=SET collation_connection=euckr_korean_ci
init_connect=SET NAMES euckr
character-set-server=euckr
collation-server=euckr_korean_ci


port = 3306
skip-locking
key_buffer_size = 16M
max_allowed_packet = 1M
table_open_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
#skip-innodb

# Don't listen on a TCP/IP port at all. This can be a security enhancement,
# if all processes that need to connect to mysqld run on the same host.
# All interaction with mysqld must be made via Unix sockets or named pipes.
# Note that using this option without enabling named pipes on Windows
# (via the "enable-named-pipe" option) will render mysqld useless!

#skip-networking

# Replication Master Server (default)
# binary logging is required for replication
#log-bin=mysql-bin

# binary logging format - mixed recommended
#binlog_format=mixed

# required unique id between 1 and 2^32 - 1
# defaults to 1 if master-host is not set
# but will not function as a master if omitted
#server-id = 1

# Replication Slave (comment out master section to use this)
#
# To configure this host as a replication slave, you can choose between
# two methods :
#
# 1) Use the CHANGE MASTER TO command (fully described in our manual) -
#    the syntax is:
#
#    CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>,
#    MASTER_USER=<user>, MASTER_PASSWORD=<password> ;
#
#    where you replace <host>, <user>, <password> by quoted strings and
#    <port> by the master's port number (3306 by default).
#
#    Example:
#
#    CHANGE MASTER TO MASTER_HOST='125.564.12.1', MASTER_PORT=3306,
#    MASTER_USER='joe', MASTER_PASSWORD='secret';
#
# OR
#
# 2) Set the variables below. However, in case you choose this method, then
#    start replication for the first time (even unsuccessfully, for example
#    if you mistyped the password in master-password and the slave fails to
#    connect), the slave will create a master.info file, and any later
#    change in this file to the variables' values below will be ignored and
#    overridden by the content of the master.info file, unless you shutdown
#    the slave server, delete master.info and restart the slaver server.
#    For that reason, you may want to leave the lines below untouched
#    (commented) and instead use CHANGE MASTER TO (see above)
#
# required unique id between 2 and 2^32 - 1
# (and different from the master)
# defaults to 2 if master-host is set
# but will not function as a slave if omitted
#server-id       = 2
#
# The replication master for this slave - required
#master-host     =   <hostname>
#
# The username the slave will use for authentication when connecting
# to the master - required
#master-user     =   <username>
#
# The password the slave will authenticate with when connecting to
# the master - required
#master-password =   <password>
#
# The port the master is listening on.
# optional - defaults to 3306
#master-port     =  <port>
#
# binary logging - not required for slaves, but recommended
#log-bin=mysql-bin

# Point the following paths to different dedicated disks
#tmpdir = /tmp/
#log-update = /path-to-dedicated-directory/hostname


# Uncomment the following if you are using InnoDB tables
#innodb_data_home_dir = C:\mysql\data/
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = C:\mysql\data/
# You can set .._buffer_pool_size up to 50 - 80 %
# of RAM but beware of setting memory usage too high
#innodb_buffer_pool_size = 16M
#innodb_additional_mem_pool_size = 2M
# Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 5M
#innodb_log_buffer_size = 8M
#innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50

[mysqldump]
default-character-set = euckr
quick
max_allowed_packet = 16M

[mysql]
default-character-set = euckr
no-auto-rehash
# Remove the next comment character if you are not familiar with SQL
#safe-updates

[myisamchk]
key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M

[mysqlhotcopy]
interactive-timeout


ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost'

go this link : link


2016년 3월 7일 월요일

a401 프린팅 설정하기

신도리코 M401 윈도우8.1(10) 환경에서 드라이버 설치

우선 이 포스트는 신도리코에서 소정의 무엇을 받아서 작성하는 것이 아니라 간간히 이 문제로 어려워하시는 분들을 몇몇 분들을 보아 도움을 드리고자 하여 작성함을 알려드립니다.

신도리코 M401 구입하셨을 때 동봉된 CD가 두 장 있으셨을거예요 ㅎ
한 장은 드라이버 CD이고 다른 한 장은 스캐너 응용프로그램 CD인데요 그 중 드라이버 CD는 윈도우7용이랍니다. ㅎㅎ 당연히 윈도우8 상에서는 드라이버 안 잡히죠 ㅋㅋ

일단 드라이버를 구하기 위해 신도리코 홈피로 접속합니다.


여기서 중요한 정보가 하나 있습니다!

드라이버를 M401로 받으시는게 아니라 M402 드라이버를 받으셔야합니다!
전에는 M401드라이버(디지털서명이 되어있지 않음)를 드라이버서명 시행 해제 후 설치하면 됐었는데 지금은 무슨 문제인지는 몰라도 윈도우 업데이트 후 드라이버 설치가 안되어버리는 불상사가 생기고 말았습니다. 그래서 부득이하게 M402드라이버로 받습니다.


Windows 8 (32, 64) / Windows 8.1 (32, 64)
네 가지 운영체제에서 Print Driver(LAN FAX 가능) v56 파일은 모두 같습니다.

파일을 받아서 편한 위치에서 압축을 풀어줍니다.


위와 같이 폴더 두 개가 확인이 되면 맞게 받으신 겁니다.
드라이버가 들어있는 폴더는 2k_xp_vista_w7 폴더입니다.

이제 제어판으로 가셔서 장치 및 프린터를 더블클릭합니다.




프린터 추가를 클릭합니다.


위와 같은 화면이 뜨면 순서대로 클릭합니다.


쭉 따라오세요.


기존 포트 사용에 체크되어있나 확인하시고 포트를 USB 가장 첫 번째 있는 포트로 잡아줍니다. 보통 USB000입니다. 다음 클릭합니다.



순서대로 잘 따라오세요.


위와 같이 드라이버를 다운받은 경로에서 포스팅 초반에 언급한 2k_xp_vista_w7 폴더까지 더블클릭해서 들어옵니다. 파일 이름에 sdoakrh.inf 파일이 맞는지 확인하고 열기 누릅니다. (경로만 맞게 들어왔다면 100% 이 파일입니다.)



신도 M402_408 드라이버가 맞는지 확인하고 다음으로 넘어갑니다.


프린터 이름 설정하시고


공유 여부 설정하시고 다음으로 넘어갑니다.


벌써 마지막 화면이네요 ㅋ
설치가 잘 되었는지 확인하기 위해 테스트 페이지 인쇄를 누르고 마칩니다.



......???????????


당연히 프린트가 안됩니다. ㅋㅋㅋ M401드라이버가 아니기 때문이죠.
허나!!! 당황하지 마시고 간단한 설정 하나로 프린트가 가능해집니다.

다시 한 번 제어판 – 장치 및 프린터로 들어갑니다.


뭐가 하나 생겼죠?ㅎㅎ 방금 설치한 프린터입니다.ㅋ
마우스 오른쪽 클릭하시고 프린터 속성 클릭해주세요.


프린터 속성이 뜨면 포트 탭으로 이동합니다.


지금 상태는 USB000 포트에 체크가 되어있습니다. 맞죠? 당연합니다. 방금 전에 USB000포트로 설정했으니깐요. 이제 USB001 또는 USB002, USB003 등등 바로 아래 있는 체크되어있지 않은 USB포트 체크박스를 클릭하고 적용을 누르는 순간!!!

반응 오죠?ㅋㅋㅋ

아까 보낸 테스트페이지가 인쇄가 되는 역사를 경험하실 겁니다 ㅎㅎ
확인 누르시고 그대로 쭈~~~욱 사용하시면 됩니당 ㅋㅋ

어떤 원리로 이런 설정으로 인해 다른 드라이버가 정상작동하는지는 저도 잘 모릅니다.ㅋㅋ
사용하시는데는 아무 지장없으나 양면인쇄할때는 어떨지 모르겠습니다. 저도 아직 양면인쇄는 안해봤는데 M401은 수동양면인쇄고 M402는 자동양면인쇄인데 M402드라이버를 잡아놨으니 자동양면인쇄 설정밖에 없죠.ㅋ 이 부분은 저도 아직 경험해 보지 않았으니 사용하시는 분이 알아가시기를 바랍니다 ^^

윈도우 8.1 환경에서는 번들 프로그램으로 따라온 스캔프로그램인 PaperPort 11 도 사용하기가 까다롭죠. ㅋ 설치해도 스캔이 실행이 안돼서 신도리코 홈페이지에서 윈도우8.1용 페이퍼포트 보조 프로그램을 받아서 실행을 해줘야지 그제서야 스캔이 된답니다. 여러모로 불편하죠..ㅋㅋ
저도 그대로 사용하다가 ADF에서 스캐닝을 하면 페이퍼포트 프로그램이 오류가 떠서 먹통이 되는 불상사를 경험했다죠. 짜증나서 인터넷에서 PaperPort 14 프로그램 구해서 사용하고 있답니다. ㅎㅎ 상위버전이라 8.1에서 아무 오류없이 깔끔하게 잘 구동이 되더라구요 ㅎㅎ 근데 한글판을 못 구해서 ㅜㅜ 짧은 영어지식으로 사용중이랍니다 ㅋㅋ 기존 페이퍼포트11버전 사용자라면 사용하는데 어려움이 없더라구요 ㅎㅎㅎ

포스팅하다보니 말이 길어졌네용 ㅋㅋ
아무쪼록 이 M401복합기를 이용하는 사용자들이 불편하지 않게 속히 정상적인 드라이버가 업데이트 되었으면 하는 바람입니다.
이 키워드를 검색하시는 분이 몇 분이나 될지는 모르겠지만 제 포스팅이 필요하신 분께 도움이 되면 좋겠다는 마음가짐으로 포스팅을 마칩니다. ^^

2016년 3월 5일 토요일

[Solved]CRTC 63: trying mode 1920x1080@60Hz with output at 1920x1280@60Hz

my pc's OS is Ubuntu 14.02 LTS




Could not apply the stored configuration for monitors
none of the selected modes were compatible with the possible modes:
Trying modes for CRTC 63
CRTC 63: trying mode 2560x1700@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 2048x1536@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1920x1440@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1856x1392@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1792x1344@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1920x1200@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1920x1080@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1600x1200@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1680x1050@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1680x1050@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1600x1024@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1400x1050@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1280x1024@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1440x900@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1280x960@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1360x768@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1360x768@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1152x864@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 1024x768@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 800x600@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 800x600@56Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 640x480@60Hz with output at 1920x1280@60Hz (pass 0)
CRTC 63: trying mode 2560x1700@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 2048x1536@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 1920x1440@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 1856x1392@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 1792x1344@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 1920x1200@60Hz with output at 1920x1280@60Hz (pass 1)
CRTC 63: trying mode 1920x1080@60Hz with output at 1920x1280@60Hz (pass 1)


I solved this error from this steps.


type cvt 1920 1280 60


sudo vim /usr/share/X11/xorg.conf.d/10-monitor.conf



Section "Monitor"
  Identifier "Monitor0"
  Modeline "1920x1280_60.00"  206.25  1920 2056 2256 2592  1280 1283 1293 1327 -hsync +vsync
EndSection
Section "Screen"
  Identifier "Screen0"
  Device "eDP1"
  Monitor "Monitor0"
  DefaultDepth 24
  SubSection "Display"
    Depth 24
    Modes "1920x1280_60" "1280x960"
  EndSubSection
EndSection




2016년 2월 28일 일요일

How To – Change Hostname on Raspberrypi

How To – Change Hostname on Raspberrypi

To change the hostname
You need to edit 2 files replace raspberry with <name> this is what you choose and does not need <> brackets
1. Edit the hostname file
sudo nano /etc/hostname
raspberry
You will see raspberry change this to whatever you want (one word with  limited characters apply) <name>
CTRL+X press Y then hit Enter
2. Next you need to change the hosts file
sudo nano/etc/hosts
Change the entry 127.0.1.1 raspberry
To 127.0.1.1 <name>
Test with:
cat /etc/hosts
It should return the new name you gave it if not repeat the steps above
3. Reboot
When you login you will see pi@<name> ~ this is your new prompt
sudo reboot

2016년 2월 20일 토요일

emmet cheat sheat(emmet 명령어)

http://docs.emmet.io/cheat-sheet/

emmet의 명령어들이 잘 정리되어있다.

atom에서 emmet를 사용할 때 참고하면 좋을듯


Syntax

Child: >

nav>ul>li
<nav> <ul> <li></li> </ul> </nav>

Sibling: +

div+p+bq
<div></div> <p></p> <blockquote></blockquote>

Climb-up: ^

div+div>p>span+em^bq
<div></div> <div> <p><span></span><em></em></p> <blockquote></blockquote> </div>
div+div>p>span+em^^bq
<div></div> <div> <p><span></span><em></em></p> </div> <blockquote></blockquote>

Grouping: ()

div>(header>ul>li*2>a)+footer>p
<div> <header> <ul> <li><a href=""></a></li> <li><a href=""></a></li> </ul> </header> <footer> <p></p> </footer> </div>
(div>dl>(dt+dd)*3)+footer>p
<div> <dl> <dt></dt> <dd></dd> <dt></dt> <dd></dd> <dt></dt> <dd></dd> </dl> </div> <footer> <p></p> </footer>

Multiplication: *

ul>li*5
<ul> <li></li> <li></li> <li></li> <li></li> <li></li> </ul>

Item numbering: $

ul>li.item$*5
<ul> <li class="item1"></li> <li class="item2"></li> <li class="item3"></li> <li class="item4"></li> <li class="item5"></li> </ul>
h$[title=item$]{Header $}*3
<h1 title="item1">Header 1</h1> <h2 title="item2">Header 2</h2> <h3 title="item3">Header 3</h3>
ul>li.item$$$*5
<ul> <li class="item001"></li> <li class="item002"></li> <li class="item003"></li> <li class="item004"></li> <li class="item005"></li> </ul>
ul>li.item$@-*5
<ul> <li class="item5"></li> <li class="item4"></li> <li class="item3"></li> <li class="item2"></li> <li class="item1"></li> </ul>
ul>li.item$@3*5
<ul> <li class="item3"></li> <li class="item4"></li> <li class="item5"></li> <li class="item6"></li> <li class="item7"></li> </ul>

ID and CLASS attributes

#header
<div id="header"></div>
.title
<div class="title"></div>
form#search.wide
<form id="search" class="wide"></form>
p.class1.class2.class3
<p class="class1 class2 class3"></p>

Custom attributes

p[title="Hello world"]
<p title="Hello world"></p>
td[rowspan=2 colspan=3 title]
<td rowspan="2" colspan="3" title=""></td>
[a='value1' b="value2"]
<div a="value1" b="value2"></div>

Text: {}

a{Click me}
<a href="">Click me</a>
p>{Click }+a{here}+{ to continue}
<p>Click <a href="">here</a> to continue</p>

Implicit tag names

.class
<div class="class"></div>
em>.class
<em><span class="class"></span></em>
ul>.class
<ul> <li class="class"></li> </ul>
table>.row>.col
<table> <tr class="row"> <td class="col"></td> </tr> </table>

HTML

All unknown abbreviations will be transformed to tag, e.g. foo → <foo></foo>.
!
Alias of html:5
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>Document</title> </head> <body> </body> </html>
a
<a href=""></a>
a:link
<a href="http://"></a>
a:mail
<a href="mailto:"></a>
abbr
<abbr title=""></abbr>
acronym, acr
<acronym title=""></acronym>
base
<base href="" />
basefont
<basefont />
br
<br />
frame
<frame />
hr
<hr />
bdo
<bdo dir=""></bdo>
bdo:r
<bdo dir="rtl"></bdo>
bdo:l
<bdo dir="ltr"></bdo>
col
<col />
link
<link rel="stylesheet" href="" />
link:css
<link rel="stylesheet" href="style.css" />
link:print
<link rel="stylesheet" href="print.css" media="print" />
link:favicon
<link rel="shortcut icon" type="image/x-icon" href="favicon.ico" />
link:touch
<link rel="apple-touch-icon" href="favicon.png" />
link:rss
<link rel="alternate" type="application/rss+xml" title="RSS" href="rss.xml" />
link:atom
<link rel="alternate" type="application/atom+xml" title="Atom" href="atom.xml" />
link:import, link:im
<link rel="import" href="component.html" />
meta
<meta />
meta:utf
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
meta:win
<meta http-equiv="Content-Type" content="text/html;charset=windows-1251" />
meta:vp
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" />
meta:compat
<meta http-equiv="X-UA-Compatible" content="IE=7" />
style
<style></style>
script
<script></script>
script:src
<script src=""></script>
img
<img src="" alt="" />
img:srcset, img:s
<img srcset="" src="" alt="" />
img:sizes, img:z
<img sizes="" srcset="" src="" alt="" />
picture
<picture></picture>
source, src
<source />
source:src, src:sc
<source src="" type="" />
source:srcset, src:s
<source srcset="" />
source:media, src:m
<source media="(min-width: )" srcset="" />
source:type, src:t
<source srcset="" type="image/" />
source:sizes, src:z
<source sizes="" srcset="" />
source:media:type, src:mt
<source media="(min-width: )" srcset="" type="image/" />
source:media:sizes, src:mz
<source media="(min-width: )" sizes="" srcset="" />
source:sizes:type, src:zt
<source sizes="" srcset="" type="image/" />
iframe
<iframe src="" frameborder="0"></iframe>
embed
<embed src="" type="" />
object
<object data="" type=""></object>
param
<param name="" value="" />
map
<map name=""></map>
area
<area shape="" coords="" href="" alt="" />
area:d
<area shape="default" href="" alt="" />
area:c
<area shape="circle" coords="" href="" alt="" />
area:r
<area shape="rect" coords="" href="" alt="" />
area:p
<area shape="poly" coords="" href="" alt="" />
form
<form action=""></form>
form:get
<form action="" method="get"></form>
form:post
<form action="" method="post"></form>
label
<label for=""></label>
input
<input type="text" />
inp
<input type="text" name="" id="" />
input:hidden, input:h
Alias of input[type=hidden name]
<input type="hidden" name="" />
input:text, input:t
Alias of inp
<input type="text" name="" id="" />
input:search
Alias of inp[type=search]
<input type="search" name="" id="" />
input:email
Alias of inp[type=email]
<input type="email" name="" id="" />
input:url
Alias of inp[type=url]
<input type="url" name="" id="" />
input:password, input:p
Alias of inp[type=password]
<input type="password" name="" id="" />
input:datetime
Alias of inp[type=datetime]
<input type="datetime" name="" id="" />
input:date
Alias of inp[type=date]
<input type="date" name="" id="" />
input:datetime-local
Alias of inp[type=datetime-local]
<input type="datetime-local" name="" id="" />
input:month
Alias of inp[type=month]
<input type="month" name="" id="" />
input:week
Alias of inp[type=week]
<input type="week" name="" id="" />
input:time
Alias of inp[type=time]
<input type="time" name="" id="" />
input:tel
Alias of inp[type=tel]
<input type="tel" name="" id="" />
input:number
Alias of inp[type=number]
<input type="number" name="" id="" />
input:color
Alias of inp[type=color]
<input type="color" name="" id="" />
input:checkbox, input:c
Alias of inp[type=checkbox]
<input type="checkbox" name="" id="" />
input:radio, input:r
Alias of inp[type=radio]
<input type="radio" name="" id="" />
input:range
Alias of inp[type=range]
<input type="range" name="" id="" />
input:file, input:f
Alias of inp[type=file]
<input type="file" name="" id="" />
input:submit, input:s
<input type="submit" value="" />
input:image, input:i
<input type="image" src="" alt="" />
input:button, input:b
<input type="button" value="" />
isindex
<isindex />
input:reset
Alias of input:button[type=reset]
<input type="reset" value="" />
select
<select name="" id=""></select>
select:disabled, select:d
Alias of select[disabled.]
<select name="" id="" disabled="disabled"></select>
option, opt
<option value=""></option>
textarea
<textarea name="" id="" cols="30" rows="10"></textarea>
marquee
<marquee behavior="" direction=""></marquee>
menu:context, menu:c
Alias of menu[type=context]>
<menu type="context"></menu>
menu:toolbar, menu:t
Alias of menu[type=toolbar]>
<menu type="toolbar"></menu>
video
<video src=""></video>
audio
<audio src=""></audio>
html:xml
<html xmlns="http://www.w3.org/1999/xhtml"></html>
keygen
<keygen />
command
<command />
button:submit, button:s, btn:s
Alias of button[type=submit]
<button type="submit"></button>
button:reset, button:r, btn:r
Alias of button[type=reset]
<button type="reset"></button>
button:disabled, button:d, btn:d
Alias of button[disabled.]
<button disabled="disabled"></button>
fieldset:disabled, fieldset:d, fset:d, fst:d
Alias of fieldset[disabled.]
<fieldset disabled="disabled"></fieldset>
bq
Alias of blockquote
<blockquote></blockquote>
fig
Alias of figure
<figure></figure>
figc
Alias of figcaption
<figcaption></figcaption>
pic
Alias of picture
<picture></picture>
ifr
Alias of iframe
<iframe src="" frameborder="0"></iframe>
emb
Alias of embed
<embed src="" type="" />
obj
Alias of object
<object data="" type=""></object>
cap
Alias of caption
<caption></caption>
colg
Alias of colgroup
<colgroup></colgroup>
fst, fset
Alias of fieldset
<fieldset></fieldset>
btn
Alias of button
<button></button>
optg
Alias of optgroup
<optgroup></optgroup>
tarea
Alias of textarea
<textarea name="" id="" cols="30" rows="10"></textarea>
leg
Alias of legend
<legend></legend>
sect
Alias of section
<section></section>
art
Alias of article
<article></article>
hdr
Alias of header
<header></header>
ftr
Alias of footer
<footer></footer>
adr
Alias of address
<address></address>
dlg
Alias of dialog
<dialog></dialog>
str
Alias of strong
<strong></strong>
prog
Alias of progress
<progress></progress>
mn
Alias of main
<main></main>
tem
Alias of template
<template></template>
datag
Alias of datagrid
<datagrid></datagrid>
datal
Alias of datalist
<datalist></datalist>
kg
Alias of keygen
<keygen />
out
Alias of output
<output></output>
det
Alias of details
<details></details>
cmd
Alias of command
<command />
doc
Alias of html>(head>meta[charset=${charset}]+title{${1:Document}})+body
<html> <head> <meta charset="UTF-8" /> <title>Document</title> </head> <body> </body> </html>
doc4
Alias of html>(head>meta[http-equiv="Content-Type" content="text/html;charset=${charset}"]+title{${1:Document}})+body
<html> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
ri:dpr, ri:d
Alias of img:s
<img srcset="" src="" alt="" />
ri:viewport, ri:v
Alias of img:z
<img sizes="" srcset="" src="" alt="" />
ri:art, ri:a
Alias of pic>src:m+img
<picture> <source media="(min-width: )" srcset="" /> <img src="" alt="" /> </picture>
ri:type, ri:t
Alias of pic>src:t+img
<picture> <source srcset="" type="image/" /> <img src="" alt="" /> </picture>
html:4t
Alias of !!!4t+doc4[lang=${lang}]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
html:4s
Alias of !!!4s+doc4[lang=${lang}]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
html:xt
Alias of !!!xt+doc4[xmlns=http://www.w3.org/1999/xhtml xml:lang=${lang}]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
html:xs
Alias of !!!xs+doc4[xmlns=http://www.w3.org/1999/xhtml xml:lang=${lang}]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
html:xxs
Alias of !!!xxs+doc4[xmlns=http://www.w3.org/1999/xhtml xml:lang=${lang}]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /> <title>Document</title> </head> <body> </body> </html>
html:5
Alias of !!!+doc[lang=${lang}]
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>Document</title> </head> <body> </body> </html>
ol+
Alias of ol>li
<ol> <li></li> </ol>
ul+
Alias of ul>li
<ul> <li></li> </ul>
dl+
Alias of dl>dt+dd
<dl> <dt></dt> <dd></dd> </dl>
map+
Alias of map>area
<map name=""> <area shape="" coords="" href="" alt="" /> </map>
table+
Alias of table>tr>td
<table> <tr> <td></td> </tr> </table>
colgroup+, colg+
Alias of colgroup>col
<colgroup> <col /> </colgroup>
tr+
Alias of tr>td
<tr> <td></td> </tr>
select+
Alias of select>option
<select name="" id=""> <option value=""></option> </select>
optgroup+, optg+
Alias of optgroup>option
<optgroup> <option value=""></option> </optgroup>
pic+
Alias of picture>source:srcset+img
<picture> <source srcset="" /> <img src="" alt="" /> </picture>
!!!
<!DOCTYPE html>
!!!4t
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
!!!4s
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
!!!xt
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
!!!xs
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
!!!xxs
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
c
<!-- ${child} -->
cc:ie6
<!--[if lte IE 6]> ${child} <![endif]-->
cc:ie
<!--[if IE]> ${child} <![endif]-->
cc:noie
<!--[if !IE]><!--> ${child} <!--<![endif]-->

CSS

CSS module uses fuzzy search to find unknown abbreviations, e.g. ov:h == ov-h == ovh == oh.
If abbreviation wasn’t found, it is transformed into property name: foo-bar → foo-bar: |;
You can prefix abbreviations with hyphen to produce vendor-prefixed properties: -foo

Visual Formatting

pos
position:relative;
pos:s
position:static;
pos:a
position:absolute;
pos:r
position:relative;
pos:f
position:fixed;
t
top:;
t:a
top:auto;
r
right:;
r:a
right:auto;
b
bottom:;
b:a
bottom:auto;
l
left:;
l:a
left:auto;
z
z-index:;
z:a
z-index:auto;
fl
float:left;
fl:n
float:none;
fl:l
float:left;
fl:r
float:right;
cl
clear:both;
cl:n
clear:none;
cl:l
clear:left;
cl:r
clear:right;
cl:b
clear:both;
d
display:block;
d:n
display:none;
d:b
display:block;
d:f
display:flex;
d:if
display:inline-flex;
d:i
display:inline;
d:ib
display:inline-block;
d:li
display:list-item;
d:ri
display:run-in;
d:cp
display:compact;
d:tb
display:table;
d:itb
display:inline-table;
d:tbcp
display:table-caption;
d:tbcl
display:table-column;
d:tbclg
display:table-column-group;
d:tbhg
display:table-header-group;
d:tbfg
display:table-footer-group;
d:tbr
display:table-row;
d:tbrg
display:table-row-group;
d:tbc
display:table-cell;
d:rb
display:ruby;
d:rbb
display:ruby-base;
d:rbbg
display:ruby-base-group;
d:rbt
display:ruby-text;
d:rbtg
display:ruby-text-group;
v
visibility:hidden;
v:v
visibility:visible;
v:h
visibility:hidden;
v:c
visibility:collapse;
ov
overflow:hidden;
ov:v
overflow:visible;
ov:h
overflow:hidden;
ov:s
overflow:scroll;
ov:a
overflow:auto;
ovx
overflow-x:hidden;
ovx:v
overflow-x:visible;
ovx:h
overflow-x:hidden;
ovx:s
overflow-x:scroll;
ovx:a
overflow-x:auto;
ovy
overflow-y:hidden;
ovy:v
overflow-y:visible;
ovy:h
overflow-y:hidden;
ovy:s
overflow-y:scroll;
ovy:a
overflow-y:auto;
ovs
overflow-style:scrollbar;
ovs:a
overflow-style:auto;
ovs:s
overflow-style:scrollbar;
ovs:p
overflow-style:panner;
ovs:m
overflow-style:move;
ovs:mq
overflow-style:marquee;
zoo, zm
zoom:1;
cp
clip:;
cp:a
clip:auto;
cp:r
clip:rect(top right bottom left);
rsz
resize:;
rsz:n
resize:none;
rsz:b
resize:both;
rsz:h
resize:horizontal;
rsz:v
resize:vertical;
cur
cursor:${pointer};
cur:a
cursor:auto;
cur:d
cursor:default;
cur:c
cursor:crosshair;
cur:ha
cursor:hand;
cur:he
cursor:help;
cur:m
cursor:move;
cur:p
cursor:pointer;
cur:t
cursor:text;

Margin & Padding

m
margin:;
m:a
margin:auto;
mt
margin-top:;
mt:a
margin-top:auto;
mr
margin-right:;
mr:a
margin-right:auto;
mb
margin-bottom:;
mb:a
margin-bottom:auto;
ml
margin-left:;
ml:a
margin-left:auto;
p
padding:;
pt
padding-top:;
pr
padding-right:;
pb
padding-bottom:;
pl
padding-left:;

Box Sizing

bxz
box-sizing:border-box;
bxz:cb
box-sizing:content-box;
bxz:bb
box-sizing:border-box;
bxsh
box-shadow:inset hoff voff blur color;
bxsh:r
box-shadow:inset hoff voff blur spread rgb(0, 0, 0);
bxsh:ra
box-shadow:inset h v blur spread rgba(0, 0, 0, .5);
bxsh:n
box-shadow:none;
w
width:;
w:a
width:auto;
h
height:;
h:a
height:auto;
maw
max-width:;
maw:n
max-width:none;
mah
max-height:;
mah:n
max-height:none;
miw
min-width:;
mih
min-height:;

Font

f
font:;
f+
font:1em Arial,sans-serif;
fw
font-weight:;
fw:n
font-weight:normal;
fw:b
font-weight:bold;
fw:br
font-weight:bolder;
fw:lr
font-weight:lighter;
fs
font-style:${italic};
fs:n
font-style:normal;
fs:i
font-style:italic;
fs:o
font-style:oblique;
fv
font-variant:;
fv:n
font-variant:normal;
fv:sc
font-variant:small-caps;
fz
font-size:;
fza
font-size-adjust:;
fza:n
font-size-adjust:none;
ff
font-family:;
ff:s
font-family:serif;
ff:ss
font-family:sans-serif;
ff:c
font-family:cursive;
ff:f
font-family:fantasy;
ff:m
font-family:monospace;
ff:a
font-family: Arial, "Helvetica Neue", Helvetica, sans-serif;
ff:t
font-family: "Times New Roman", Times, Baskerville, Georgia, serif;
ff:v
font-family: Verdana, Geneva, sans-serif;
fef
font-effect:;
fef:n
font-effect:none;
fef:eg
font-effect:engrave;
fef:eb
font-effect:emboss;
fef:o
font-effect:outline;
fem
font-emphasize:;
femp
font-emphasize-position:;
femp:b
font-emphasize-position:before;
femp:a
font-emphasize-position:after;
fems
font-emphasize-style:;
fems:n
font-emphasize-style:none;
fems:ac
font-emphasize-style:accent;
fems:dt
font-emphasize-style:dot;
fems:c
font-emphasize-style:circle;
fems:ds
font-emphasize-style:disc;
fsm
font-smooth:;
fsm:a
font-smooth:auto;
fsm:n
font-smooth:never;
fsm:aw
font-smooth:always;
fst
font-stretch:;
fst:n
font-stretch:normal;
fst:uc
font-stretch:ultra-condensed;
fst:ec
font-stretch:extra-condensed;
fst:c
font-stretch:condensed;
fst:sc
font-stretch:semi-condensed;
fst:se
font-stretch:semi-expanded;
fst:e
font-stretch:expanded;
fst:ee
font-stretch:extra-expanded;
fst:ue
font-stretch:ultra-expanded;

Text

va
vertical-align:top;
va:sup
vertical-align:super;
va:t
vertical-align:top;
va:tt
vertical-align:text-top;
va:m
vertical-align:middle;
va:bl
vertical-align:baseline;
va:b
vertical-align:bottom;
va:tb
vertical-align:text-bottom;
va:sub
vertical-align:sub;
ta
text-align:left;
ta:l
text-align:left;
ta:c
text-align:center;
ta:r
text-align:right;
ta:j
text-align:justify;
ta-lst
text-align-last:;
tal:a
text-align-last:auto;
tal:l
text-align-last:left;
tal:c
text-align-last:center;
tal:r
text-align-last:right;
td
text-decoration:none;
td:n
text-decoration:none;
td:u
text-decoration:underline;
td:o
text-decoration:overline;
td:l
text-decoration:line-through;
te
text-emphasis:;
te:n
text-emphasis:none;
te:ac
text-emphasis:accent;
te:dt
text-emphasis:dot;
te:c
text-emphasis:circle;
te:ds
text-emphasis:disc;
te:b
text-emphasis:before;
te:a
text-emphasis:after;
th
text-height:;
th:a
text-height:auto;
th:f
text-height:font-size;
th:t
text-height:text-size;
th:m
text-height:max-size;
ti
text-indent:;
ti:-
text-indent:-9999px;
tj
text-justify:;
tj:a
text-justify:auto;
tj:iw
text-justify:inter-word;
tj:ii
text-justify:inter-ideograph;
tj:ic
text-justify:inter-cluster;
tj:d
text-justify:distribute;
tj:k
text-justify:kashida;
tj:t
text-justify:tibetan;
to
text-outline:;
to+
text-outline:0 0 #000;
to:n
text-outline:none;
tr
text-replace:;
tr:n
text-replace:none;
tt
text-transform:uppercase;
tt:n
text-transform:none;
tt:c
text-transform:capitalize;
tt:u
text-transform:uppercase;
tt:l
text-transform:lowercase;
tw
text-wrap:;
tw:n
text-wrap:normal;
tw:no
text-wrap:none;
tw:u
text-wrap:unrestricted;
tw:s
text-wrap:suppress;
tsh
text-shadow:hoff voff blur #000;
tsh:r
text-shadow:h v blur rgb(0, 0, 0);
tsh:ra
text-shadow:h v blur rgba(0, 0, 0, .5);
tsh+
text-shadow:0 0 0 #000;
tsh:n
text-shadow:none;
lh
line-height:;
lts
letter-spacing:;
lts-n
letter-spacing:normal;
whs
white-space:;
whs:n
white-space:normal;
whs:p
white-space:pre;
whs:nw
white-space:nowrap;
whs:pw
white-space:pre-wrap;
whs:pl
white-space:pre-line;
whsc
white-space-collapse:;
whsc:n
white-space-collapse:normal;
whsc:k
white-space-collapse:keep-all;
whsc:l
white-space-collapse:loose;
whsc:bs
white-space-collapse:break-strict;
whsc:ba
white-space-collapse:break-all;
wob
word-break:;
wob:n
word-break:normal;
wob:k
word-break:keep-all;
wob:ba
word-break:break-all;
wos
word-spacing:;
wow
word-wrap:;
wow:nm
word-wrap:normal;
wow:n
word-wrap:none;
wow:u
word-wrap:unrestricted;
wow:s
word-wrap:suppress;
wow:b
word-wrap:break-word;

Background

bg
background:#000;
bg+
background:#fff url() 0 0 no-repeat;
bg:n
background:none;
bgc
background-color:#fff;
bgc:t
background-color:transparent;
bgi
background-image:url();
bgi:n
background-image:none;
bgr
background-repeat:;
bgr:n
background-repeat:no-repeat;
bgr:x
background-repeat:repeat-x;
bgr:y
background-repeat:repeat-y;
bgr:sp
background-repeat:space;
bgr:rd
background-repeat:round;
bga
background-attachment:;
bga:f
background-attachment:fixed;
bga:s
background-attachment:scroll;
bgp
background-position:0 0;
bgpx
background-position-x:;
bgpy
background-position-y:;
bgbk
background-break:;
bgbk:bb
background-break:bounding-box;
bgbk:eb
background-break:each-box;
bgbk:c
background-break:continuous;
bgcp
background-clip:padding-box;
bgcp:bb
background-clip:border-box;
bgcp:pb
background-clip:padding-box;
bgcp:cb
background-clip:content-box;
bgcp:nc
background-clip:no-clip;
bgo
background-origin:;
bgo:pb
background-origin:padding-box;
bgo:bb
background-origin:border-box;
bgo:cb
background-origin:content-box;
bgsz
background-size:;
bgsz:a
background-size:auto;
bgsz:ct
background-size:contain;
bgsz:cv
background-size:cover;

Color

c
color:#000;
c:r
color:rgb(0, 0, 0);
c:ra
color:rgba(0, 0, 0, .5);
op
opacity:;

Generated content

cnt
content:'';
cnt:n, ct:n
content:normal;
cnt:oq, ct:oq
content:open-quote;
cnt:noq, ct:noq
content:no-open-quote;
cnt:cq, ct:cq
content:close-quote;
cnt:ncq, ct:ncq
content:no-close-quote;
cnt:a, ct:a
content:attr();
cnt:c, ct:c
content:counter();
cnt:cs, ct:cs
content:counters();
ct
content:;
q
quotes:;
q:n
quotes:none;
q:ru
quotes:'\00AB' '\00BB' '\201E' '\201C';
q:en
quotes:'\201C' '\201D' '\2018' '\2019';
coi
counter-increment:;
cor
counter-reset:;

Outline

ol
outline:;
ol:n
outline:none;
olo
outline-offset:;
olw
outline-width:;
olw:tn
outline-width:thin;
olw:m
outline-width:medium;
olw:tc
outline-width:thick;
ols
outline-style:;
ols:n
outline-style:none;
ols:dt
outline-style:dotted;
ols:ds
outline-style:dashed;
ols:s
outline-style:solid;
ols:db
outline-style:double;
ols:g
outline-style:groove;
ols:r
outline-style:ridge;
ols:i
outline-style:inset;
ols:o
outline-style:outset;
olc
outline-color:#000;
olc:i
outline-color:invert;

Tables

tbl
table-layout:;
tbl:a
table-layout:auto;
tbl:f
table-layout:fixed;
cps
caption-side:;
cps:t
caption-side:top;
cps:b
caption-side:bottom;
ec
empty-cells:;
ec:s
empty-cells:show;
ec:h
empty-cells:hide;

Border

bd
border:;
bd+
border:1px solid #000;
bd:n
border:none;
bdbk
border-break:close;
bdbk:c
border-break:close;
bdcl
border-collapse:;
bdcl:c
border-collapse:collapse;
bdcl:s
border-collapse:separate;
bdc
border-color:#000;
bdc:t
border-color:transparent;
bdi
border-image:url();
bdi:n
border-image:none;
bdti
border-top-image:url();
bdti:n
border-top-image:none;
bdri
border-right-image:url();
bdri:n
border-right-image:none;
bdbi
border-bottom-image:url();
bdbi:n
border-bottom-image:none;
bdli
border-left-image:url();
bdli:n
border-left-image:none;
bdci
border-corner-image:url();
bdci:n
border-corner-image:none;
bdci:c
border-corner-image:continue;
bdtli
border-top-left-image:url();
bdtli:n
border-top-left-image:none;
bdtli:c
border-top-left-image:continue;
bdtri
border-top-right-image:url();
bdtri:n
border-top-right-image:none;
bdtri:c
border-top-right-image:continue;
bdbri
border-bottom-right-image:url();
bdbri:n
border-bottom-right-image:none;
bdbri:c
border-bottom-right-image:continue;
bdbli
border-bottom-left-image:url();
bdbli:n
border-bottom-left-image:none;
bdbli:c
border-bottom-left-image:continue;
bdf
border-fit:repeat;
bdf:c
border-fit:clip;
bdf:r
border-fit:repeat;
bdf:sc
border-fit:scale;
bdf:st
border-fit:stretch;
bdf:ow
border-fit:overwrite;
bdf:of
border-fit:overflow;
bdf:sp
border-fit:space;
bdlen
border-length:;
bdlen:a
border-length:auto;
bdsp
border-spacing:;
bds
border-style:;
bds:n
border-style:none;
bds:h
border-style:hidden;
bds:dt
border-style:dotted;
bds:ds
border-style:dashed;
bds:s
border-style:solid;
bds:db
border-style:double;
bds:dtds
border-style:dot-dash;
bds:dtdtds
border-style:dot-dot-dash;
bds:w
border-style:wave;
bds:g
border-style:groove;
bds:r
border-style:ridge;
bds:i
border-style:inset;
bds:o
border-style:outset;
bdw
border-width:;
bdt, bt
border-top:;
bdt+
border-top:1px solid #000;
bdt:n
border-top:none;
bdtw
border-top-width:;
bdts
border-top-style:;
bdts:n
border-top-style:none;
bdtc
border-top-color:#000;
bdtc:t
border-top-color:transparent;
bdr, br
border-right:;
bdr+
border-right:1px solid #000;
bdr:n
border-right:none;
bdrw
border-right-width:;
bdrst
border-right-style:;
bdrst:n
border-right-style:none;
bdrc
border-right-color:#000;
bdrc:t
border-right-color:transparent;
bdb, bb
border-bottom:;
bdb+
border-bottom:1px solid #000;
bdb:n
border-bottom:none;
bdbw
border-bottom-width:;
bdbs
border-bottom-style:;
bdbs:n
border-bottom-style:none;
bdbc
border-bottom-color:#000;
bdbc:t
border-bottom-color:transparent;
bdl, bl
border-left:;
bdl+
border-left:1px solid #000;
bdl:n
border-left:none;
bdlw
border-left-width:;
bdls
border-left-style:;
bdls:n
border-left-style:none;
bdlc
border-left-color:#000;
bdlc:t
border-left-color:transparent;
bdrs
border-radius:;
bdtrrs
border-top-right-radius:;
bdtlrs
border-top-left-radius:;
bdbrrs
border-bottom-right-radius:;
bdblrs
border-bottom-left-radius:;

Lists

lis
list-style:;
lis:n
list-style:none;
lisp
list-style-position:;
lisp:i
list-style-position:inside;
lisp:o
list-style-position:outside;
list
list-style-type:;
list:n
list-style-type:none;
list:d
list-style-type:disc;
list:c
list-style-type:circle;
list:s
list-style-type:square;
list:dc
list-style-type:decimal;
list:dclz
list-style-type:decimal-leading-zero;
list:lr
list-style-type:lower-roman;
list:ur
list-style-type:upper-roman;
lisi
list-style-image:;
lisi:n
list-style-image:none;

Print

pgbb
page-break-before:;
pgbb:au
page-break-before:auto;
pgbb:al
page-break-before:always;
pgbb:l
page-break-before:left;
pgbb:r
page-break-before:right;
pgbi
page-break-inside:;
pgbi:au
page-break-inside:auto;
pgbi:av
page-break-inside:avoid;
pgba
page-break-after:;
pgba:au
page-break-after:auto;
pgba:al
page-break-after:always;
pgba:l
page-break-after:left;
pgba:r
page-break-after:right;
orp
orphans:;
wid
widows:;

Others

!
!important
@f
@font-face { font-family:; src:url(|); }
@f+
@font-face { font-family: 'FontName'; src: url('FileName.eot'); src: url('FileName.eot?#iefix') format('embedded-opentype'), url('FileName.woff') format('woff'), url('FileName.ttf') format('truetype'), url('FileName.svg#FontName') format('svg'); font-style: normal; font-weight: normal; }
@i, @import
@import url();
@kf
@-webkit-keyframes identifier { from { } to { } } @-o-keyframes identifier { from { } to { } } @-moz-keyframes identifier { from { } to { } } @keyframes identifier { from { } to { } }
@m, @media
@media screen { }
ac
align-content:;
ac:c
align-content:center;
ac:fe
align-content:flex-end;
ac:fs
align-content:flex-start;
ac:s
align-content:stretch;
ac:sa
align-content:space-around;
ac:sb
align-content:space-between;
ai
align-items:;
ai:b
align-items:baseline;
ai:c
align-items:center;
ai:fe
align-items:flex-end;
ai:fs
align-items:flex-start;
ai:s
align-items:stretch;
anim
animation:;
anim-
animation:name duration timing-function delay iteration-count direction fill-mode;
animdel
animation-delay:time;
animdir
animation-direction:normal;
animdir:a
animation-direction:alternate;
animdir:ar
animation-direction:alternate-reverse;
animdir:n
animation-direction:normal;
animdir:r
animation-direction:reverse;
animdur
animation-duration:0s;
animfm
animation-fill-mode:both;
animfm:b
animation-fill-mode:backwards;
animfm:bt, animfm:bh
animation-fill-mode:both;
animfm:f
animation-fill-mode:forwards;
animic
animation-iteration-count:1;
animic:i
animation-iteration-count:infinite;
animn
animation-name:none;
animps
animation-play-state:running;
animps:p
animation-play-state:paused;
animps:r
animation-play-state:running;
animtf
animation-timing-function:linear;
animtf:cb
animation-timing-function:cubic-bezier(0.1, 0.7, 1.0, 0.1);
animtf:e
animation-timing-function:ease;
animtf:ei
animation-timing-function:ease-in;
animtf:eio
animation-timing-function:ease-in-out;
animtf:eo
animation-timing-function:ease-out;
animtf:l
animation-timing-function:linear;
ap
appearance:${none};
as
align-self:;
as:a
align-self:auto;
as:b
align-self:baseline;
as:c
align-self:center;
as:fe
align-self:flex-end;
as:fs
align-self:flex-start;
as:s
align-self:stretch;
bfv
backface-visibility:;
bfv:h
backface-visibility:hidden;
bfv:v
backface-visibility:visible;
bg:ie
filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='x.png',sizingMethod='crop');
cm
/* ${child} */
colm
columns:;
colmc
column-count:;
colmf
column-fill:;
colmg
column-gap:;
colmr
column-rule:;
colmrc
column-rule-color:;
colmrs
column-rule-style:;
colmrw
column-rule-width:;
colms
column-span:;
colmw
column-width:;
d:ib+
display: inline-block; *display: inline; *zoom: 1;
fx
flex:;
fxb
flex-basis:;
fxd
flex-direction:;
fxd:c
flex-direction:column;
fxd:cr
flex-direction:column-reverse;
fxd:r
flex-direction:row;
fxd:rr
flex-direction:row-reverse;
fxf
flex-flow:;
fxg
flex-grow:;
fxsh
flex-shrink:;
fxw
flex-wrap: ;
fxw:n
flex-wrap:nowrap;
fxw:w
flex-wrap:wrap;
fxw:wr
flex-wrap:wrap-reverse;
jc
justify-content:;
jc:c
justify-content:center;
jc:fe
justify-content:flex-end;
jc:fs
justify-content:flex-start;
jc:sa
justify-content:space-around;
jc:sb
justify-content:space-between;
mar
max-resolution:res;
mir
min-resolution:res;
op+
opacity: ; filter: alpha(opacity=);
op:ie
filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
op:ms
-ms-filter:'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
ord
order:;
ori
orientation:;
ori:l
orientation:landscape;
ori:p
orientation:portrait;
tov
text-overflow:${ellipsis};
tov:c
text-overflow:clip;
tov:e
text-overflow:ellipsis;
trf
transform:;
trf:r
transform: rotate(angle);
trf:rx
transform: rotateX(angle);
trf:ry
transform: rotateY(angle);
trf:rz
transform: rotateZ(angle);
trf:sc
transform: scale(x, y);
trf:sc3
transform: scale3d(x, y, z);
trf:scx
transform: scaleX(x);
trf:scy
transform: scaleY(y);
trf:scz
transform: scaleZ(z);
trf:skx
transform: skewX(angle);
trf:sky
transform: skewY(angle);
trf:t
transform: translate(x, y);
trf:t3
transform: translate3d(tx, ty, tz);
trf:tx
transform: translateX(x);
trf:ty
transform: translateY(y);
trf:tz
transform: translateZ(z);
trfo
transform-origin:;
trfs
transform-style:preserve-3d;
trs
transition:prop time;
trsde
transition-delay:time;
trsdu
transition-duration:time;
trsp
transition-property:prop;
trstf
transition-timing-function:tfunc;
us
user-select:${none};
wfsm
-webkit-font-smoothing:${antialiased};
wfsm:a
-webkit-font-smoothing:antialiased;
wfsm:n
-webkit-font-smoothing:none;
wfsm:s, wfsm:sa
-webkit-font-smoothing:subpixel-antialiased;
wm
writing-mode:lr-tb;
wm:btl
writing-mode:bt-lr;
wm:btr
writing-mode:bt-rl;
wm:lrb
writing-mode:lr-bt;
wm:lrt
writing-mode:lr-tb;
wm:rlb
writing-mode:rl-bt;
wm:rlt
writing-mode:rl-tb;
wm:tbl
writing-mode:tb-lr;
wm:tbr
writing-mode:tb-rl;

XSL

tmatch, tm
<xsl:template match="" mode=""></xsl:template>
tname, tn
<xsl:template name=""></xsl:template>
call
<xsl:call-template name="" />
ap
<xsl:apply-templates select="" mode="" />
api
<xsl:apply-imports />
imp
<xsl:import href="" />
inc
<xsl:include href="" />
ch
<xsl:choose></xsl:choose>
xsl:when, wh
<xsl:when test=""></xsl:when>
ot
<xsl:otherwise></xsl:otherwise>
if
<xsl:if test=""></xsl:if>
par
<xsl:param name=""></xsl:param>
pare
<xsl:param name="" select="" />
var
<xsl:variable name=""></xsl:variable>
vare
<xsl:variable name="" select="" />
wp
<xsl:with-param name="" select="" />
key
<xsl:key name="" match="" use="" />
elem
<xsl:element name=""></xsl:element>
attr
<xsl:attribute name=""></xsl:attribute>
attrs
<xsl:attribute-set name=""></xsl:attribute-set>
cp
<xsl:copy select="" />
co
<xsl:copy-of select="" />
val
<xsl:value-of select="" />
each, for
<xsl:for-each select=""></xsl:for-each>
tex
<xsl:text></xsl:text>
com
<xsl:comment></xsl:comment>
msg
<xsl:message terminate="no"></xsl:message>
fall
<xsl:fallback></xsl:fallback>
num
<xsl:number value="" />
nam
<namespace-alias stylesheet-prefix="" result-prefix="" />
pres
<xsl:preserve-space elements="" />
strip
<xsl:strip-space elements="" />
proc
<xsl:processing-instruction name=""></xsl:processing-instruction>
sort
<xsl:sort select="" order="" />
choose+
Alias of xsl:choose>xsl:when+xsl:otherwise
<xsl:choose> <xsl:when test=""></xsl:when> <xsl:otherwise></xsl:otherwise> </xsl:choose>
xsl
Alias of !!!+xsl:stylesheet[version=1.0 xmlns:xsl=http://www.w3.org/1999/XSL/Transform]>{ |}
<?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"></xsl:stylesheet>
!!!
<?xml version="1.0" encoding="UTF-8"?>