60 lines
1.8 KiB
C
60 lines
1.8 KiB
C
// Copyright (c) 2010 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
//
|
|
// 2013/8/30
|
|
//
|
|
// This file defines preprocessor macros for stringizing preprocessor
|
|
// symbols (or their output) and manipulating preprocessor symbols
|
|
// that define strings.
|
|
|
|
#ifndef BASE_STRINGIZE_MACROS_H_
|
|
#define BASE_STRINGIZE_MACROS_H_
|
|
#pragma once
|
|
|
|
#include "build/build_config.h"
|
|
|
|
// This is not very useful as it does not expand defined symbols if
|
|
// called directly. Use its counterpart without the _NO_EXPANSION
|
|
// suffix, below.
|
|
#define STRINGIZE_NO_EXPANSION(x) #x
|
|
|
|
// Use this to quote the provided parameter, first expanding it if it
|
|
// is a preprocessor symbol.
|
|
//
|
|
// For example, if:
|
|
// #define A FOO
|
|
// #define B(x) myobj->FunctionCall(x)
|
|
//
|
|
// Then:
|
|
// STRINGIZE(A) produces "FOO"
|
|
// STRINGIZE(B(y)) produces "myobj->FunctionCall(y)"
|
|
#define STRINGIZE(x) STRINGIZE_NO_EXPANSION(x)
|
|
|
|
// The following are defined only on Windows (for use when interacting
|
|
// with Windows APIs) as wide strings are otherwise deprecated.
|
|
#if defined(OS_WIN)
|
|
|
|
// Second-level utility macros to let us expand symbols.
|
|
#define LSTRINGIZE_NO_EXPANSION(x) L ## #x
|
|
#define TO_L_STRING_NO_EXPANSION(x) L ## x
|
|
|
|
// L version of STRINGIZE(). For examples above,
|
|
// LSTRINGIZE(A) produces L"FOO"
|
|
// LSTRINGIZE(B(y)) produces L"myobj->FunctionCall(y)"
|
|
#define LSTRINGIZE(x) LSTRINGIZE_NO_EXPANSION(x)
|
|
|
|
// Adds an L in front of an existing ASCII string constant (after
|
|
// expanding symbols). Does not do any quoting.
|
|
//
|
|
// For example, if:
|
|
// #define C "foo"
|
|
//
|
|
// Then:
|
|
// TO_L_STRING(C) produces L"foo"
|
|
#define TO_L_STRING(x) TO_L_STRING_NO_EXPANSION(x)
|
|
|
|
#endif // defined(OS_WIN)
|
|
|
|
#endif // BASE_STRINGIZE_MACROS_H_
|