Idiomatic way to prevent slicing? The 2019 Stack Overflow Developer Survey Results Are InForce function to be called only with specific typesWhat's the best way to trim std::string?What is object slicing?What's the point of g++ -Wreorder?Easiest way to convert int to string in C++Does the C++ spec allow an instance of a non-virtual class to include memory for a vtable pointer?capture variables inside of subclass?Detecting if a type can be derived from in C++C++ overload function by return typeIs using inline classes inside a function permitted to be used as template types?Short-circuit evaluation and assignment in C++

What does "rabbited" mean/imply in this sentence?

Time travel alters history but people keep saying nothing's changed

If the Wish spell is used to duplicate the effect of Simulacrum, are existing duplicates destroyed?

Lethal sonic weapons

Unbreakable Formation vs. Cry of the Carnarium

Pristine Bit Checking

Understanding the implication of what "well-defined" means for the operation in quotient group

What effect does the “loading” weapon property have in practical terms?

Which Sci-Fi work first showed weapon of galactic-scale mass destruction?

Realistic Alternatives to Dust: What Else Could Feed a Plankton Bloom?

"What time...?" or "At what time...?" - what is more grammatically correct?

Landlord wants to switch my lease to a "Land contract" to "get back at the city"

Why is it "Tumoren" and not "Tumore"?

Does duplicating a spell with Wish count as casting that spell?

How to answer pointed "are you quitting" questioning when I don't want them to suspect

"To split hairs" vs "To be pedantic"

On the insanity of kings as an argument against monarchy

Deadlock Graph and Interpretation, solution to avoid

Does a dangling wire really electrocute me if I'm standing in water?

Inflated grade on resume at previous job, might former employer tell new employer?

What do the Banks children have against barley water?

Is this food a bread or a loaf?

What is the motivation for a law requiring 2 parties to consent for recording a conversation

How are circuits which use complex ICs normally simulated?



Idiomatic way to prevent slicing?



The 2019 Stack Overflow Developer Survey Results Are InForce function to be called only with specific typesWhat's the best way to trim std::string?What is object slicing?What's the point of g++ -Wreorder?Easiest way to convert int to string in C++Does the C++ spec allow an instance of a non-virtual class to include memory for a vtable pointer?capture variables inside of subclass?Detecting if a type can be derived from in C++C++ overload function by return typeIs using inline classes inside a function permitted to be used as template types?Short-circuit evaluation and assignment in C++



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








9















Sometimes it can be an annoyance that c++ defaults to allow slicing. For example



#include <iostream>
struct foo int a; ;
struct bar : foo int b; ;

int main()
bar x1,2;
foo y = x; // <- I dont want this to compile!



This compiles and runs as expected! Though, what if I dont want to enable slicing?



What is the idomatic way to write foo such that one cannot slice instances of any derived class?










share|improve this question






























    9















    Sometimes it can be an annoyance that c++ defaults to allow slicing. For example



    #include <iostream>
    struct foo int a; ;
    struct bar : foo int b; ;

    int main()
    bar x1,2;
    foo y = x; // <- I dont want this to compile!



    This compiles and runs as expected! Though, what if I dont want to enable slicing?



    What is the idomatic way to write foo such that one cannot slice instances of any derived class?










    share|improve this question


























      9












      9








      9


      3






      Sometimes it can be an annoyance that c++ defaults to allow slicing. For example



      #include <iostream>
      struct foo int a; ;
      struct bar : foo int b; ;

      int main()
      bar x1,2;
      foo y = x; // <- I dont want this to compile!



      This compiles and runs as expected! Though, what if I dont want to enable slicing?



      What is the idomatic way to write foo such that one cannot slice instances of any derived class?










      share|improve this question
















      Sometimes it can be an annoyance that c++ defaults to allow slicing. For example



      #include <iostream>
      struct foo int a; ;
      struct bar : foo int b; ;

      int main()
      bar x1,2;
      foo y = x; // <- I dont want this to compile!



      This compiles and runs as expected! Though, what if I dont want to enable slicing?



      What is the idomatic way to write foo such that one cannot slice instances of any derived class?







      c++ inheritance object-slicing






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 6 hours ago









      rrauenza

      3,55921835




      3,55921835










      asked 9 hours ago









      user463035818user463035818

      18.8k42970




      18.8k42970






















          3 Answers
          3






          active

          oldest

          votes


















          12














          I'm not sure if there is a named idiom for it but you can add a deleted function to the overload set that is a better match then the base classes slicing operations. If you change foo to



          struct foo 

          int a;
          foo() = default; // you have to add this because of the template constructor

          template<typename T>
          foo(const T&) = delete; // error trying to copy anything but a foo

          template<typename T>
          foo& operator=(const T&) = delete; // error assigning anything else but a foo
          ;


          then you can only ever copy construct or copy assign a foo to foo. Any other type will pick the function template and you'll get an error about using a deleted function. This does mean that your class, and the classes that use it can no longer be an aggregate though. Since the members that are added are templates, they are not considered copy constructors or copy assignment operators so you'll get the default copy and move constructors and assignment operators.






          share|improve this answer

























          • Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

            – eerorika
            8 hours ago











          • if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

            – user463035818
            8 hours ago






          • 1





            @user463035818 Yep. I've been using it since I've asked that Q.

            – NathanOliver
            8 hours ago






          • 3





            I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

            – NathanOliver
            8 hours ago



















          4














          Since 2011, the idiomatic way has been to use auto:



          #include <iostream>
          struct foo int a; ;
          struct bar : foo int b; ;

          int main()
          bar x1,2;
          auto y = x; // <- y is a bar



          If you wish to actively prevent slicing, there are a number of ways:



          Usually the most preferable way, unless you specifically need inheritance (you often don't) is to use encapsulation:



          #include <iostream>

          struct foo int a; ;
          struct bar

          bar(int a, int b)
          : foo_(a)
          , b(b)


          int b;

          int get_a() const return foo_.a;

          private:
          foo foo_;
          ;

          int main()
          bar x1,2;
          // foo y = x; // <- does not compile




          Another more specialised way might be to alter the permissions around copy operators:



          #include <iostream>

          struct foo
          int a;
          protected:
          foo(foo const&) = default;
          foo(foo&&) = default;
          foo& operator=(foo const&) = default;
          foo& operator=(foo&&) = default;

          ;

          struct bar : foo

          bar(int a, int b)
          : fooa, bb


          int b;
          ;

          int main()
          auto x = bar (1,2);
          // foo y = x; // <- does not compile






          share|improve this answer






























            3














            You can prevent the base from being copied outside of member functions of derived classes and the base itself by declaring the copy constructor protected:



            struct foo 
            // ...
            protected:
            foo(foo&) = default;
            ;





            share|improve this answer


















            • 4





              but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

              – user463035818
              9 hours ago











            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55600025%2fidiomatic-way-to-prevent-slicing%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            3 Answers
            3






            active

            oldest

            votes








            3 Answers
            3






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            12














            I'm not sure if there is a named idiom for it but you can add a deleted function to the overload set that is a better match then the base classes slicing operations. If you change foo to



            struct foo 

            int a;
            foo() = default; // you have to add this because of the template constructor

            template<typename T>
            foo(const T&) = delete; // error trying to copy anything but a foo

            template<typename T>
            foo& operator=(const T&) = delete; // error assigning anything else but a foo
            ;


            then you can only ever copy construct or copy assign a foo to foo. Any other type will pick the function template and you'll get an error about using a deleted function. This does mean that your class, and the classes that use it can no longer be an aggregate though. Since the members that are added are templates, they are not considered copy constructors or copy assignment operators so you'll get the default copy and move constructors and assignment operators.






            share|improve this answer

























            • Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

              – eerorika
              8 hours ago











            • if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

              – user463035818
              8 hours ago






            • 1





              @user463035818 Yep. I've been using it since I've asked that Q.

              – NathanOliver
              8 hours ago






            • 3





              I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

              – NathanOliver
              8 hours ago
















            12














            I'm not sure if there is a named idiom for it but you can add a deleted function to the overload set that is a better match then the base classes slicing operations. If you change foo to



            struct foo 

            int a;
            foo() = default; // you have to add this because of the template constructor

            template<typename T>
            foo(const T&) = delete; // error trying to copy anything but a foo

            template<typename T>
            foo& operator=(const T&) = delete; // error assigning anything else but a foo
            ;


            then you can only ever copy construct or copy assign a foo to foo. Any other type will pick the function template and you'll get an error about using a deleted function. This does mean that your class, and the classes that use it can no longer be an aggregate though. Since the members that are added are templates, they are not considered copy constructors or copy assignment operators so you'll get the default copy and move constructors and assignment operators.






            share|improve this answer

























            • Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

              – eerorika
              8 hours ago











            • if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

              – user463035818
              8 hours ago






            • 1





              @user463035818 Yep. I've been using it since I've asked that Q.

              – NathanOliver
              8 hours ago






            • 3





              I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

              – NathanOliver
              8 hours ago














            12












            12








            12







            I'm not sure if there is a named idiom for it but you can add a deleted function to the overload set that is a better match then the base classes slicing operations. If you change foo to



            struct foo 

            int a;
            foo() = default; // you have to add this because of the template constructor

            template<typename T>
            foo(const T&) = delete; // error trying to copy anything but a foo

            template<typename T>
            foo& operator=(const T&) = delete; // error assigning anything else but a foo
            ;


            then you can only ever copy construct or copy assign a foo to foo. Any other type will pick the function template and you'll get an error about using a deleted function. This does mean that your class, and the classes that use it can no longer be an aggregate though. Since the members that are added are templates, they are not considered copy constructors or copy assignment operators so you'll get the default copy and move constructors and assignment operators.






            share|improve this answer















            I'm not sure if there is a named idiom for it but you can add a deleted function to the overload set that is a better match then the base classes slicing operations. If you change foo to



            struct foo 

            int a;
            foo() = default; // you have to add this because of the template constructor

            template<typename T>
            foo(const T&) = delete; // error trying to copy anything but a foo

            template<typename T>
            foo& operator=(const T&) = delete; // error assigning anything else but a foo
            ;


            then you can only ever copy construct or copy assign a foo to foo. Any other type will pick the function template and you'll get an error about using a deleted function. This does mean that your class, and the classes that use it can no longer be an aggregate though. Since the members that are added are templates, they are not considered copy constructors or copy assignment operators so you'll get the default copy and move constructors and assignment operators.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 9 hours ago

























            answered 9 hours ago









            NathanOliverNathanOliver

            98.5k16138218




            98.5k16138218












            • Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

              – eerorika
              8 hours ago











            • if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

              – user463035818
              8 hours ago






            • 1





              @user463035818 Yep. I've been using it since I've asked that Q.

              – NathanOliver
              8 hours ago






            • 3





              I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

              – NathanOliver
              8 hours ago


















            • Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

              – eerorika
              8 hours ago











            • if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

              – user463035818
              8 hours ago






            • 1





              @user463035818 Yep. I've been using it since I've asked that Q.

              – NathanOliver
              8 hours ago






            • 3





              I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

              – NathanOliver
              8 hours ago

















            Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

            – eerorika
            8 hours ago





            Note that this doesn't prevent explicit slicing like this: foo y = static_cast<foo&>(x);. That said, perhaps it's not a problem to OP.

            – eerorika
            8 hours ago













            if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

            – user463035818
            8 hours ago





            if I understand correctly this is a nice way to prevent implicit conversions for function parameters in general

            – user463035818
            8 hours ago




            1




            1





            @user463035818 Yep. I've been using it since I've asked that Q.

            – NathanOliver
            8 hours ago





            @user463035818 Yep. I've been using it since I've asked that Q.

            – NathanOliver
            8 hours ago




            3




            3





            I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

            – NathanOliver
            8 hours ago






            I look at it as reverse SFINAE. You make the overloads you want to compile, and then add a deleted template stopping everything else.

            – NathanOliver
            8 hours ago














            4














            Since 2011, the idiomatic way has been to use auto:



            #include <iostream>
            struct foo int a; ;
            struct bar : foo int b; ;

            int main()
            bar x1,2;
            auto y = x; // <- y is a bar



            If you wish to actively prevent slicing, there are a number of ways:



            Usually the most preferable way, unless you specifically need inheritance (you often don't) is to use encapsulation:



            #include <iostream>

            struct foo int a; ;
            struct bar

            bar(int a, int b)
            : foo_(a)
            , b(b)


            int b;

            int get_a() const return foo_.a;

            private:
            foo foo_;
            ;

            int main()
            bar x1,2;
            // foo y = x; // <- does not compile




            Another more specialised way might be to alter the permissions around copy operators:



            #include <iostream>

            struct foo
            int a;
            protected:
            foo(foo const&) = default;
            foo(foo&&) = default;
            foo& operator=(foo const&) = default;
            foo& operator=(foo&&) = default;

            ;

            struct bar : foo

            bar(int a, int b)
            : fooa, bb


            int b;
            ;

            int main()
            auto x = bar (1,2);
            // foo y = x; // <- does not compile






            share|improve this answer



























              4














              Since 2011, the idiomatic way has been to use auto:



              #include <iostream>
              struct foo int a; ;
              struct bar : foo int b; ;

              int main()
              bar x1,2;
              auto y = x; // <- y is a bar



              If you wish to actively prevent slicing, there are a number of ways:



              Usually the most preferable way, unless you specifically need inheritance (you often don't) is to use encapsulation:



              #include <iostream>

              struct foo int a; ;
              struct bar

              bar(int a, int b)
              : foo_(a)
              , b(b)


              int b;

              int get_a() const return foo_.a;

              private:
              foo foo_;
              ;

              int main()
              bar x1,2;
              // foo y = x; // <- does not compile




              Another more specialised way might be to alter the permissions around copy operators:



              #include <iostream>

              struct foo
              int a;
              protected:
              foo(foo const&) = default;
              foo(foo&&) = default;
              foo& operator=(foo const&) = default;
              foo& operator=(foo&&) = default;

              ;

              struct bar : foo

              bar(int a, int b)
              : fooa, bb


              int b;
              ;

              int main()
              auto x = bar (1,2);
              // foo y = x; // <- does not compile






              share|improve this answer

























                4












                4








                4







                Since 2011, the idiomatic way has been to use auto:



                #include <iostream>
                struct foo int a; ;
                struct bar : foo int b; ;

                int main()
                bar x1,2;
                auto y = x; // <- y is a bar



                If you wish to actively prevent slicing, there are a number of ways:



                Usually the most preferable way, unless you specifically need inheritance (you often don't) is to use encapsulation:



                #include <iostream>

                struct foo int a; ;
                struct bar

                bar(int a, int b)
                : foo_(a)
                , b(b)


                int b;

                int get_a() const return foo_.a;

                private:
                foo foo_;
                ;

                int main()
                bar x1,2;
                // foo y = x; // <- does not compile




                Another more specialised way might be to alter the permissions around copy operators:



                #include <iostream>

                struct foo
                int a;
                protected:
                foo(foo const&) = default;
                foo(foo&&) = default;
                foo& operator=(foo const&) = default;
                foo& operator=(foo&&) = default;

                ;

                struct bar : foo

                bar(int a, int b)
                : fooa, bb


                int b;
                ;

                int main()
                auto x = bar (1,2);
                // foo y = x; // <- does not compile






                share|improve this answer













                Since 2011, the idiomatic way has been to use auto:



                #include <iostream>
                struct foo int a; ;
                struct bar : foo int b; ;

                int main()
                bar x1,2;
                auto y = x; // <- y is a bar



                If you wish to actively prevent slicing, there are a number of ways:



                Usually the most preferable way, unless you specifically need inheritance (you often don't) is to use encapsulation:



                #include <iostream>

                struct foo int a; ;
                struct bar

                bar(int a, int b)
                : foo_(a)
                , b(b)


                int b;

                int get_a() const return foo_.a;

                private:
                foo foo_;
                ;

                int main()
                bar x1,2;
                // foo y = x; // <- does not compile




                Another more specialised way might be to alter the permissions around copy operators:



                #include <iostream>

                struct foo
                int a;
                protected:
                foo(foo const&) = default;
                foo(foo&&) = default;
                foo& operator=(foo const&) = default;
                foo& operator=(foo&&) = default;

                ;

                struct bar : foo

                bar(int a, int b)
                : fooa, bb


                int b;
                ;

                int main()
                auto x = bar (1,2);
                // foo y = x; // <- does not compile







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered 9 hours ago









                Richard HodgesRichard Hodges

                57k658105




                57k658105





















                    3














                    You can prevent the base from being copied outside of member functions of derived classes and the base itself by declaring the copy constructor protected:



                    struct foo 
                    // ...
                    protected:
                    foo(foo&) = default;
                    ;





                    share|improve this answer


















                    • 4





                      but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                      – user463035818
                      9 hours ago















                    3














                    You can prevent the base from being copied outside of member functions of derived classes and the base itself by declaring the copy constructor protected:



                    struct foo 
                    // ...
                    protected:
                    foo(foo&) = default;
                    ;





                    share|improve this answer


















                    • 4





                      but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                      – user463035818
                      9 hours ago













                    3












                    3








                    3







                    You can prevent the base from being copied outside of member functions of derived classes and the base itself by declaring the copy constructor protected:



                    struct foo 
                    // ...
                    protected:
                    foo(foo&) = default;
                    ;





                    share|improve this answer













                    You can prevent the base from being copied outside of member functions of derived classes and the base itself by declaring the copy constructor protected:



                    struct foo 
                    // ...
                    protected:
                    foo(foo&) = default;
                    ;






                    share|improve this answer












                    share|improve this answer



                    share|improve this answer










                    answered 9 hours ago









                    eerorikaeerorika

                    89.8k664136




                    89.8k664136







                    • 4





                      but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                      – user463035818
                      9 hours ago












                    • 4





                      but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                      – user463035818
                      9 hours ago







                    4




                    4





                    but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                    – user463035818
                    9 hours ago





                    but then I cannot copy foos anymore :( I'd like to prevent only copying a bar to a foo if possible

                    – user463035818
                    9 hours ago

















                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55600025%2fidiomatic-way-to-prevent-slicing%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    How to create a command for the “strange m” symbol in latex? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)How do you make your own symbol when Detexify fails?Writing bold small caps with mathpazo packageplus-minus symbol with parenthesis around the minus signGreek character in Beamer document titleHow to create dashed right arrow over symbol?Currency symbol: Turkish LiraDouble prec as a single symbol?Plus Sign Too Big; How to Call adfbullet?Is there a TeX macro for three-legged pi?How do I get my integral-like symbol to align like the integral?How to selectively substitute a letter with another symbol representing the same letterHow do I generate a less than symbol and vertical bar that are the same height?

                    Българска екзархия Съдържание История | Български екзарси | Вижте също | Външни препратки | Литература | Бележки | НавигацияУстав за управлението на българската екзархия. Цариград, 1870Слово на Ловешкия митрополит Иларион при откриването на Българския народен събор в Цариград на 23. II. 1870 г.Българската правда и гръцката кривда. От С. М. (= Софийски Мелетий). Цариград, 1872Предстоятели на Българската екзархияПодмененият ВеликденИнформационна агенция „Фокус“Димитър Ризов. Българите в техните исторически, етнографически и политически граници (Атлас съдържащ 40 карти). Berlin, Königliche Hoflithographie, Hof-Buch- und -Steindruckerei Wilhelm Greve, 1917Report of the International Commission to Inquire into the Causes and Conduct of the Balkan Wars

                    Чепеларе Съдържание География | История | Население | Спортни и природни забележителности | Културни и исторически обекти | Религии | Обществени институции | Известни личности | Редовни събития | Галерия | Източници | Литература | Външни препратки | Навигация41°43′23.99″ с. ш. 24°41′09.99″ и. д. / 41.723333° с. ш. 24.686111° и. д.*ЧепелареЧепеларски Linux fest 2002Начало на Зимен сезон 2005/06Национални хайдушки празници „Капитан Петко Войвода“Град ЧепелареЧепеларе – народният ски курортbgrod.orgwww.terranatura.hit.bgСправка за населението на гр. Исперих, общ. Исперих, обл. РазградМузей на родопския карстМузей на спорта и скитеЧепеларебългарскибългарскианглийскитукИстория на градаСки писти в ЧепелареВремето в ЧепелареРадио и телевизия в ЧепелареЧепеларе мами с родопски чар и добри пистиЕвтин туризъм и снежни атракции в ЧепелареМестоположениеИнформация и снимки от музея на родопския карст3D панорами от ЧепелареЧепелареррр